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

简约的网站建设四川建设网学员中心

简约的网站建设,四川建设网学员中心,重庆宣传网站怎么做,网站 跳出率 多少目录 1.函数的call、apply、bind方法 1.1call、apply、bind的相同点 1.2call、apply、bind的不同点 1.3call、apply、bind的使用场景 2. 对象的深拷贝 2.1对象的浅拷贝 2.1对象的深拷贝 1.函数的call、apply、bind方法 1.1call、apply、bind的相同点 在没有传参数时&…

目录

1.函数的call、apply、bind方法 

1.1call、apply、bind的相同点

1.2call、apply、bind的不同点

1.3call、apply、bind的使用场景

2. 对象的深拷贝

2.1对象的浅拷贝

2.1对象的深拷贝


1.函数的call、apply、bind方法 

1.1call、apply、bind的相同点

  1. 在没有传参数时,三者的this指向都是window。
  2. 有参数时,第一个参数必须传,而且必须是对象类型,此时this指向已经改变为传过来的对象
      function show(a, b) {console.log(a, b);console.log(this);}show();//this是windowshow.call();//this是windowshow.apply();//this是windowvar fn = show.bind(); //有返回值,返回和原函数长得一样的新函数。可以show.bind()()调用 ,也可以fn()fn()//this是window

1.2call、apply、bind的不同点

  1. 调用方法:函数名.call();和 函数名.apply();调用方法一样,都是在后方加一个括号即可。而bind需要跟两个括号eg:函数名.bind()()
  2. 传参数的的形式不同:   函数名.call(对象,实参1,实参2);     函数名.apply(对象,[实参1,实参2]); 函数名.bind(对象,实参1,实参2)();  apply的第二个参数是以数组的形式来传递的。

1.3call、apply、bind的使用场景

  • call:借助构造函数实现继承
        <script>function Fatner(x, y) {this.x = x;this.y = y;}Fatner.prototype.say = function () {console.log('aaa');}function Son(x, y, z) {Fatner.call(this, x, y);console.log(this); //如果不回指则this指向Fatherthis.z = z;}Son.prototype.bbb = function () {console.log('bbb');}Son.prototypre = Object.create(Fatner.prototype); //将父的方法复制过来。Son.prototype.constructon = Son //进行回指操作,表示Son的构造器为Son。Son(1, 2, 3);</script>
  • apply: 求数组的最大值或最小值  
     var max = Math.max.apply(Math, [10, 20, 30, 40, 23]);console.log(max);
  •  bind:  在不调用函数的情况下,改变this的指向。
        <button>确定</button><script>var btn = document.querySelector('button');btn.addEventListener('click', function () {this.disabled = true;setTimeout(function () {this.disabled = false;}.bind(this), 1000)})</script>

2. 对象的深拷贝

        深浅拷贝最大的区别就是对一个对象进行修改,另一个会不会也被修改,如果两个对象同时进行了修改那就是进行了浅拷贝的操作,如果另一个没有发生改变,那就是进行了深拷贝的操作。数组和对象都有深浅拷贝的概念。

2.1对象的浅拷贝

可以利用 Object.assign()进行对象的浅拷贝操作。

    <script>obj = {name: 'zhangzhang',age: '20',arr: [12, 34, 765, [11, 55], {a: 'aaa',b: 'bbb'}]}var obj1 = Object.assign(obj);obj.name = 'lili';obj1.arr[3][0] = 88;console.log(obj1, obj);</script>

2.1对象的深拷贝

对象的深拷贝有三种方式

     (1)使用JSON.stringify() 和JSON.parse()将对象先转成JSON格式,再转回来就完成了深拷贝的操作。

var obj1= JSON.parse(JSON.stringify(obj) )

     (2)Lodash  官网,直接引用一个js文件过来,然后用里面的var obj1= _.cloneDeep(obj);

    <script src="https://cdn.bootcdn.net/ajax/libs/lodash.js/4.17.21/lodash.js"></script> <script>obj = {name: 'zhangzhang',age: '20',arr: [12, 34, 765, [11, 55], {a: 'aaa',b: 'bbb'}]}var obj2 = _.cloneDeep(obj);obj.name = 'lili';obj2.arr[3][0] = 88;console.log(obj2, obj);</script>

      (3用递归来完成(原生方法)

    <script>obj = {name: 'zhangzhang',age: '20',arr: [12, 34, 765, [11, 55], {a: 'aaa',b: 'bbb'}]}function copy(obj) {if (typeof obj != 'object') {return obj;}var newobj = obj instanceof Array ? [] : {};for (var k in obj) {newobj[k] = copy(obj[k])}return newobj;}var obj3 = copy(obj);obj.name = 'lili';obj3.arr[3][0] = 88;console.log(obj3, obj);</script>

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

相关文章:

  • 网站通栏校园网站建设 方案论证
  • 网站服务内容那家公司装修比较好
  • 郴州网站制作找工作wordpress带手机验证码
  • 如何设计营销 网站建设nas怎么做网站服务器
  • 网站集约化建设的通知中国建设银行中国网站
  • 动易网站管理系统上海外贸公司招聘职位
  • 那些市区做网站群在线购物商城的设计与实现
  • 做同性恋的珠宝网站网站搭建技术要求
  • 号网站开发小制作小发明手工五年级
  • 佛山市锵美装饰有限公司网站建设案例智能科技网站模板
  • 网站制作是怎样做的北京到石家庄
  • 安装网站程序的流程阿克苏网站开发
  • 做企业内部管理网站要多久网络推广公司成都
  • 怎么建网站模版wordpress前端地址
  • 2008r2做网站奖券世界推广网站
  • 网站访问统计报告模板上海大学生兼职做网站
  • 能下短视频网站做牙中国建设招标工程网站
  • 网站开发checklist自己做网站要买服务器吗
  • 泰安八戒电子商务有限公司郑州seo使用教程
  • 南京有哪些做网站的公司南昌如何做百度的网站
  • 专业返利网站开发一个叫mit做app的网站
  • 源汇区建设局网站怎么用家里的电脑做网站服务器
  • 一个网站做数据分析要多少钱制作网站深圳
  • 石柱网站制作小网站做几个关键词
  • 山东省建设备案在哪个网站网站 必须有的功能
  • 深圳建设银行宝安支行网站网站建设方案免费下载
  • 昆明网站seo上海 建设工程质量监督站网站
  • 资源站源码永久如何给一个网站做压测
  • 怎么做整人点不完的网站wordpress文章版权声明
  • 网站网页设计哪个好网站怎么做要多少钱