underscore的bind和bindAll方法
bind方法和bindAll方法都是用来设定函数的this值的,区别是调用方式不同。
var xiaoming = { say:function(){ console.log('I am xiaoming'); } } //bind var func = bind(xiaoming, xiaoming.say); func(); // I am xiaoming //bindAll bindAll(xiaoming, 'say'); var func = xiaoming.say; func(); // I am xiaoming
bind和bindAll都是改变函数的this指向,然后返回一个新的函数,永久的指向这个this指向
举例
function Person(name,age){ this.name = name; this.age = age; bindAll(this, 'sayName', 'sayAge'); } Person.prototype.sayName = function(){ console.log(this.name); } Person.prototype.sayAge = function(){ console.log(this.age); } var person = new Person('xiaoming',26); var func = person.sayName; func(); $('button').click(person.sayAge);
无论如何调用,sayName和sayPerson的this都指向person对象。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2016-05-12 npm错误总结