ES6学习模板字符串、解构赋值(三)

这里写目录标题

一、模板字符串

ES6模板字符串用反引号 `` 标识,${}这样的方式简化了字符串中嵌入变量的写法。

js 复制代码
           const oBox = document.querySelector('.box');
            let text = "hello,es6!";
            //传统写法
            //let htmlTel = "<p>" + text + "</p>";
            //模板字符串写法
            let htmlTel = `<p>${text}</p>`;
            oBox.innerHTML = htmlTel;

二、解构赋值

解构赋值是对赋值运算符的一种扩展,通常是针对数组和对象进行操作。优点是使得代码书写简洁易读性高。

2.1、数组解构

在以前,为变量赋值,只能直接指定值

js 复制代码
            let a=1;
            let b=2;
            let c=3;

ES6允许我们这样写:

js 复制代码
         let [a,b,c]=[1,2,3];

如果解构不成功,变量的值就等于undefined,例如:

js 复制代码
	let [a,b,c,d]=[1,2,3];

2.2、对象解构

js 复制代码
          let book={
                name:'ES入门学习',
                price:'20.99'
            }
            let{name,price}=book;

对象的解构赋值时,可以对属性忽略和使用剩余运算符

js 复制代码
            let obj = {
                a: {
                    name: '张三'
                },
                b: [],
                c: 'hello world'
            }
            //可忽略 忽略b,c属性
            let {a} = obj;
            console.log(a);

2.3、函数参数解构

js 复制代码
        function demo([x,y]) {
            return x+y;
        }    
        console.log(demo([1,3]));

2.4、解构用途

2.4.1、交换变量值

js 复制代码
            let a=2;
            let b=5;
            [a,b]=[b,a];

上面代码交换变量a和b的值,这样的写法简单易读,但是要注意变量重复声明问题。

2.4.2、从函数返回多个值

函数只能返回一个值,如果要返回多个值,只能将它们放在数组或对象里返回。有了解构赋值,取出这些值就非常方便。

js 复制代码
        function demo() {
            return [1,2,3]
        } 
        let [a,b,c]=demo();

2.4.3、提取JSON数据

解构赋值对提取 JSON 对象中的数据,尤其有用

js 复制代码
            let jsonData = {
                id: 42,
                status: "OK",
                data: [867, 5309]
            };
            let { id, status, data: number } = jsonData;
            console.log(id, status, number);
相关推荐
魔法阵维护师25 分钟前
从零开发游戏需要学习的c#模块,第三十四章(设置界面)
学习·游戏·c#
এ慕ོ冬℘゜29 分钟前
手写生产级 jQuery Toast 轻量提示组件|零插件依赖、动画流畅、极简高
前端·javascript·jquery
FserSuN1 小时前
Machine Learning Specialization - Week 1, 9-20学习总结
人工智能·学习·机器学习
大家的林语冰1 小时前
Express 团队官宣:全新网站正式上线,Logo 重做,支持两个主版本文档无缝切换!
javascript·node.js·express
OBiO20131 小时前
肺部靶向 AAV 怎么选?如何解决靶向不精准、转导效率低的递送难题?
学习
我命由我123451 小时前
UGC、PGC、PUGC 极简理解
经验分享·笔记·学习·职场和发展·求职招聘·职场发展·学习方法
七老板的blog2 小时前
【Agent智能体】 任务规划工作流
python·学习·ai·开源
时寒的笔记2 小时前
LF11期_day19~20 补环境(二)入门案例
javascript
海鸥-w2 小时前
前端学习python第二天手敲笔记整理
前端·python·学习
爱吃提升2 小时前
Figma 组件库搭建清单(含命名规范+常用组件模板)
前端·javascript·figma