当前位置: 首页 > news >正文

铁道部售票网站多少钱建设国内十大4a广告公司

铁道部售票网站多少钱建设,国内十大4a广告公司,天津基础设施建设,个人网站源代码html一、Rest 参数与 Spread 语法 1.rest参数 ...变量名:收集剩余的参数并存进指定数组中,需要放到最后; 2.arguments变量 // arguments,以参数在参数列表中的索引作为键,存储所有参数,以类数组对象的形式输出所有函数参数 // 箭头…

一、Rest 参数与 Spread 语法

1.rest参数

...变量名:收集剩余的参数并存进指定数组中,需要放到最后;

2.arguments变量

        // arguments,以参数在参数列表中的索引作为键,存储所有参数,以类数组对象的形式输出所有函数参数

        // 箭头函数没有arguments和this对象,会去上级函数找,没有上级函数就报错

        function fn3(a, b, ...c) {

            console.log(arguments);

            console.log(Array.from(arguments)); // 转为数组

        }

        fn3(1, 2, 3, 4, 5, 6);

3.Spread 语法

使用...,把任意可迭代对象“展开”到参数列表中

        // 可传入多个可迭代对象

        const arr2 = [9, 77, 85, 12, 33];

        console.log(Math.max(...arr, ...arr2)); // 85

        // 可以与常规值结合使用

        console.log(Math.max(1, ...arr, 2, ...arr2, 25)); //85

        // 合并数组

        let sumArr = [0, ...arr, ...arr2];

        // 常用的复制数组方法

        let arr4 = [...arr];

使用 spread 语法将任意可迭代对象转换为字符数组

        let str = "Hello";

        console.log([...str]);  // ['H', 'e', 'l', 'l', 'o']

        let s = new Set();

        s.add("css").add("html");

        console.log([...s]);  // ['css', 'html']

        let m = new Map();

        m.set("name", "jack").set("age", 20)

        console.log([...m]);  // [Array(2), Array(2)]

4.浅复制/深复制

浅复制:

        // “001” => ["a","b","c"];// const arr = [1, "001", 2, 3];const arr = [1, ["a", "b", "c"], 2, 3];// 浅复制,修改一个影响到另一个const newArr = [...arr]; // [1, "001", 2, 3]; newArr[1][0] = "X";console.log(arr);//[1, ['X', 'b', 'c'], 2, 3]

深复制方法一:

        // “001” => ["a","b","c"];// const arr = [1, "001", 2, 3];const arr = [1, ["a", "b", "c"], 2, 3];// 深复制,修改一个不会影响到另一个const newArr = JSON.parse(JSON.stringify(arr)); // [1, "001", 2, 3];newArr[1][0] = "X";console.log(newArr);  //[1, ['X', 'b', 'c'], 2, 3]console.log(arr);  //[1, ['a', 'b', 'c'], 2, 3]

 方法二方法三:

 <script src="../../../lodash.min.js"></script><script>//  深度复制复杂对象 (面试题)const o1 = { a: undefined, b: function () { }, list: [1, 2, 3] };// 方法一:JSON.parse(JSON.stringify(o1)),无法复制复杂的// 方法二:递归深度赋值Object.entries(o1).forEach((el) => {if (Array.isArray(el[1])) {newObj[el[0]] = [];el[1].forEach((elx) => {newObj[el[0]].push(elx);});} else {newObj[el[0]] = el[1];}});// 方法三:第三方代码,引用js文件后,使用里面规定的代码实现const newObj = _.cloneDeep(o1);console.log(newObj)

二、变量作用域,闭包

1.代码块

如果在代码块 {...} 内声明了一个变量,那么这个变量只在该代码块内可见。

对于 iffor 和 while 等,在 {...} 中声明的变量也仅在内部可见。

let i 位于 {...} 之外。但是 for 构造很特殊:在其中声明的变量被视为块的一部分。

2.嵌套函数(重要)

 如果一个函数是在另一个函数中创建的,该函数就被称为“嵌套”函数。

function makeCounter() {let count = 0;return function() {return count++;};
}let counter = makeCounter();alert( counter() ); // 0
alert( counter() ); // 1

http://www.yayakq.cn/news/222507/

相关文章:

  • 公司网站建设优点wordpress建商城
  • 九江建网站多少钱wordpress 2m带宽 支持多少人
  • 安徽省建设厅网站电话微信社群运营主要是做什么的
  • 广州网站建设支付1920网页设计尺寸规范
  • 做网站心得国外做内容网站
  • 青岛正规网站设计公司尚普咨询市场调研公司
  • 效果好的网站建济南营销网站建设
  • 如何做汽车的创意视频网站会计网站模板
  • 南京网站设计ui百度app下载安装普通下载
  • 中国网站的特点适合网站开发的框架
  • 揭阳制作公司网站wordpress 父级页面
  • 做交互的设计网站成品播放器
  • 凡科网站模块兖州网站建设哪家便宜
  • 做一个网站成本要多少钱wordpress 全局广告
  • 全景网站如何做没公司怎么做网站
  • 可以做视频推广的网站吗烟台企业展厅设计
  • 如何优化网站 提高排名家具设计软件有哪些软件
  • 网站搭建计划书深圳建设一个网站制作公司
  • 实搜网站建设东莞公司网站建设公司
  • 网站建设面谈销售话术重庆艺术字体设计
  • 做网站该读啥学校单页设计风格
  • 网站域名到期怎么回事网站加速
  • 赶集的网站怎么做dede淘宝客网站
  • 网站建设单选按钮男女性男女直接做的视频网站
  • 网站mp3播放器代码临沂专业做网站公司
  • 怎么做网站页面模板厦门市建设与管理局
  • 化妆品应如何网站建设定位wordpress 注册函数
  • 营销型网站设计方针wordpress账号交易
  • 公司网站微信推广wordpress no.7高级版
  • 酒店网站建设公司排名济南代理公司注册