javascript的动态this与动态绑定 javascript是一门动态语言最明显就是那个dynamic this。它一般都是作为函数调用者存在。在javascript所有关系都可以作为对象的一个关联数组元素而存在。那么函数就是被掰成两部分储存于对象一是其函数名键一是函数体值那么函数中的this一般都指向函数所在的对象。但这是一般而已在全局调用函数时我们并没有看到调用者或者这时就是window。不过函数声明后其实并没有绑定到任何对象因此我们可以用call apply这些方法设置调用者。一个简单的例子window.name window;varrun function() {alert(My name is this.name);}run();运行代码这里你不能说run是作为window的一个属性而存在但它的确是被window属性调用了。实质上大多数暴露在最上层的东西都则window接管了。在它们需要调用时被拷贝到window这个对象上不过在IE中window并不继承对象于是有了window[xxx]与window.xxx性能上的差异。这是内部实现不深究了。另一个例子绑定到一个明确的对象上window.name window;object {name:object,run:function() {alert(My name is this.name);}};object.run();运行代码答案显然易见this总是为它的调用者。但如果复杂一点呢window.name window;object {name:object,run:function() {varinner function(){alert(My name is this.name);}inner();}};object.run();运行代码尽管它是定义在object内部尽管它是定义run函数内部但它弹出的既不是object也不是run因为它既不是object的属性也不是run的属性。它松散在存在于run的作用域用不能被前两者调用就只有被window拯救。window等原生对象浸透于在所有脚本的内部无孔不入只要哪里需要到它做贡献的地方它都义不容辞。但通常我们不需要它来帮倒忙这就需要奠出call与apply两大利器了。window.name window;varobject {name:object,run:function() {inner function() {alert(this.name);}inner.call(this);}}object.run();运行代码call与apply的区别在于第一个参数以后的参数的形式call是一个个aplly则都放到一个数组上在参数不明确的情况我们可以借助arguments与Array.slice轻松搞定。window.name Window;varcat {name:Cat};vardog {name:Dog,sound:function(word) {alert(this.name word);}};dog.sound( is pooping);dog.sound.call(window, is banking);dog.sound.call(dog, is banking);dog.sound.apply(cat, [ miaowing]);运行代码由此Prototype开发者搞了一个非常有名的函数出来bind!以下是它的一个最简单的版本varbind function(context, fn) {returnfunction() {returnfn.apply(context, arguments);}}

相关新闻

最新新闻

MatAnyone终极指南:基于一致性记忆传播的稳定视频抠像框架

MatAnyone终极指南:基于一致性记忆传播的稳定视频抠像框架

MatAnyone终极指南:基于一致性记忆传播的稳定视频抠像框架 【免费下载链接】MatAnyone [CVPR 2025] MatAnyone: Stable Video Matting with Consistent Memory Propagation 项目地址: https://gitcode.com/gh_mirrors/ma/MatAnyone 想要制作专业视频却苦于没…

2026/7/6 5:09:40
从零搭建SpringBoot微服务完整教程

从零搭建SpringBoot微服务完整教程

我从命令行里敲下mvn archetype:generate的那一刻,一个崭新的项目骨架在本地磁盘上徐徐展开。这不仅仅是Spring Boot的启动,更是一次关于“能力边界”的重新定义。从零搭建一个微服务,意味着你要在混沌中建立秩序,在空白处绘制蓝图…

2026/7/6 5:09:40
毕设分享 深度学习手写数字识别系统(源码+论文)

毕设分享 深度学习手写数字识别系统(源码+论文)

文章目录 0 前言1 项目运行效果2 深度学习手写字符识别原理2.1 结构解析2.2 C1层2.3 S2层S2层和C3层连接 2.4 F6与C5层 3 写数字识别算法模型的构建3.1 输入层设计3.2 激活函数的选取3.3 卷积层设计3.4 降采样层3.5 输出层设计 4 网络模型的总体结构5 部分实现代码6 最后 0 前言…

2026/7/6 5:09:40
高速PCB信号完整性设计:从100MHz到GHz的5个关键阻抗控制实战

高速PCB信号完整性设计:从100MHz到GHz的5个关键阻抗控制实战

高速PCB信号完整性设计:从100MHz到GHz的5个关键阻抗控制实战 随着数字电路速度的不断提升,信号完整性(SI)问题已成为高速PCB设计中最具挑战性的环节之一。当信号频率超过100MHz时,传输线效应、阻抗不连续和电磁干扰等问题会显著影响系统性能。…

2026/7/6 5:09:40
新手也能上手!2026年首选推荐的专业AI论文平台

新手也能上手!2026年首选推荐的专业AI论文平台

2026年AI论文写作工具已从“基础生成”进化为智能化学术辅助系统,功能覆盖从文献分析到格式排版的全流程。测评聚焦文献真实性、格式合规性、长文本逻辑、查重降重、AIGC合规等核心维度。本次测试涵盖6款主流工具,覆盖中英文写作、全流程与专项功能、免费…

2026/7/6 5:09:40
3D点云深度学习实战:从配准、分割到目标检测的完整学习路径

3D点云深度学习实战:从配准、分割到目标检测的完整学习路径

🚀 30款热门AI模型一站整合,DeepSeek/GLM/Qwen 随心用,限时 5 折。 👉 点击领海量免费额度 这次我们来看一套完整的3D点云学习资源。这套课程不是某个单一的模型或工具,而是一个面向AI、计算机视觉(CV&a…

2026/7/6 5:04:39

月新闻