深入bind
栏目: JavaScript · 发布时间: 5年前
内容简介:今天来聊聊我们要明确4点内容遵循以上4点
今天来聊聊 bind 关于之前的call跟apply 查看此链接
我们要明确4点内容
1. bind之后返回一个函数
let obj = { name : 'skr' } function fn(){ console.log(this) } let bindfn = fn.bind(obj) console.log(typeof bindfn) // function
2.bind改变this 并且可以传参 bind之后的函数仍旧可以传参
let obj = { name : 'skr' } function fn(){ console.log(arguments,this) } let bindfn = fn.bind(obj,'陈','孙','李') bindfn('张三李四') //[Arguments] { '0': '陈', '1': '孙', '2': '李', '3': '张三李四' },{ name: 'skr' }
3.bind之后的函数做为构造函数执行,this是作为新的一个引用
let obj = { name : 'skr' } function fn(name){ this.name = name console.log(this) //{ name: '坤坤' } console.log(obj) //{ name: 'skr' } } let bindfn = fn.bind(obj) let obj2 = new bindfn('坤坤')
4 作为构造函数时候 在原型上添加属性 实例能找到这个属性
let obj = { name : 'skr' } function fn(name){ this.name = name console.log(this) //{ name: '坤坤' } console.log(obj) //{ name: 'skr' } } let bindfn = fn.bind(obj) let obj2 = new bindfn('坤坤') fn.prototype.arrt = '小生' console.log(obj2.arrt) // 小生
实现一个bind
遵循以上4点
- bind之后返回一个函数
Function.prototype.bind = function(){ return function(){ // 代码省略 } }
- bind改变this 并且可以传参 bind之后的函数仍旧可以传参
Function.prototype.bind = function(context){ let _this = this let args = Array.prototype.slice.call(arguments,1) // 保存外部函数的参数 return function(){ return _this.apply(context,args.concat(Array.from(arguments))) // 链接内部函数参数 } } let obj = { name :"1" } function a(){ console.log(this,arguments) } a.bind(obj,1,2,3,4,5,6)(7,8,9) /* 打印结果: { name: '1' } [Arguments] { '0': 1, '1': 2, '2': 3, '3': 4, '4': 5, '5': 6, '6': 7, '7': 8, '8': 9 } */
- bind之后的函数做为构造函数执行,this是作为新的一个引用
Function.prototype.bind = function(context){ let _this = this let args = Array.prototype.slice.call(arguments,1) // 保存外部函数的参数 let fn2 = function(){ return _this.apply(this instanceof fn2 ? this:context ,args.concat(Array.from(arguments))) // 看看是否是new 出来的 是new的话就不改变this } return fn2 } let obj = { name :"1" } function a(name){ this.name = name console.log(this) } let bindfn = a.bind(obj) let obj2 = new bindfn('2') // {name:'2'} console.log(obj) // {name:'1'}
- 作为构造函数时候 在原型上添加属性 实例能找到这个属性
Function.prototype.bind = function(context){ let _this = this let args = Array.prototype.slice.call(arguments,1) // 保存外部函数的参数 function ConS(){} let fn2 = function(){ return _this.apply(this instanceof fn2 ? this:context ,args.concat(Array.from(arguments))) // 看看是否是new 出来的 是new的话就不改变this } console.log(this) ConS.prototype = this.prototype // 通过第三方 new ConS().__proto__ === this.prototype fn2.prototype = new ConS() // new fn2().__proto__ === new ConS() ---> new fn2().__proto__.__proto__ === this.prototype 从而拿到this实例上的原型属性和方法 return fn2 } let obj = { name :"1" } function a(name){ this.name = name console.log(this) } let bindfn = a.bind(obj) let obj2 = new bindfn('2') // {name:'2'} console.log(obj2) // {name:'1'}
大致上就是这样了
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 【1】JavaScript 基础深入——数据类型深入理解与总结
- 深入理解 Java 函数式编程,第 5 部分: 深入解析 Monad
- 深入理解 HTTPS
- 深入理解 HTTPS
- 深入浅出Disruptor
- 深入了解 JSONP
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
博客秘诀:超人气博客是怎样炼成的
Darren Rowse、Chris Garrett / 向怡宁 / 人民邮电出版社 / 201005 / 39.00元
作为Web 2.0的新生事物的博客,如今已蓬勃发展,呈燎原之势,业已成为许多人的一种生活方式。中国从事博客写作的人数已达千万级,各类博客网站不可胜数。 然而,为什么有的博客人气鼎盛,拥趸众多,有的博客却门前冷落,少人问津呢?究竟应该怎样写好自己的博客,才能让它吸引更多访客的关注呢?博客网站还能为我做什么呢? 本书的两位作者长期主持知名博客站点ProBlogger.net,指导了成千上万......一起来看看 《博客秘诀:超人气博客是怎样炼成的》 这本书的介绍吧!