javascript中this什么意思

this的中文意思为“当前;这个”,是javascript中的一个指针型变量,它指向当前函数的运行环境。在不同的场景中调用同一个函数,this的指向会发生变化,但它永远指向其所在函数的真实调用者;如果没有调用者,this就指向window。

javascript中this什么意思

本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

JavaScript 函数的作用域是静态的,但是函数的调用却是动态的。由于函数可以在不同的运行环境内执行,因此 JavaScript 在函数体内定义了 this 关键字,用来获取当前的运行环境。

this 是一个指针型变量,它指向当前函数的运行环境。

在不同的场景中调用同一个函数,this的指向也可能会发生变化,但是它永远指向其所在函数的真实调用者(谁调用就指向谁);如果没有调用者,this就指向全局对象window。

立即学习“Java免费学习笔记(深入)”;

使用 this

this 是由 JavaScript 引擎在执行函数时自动生成的,存在于函数内的一个动态指针,指代当前调用对象。具体用法如下:

this[.属性]

登录后复制

如果 this 未包含属性,则传递的是当前对象。

this 用法灵活,其包含的值也是变化多端。例如,下面示例使用 call() 方法不断改变函数内 this 指代对象。

var x = "window";  //定义全局变量x,初始化字符串为“window”function a () {  //定义构造函数a    this.x = "a";  //定义私有属性x,初始化字符a}function b () {  //定义构造函数b    this.x = "b";  //定义私有属性x,初始化为字符b}function c () {  //定义普通函数,提示变量x的值    console.log(x);}function f () {  //定义普通函数,提示this包含的x的值    console.log(this.x);}f();  //返回字符串“window”,this指向window对象f.call(window);  //返回字符串“window”,指向window对象f.call(new a());  //返回字符a,this指向函数a的实例f.call(new b());  //返回字符b,this指向函数b的实例f.call(c);  //返回undefined,this指向函数c对象

登录后复制

下面简单总结 this 在 5 种常用场景中的表现以及应对策略。

1. 普通调用

下面示例演示了函数引用和函数调用对 this 的影响。

var obj = {  //父对象    name : "父对象obj",    func : function () {        return this;    }}obj.sub_obj = {  //子对象    name : "子对象sub_obj",    func : obj.func}var who = obj.sub_obj.func();console.log(who.name);  //返回“子对象sub_obj”,说明this代表sub_obj

登录后复制

如果把子对象 sub_obj 的 func 改为函数调用。

obj.sub_obj = {    name : "子对象sub_obj",    func : obj.func()  //调用父对象obj的方法func}

登录后复制

则函数中的 this 所代表的是定义函数时所在的父对象 obj。

var who = obj.sub_obj.func;console.log(who.name);  //返回“父对象obj”,说明this代表父对象obj

登录后复制

2. 实例化

使用 new 命令调用函数时,this 总是指代实例对象。

var obj = {};obj.func = function () {    if (this == obj) console.log("this = obj");    else if (this == window) console.log("this = window");    else if (this.contructor == arguments.callee) console.log("this = 实例对象");}new obj.func;  //实例化

登录后复制

3. 动态调用

使用 call 和 apply 可以强制改变 this,使其指向参数对象。

function func () {    //如果this的构造函数等于当前函数,则表示this为实例对象    if (this.contructor == arguments.callee) console.log("this = 实例对象");    //如果this等于window,则表示this为window对象    else if (this == window) console.log("this = window对象");    //如果this为其他对象,则表示this为其他对象    else console.log("this == 其他对象  this.constructor =" + this.constructor);}func();  //this指向window对象new func();  //this指向实例对象cunc.call(1);  //this指向数值对象

登录后复制

在上面示例中,直接调用 func() 时,this 代表 window 对象。当使用 new 命令调用函数时,将创建一个新的实例对象,this 就指向这个新创建的实例对象。

使用 call() 方法执行函数 func() 时,由于 call() 方法的参数值为数字 1,则 JavaScript 引擎会把数字 1 强制封装为数值对象,此时 this 就会指向这个数值对象。

4. 事件处理

在事件处理函数汇总,this 总是指向触发该事件的对象。

    var button = document.getElementsByTagName("put")[0];    var obj = {};    obj.func = function () {        if (this == obj) console.log("this = obj");        if (this == window) console.log("this = window");        if (this == button) console.log("this = button");    }    button.onclick = obj.func;

登录后复制

在上面代码中,func() 所包含的 this 不再指向对象 obj,而是指向按钮 button,因为 func() 是被传递给按钮的事件处理函数之后才被调用执行的。

如果使用 DOM2 级标准注册事件处理函数,程序如下:

if (window.attachEvent) {  //兼容IE模型    button.attachEvent("onclick", obj.func);} else {  //兼容DOM标准模型    button.addEventListener("click", obj.func, true);}

登录后复制

在 IE 浏览器中,this 指向 window 对象和 button 对象,而在 DOM 标准的浏览器中仅指向 button 对象。因为,在 IE 浏览器中,attachEvent() 是 window 对象的方法,调用该方法时,this 会指向 window 对象。

为了解决浏览器兼容性问题,可以调用 call() 或 apply() 方法强制在对象 obj 身上执行方法 func(),避免出现不同的浏览器对 this 解析不同的问题。

if (window.attachEvent) {    button.attachEvent("onclick", function () {  //用闭包封装call()方法强制执行func()        obj.func.call(obj);    });} else {    button.attachEventListener("onclick", function () {        obj.func.call(obj);    }, true);}

登录后复制

当再次执行时,func() 中包含的 this 始终指向对象 obj。

5. 定时器

使用定时器调用函数。

var obj = {};obj.func = function () {    if (this == obj) console.log("this = obj");    else if (this == window) console.log("this = window对象");    else if (this.constructor == arguments.callee) console.log("this = 实例对象");    else console.log("this == 其他对象  this.constructor =" + this.constructor);}setTimeOut(obj.func, 100);

登录后复制

在 IE 中 this 指向 window 对象和 button 对象,具体原因与上面讲解的 attachEvent() 方法相同。在符合 DOM 标准的浏览器中,this 指向 window 对象,而不是 button 对象。

因为方法 setTimeOut() 是在全局作用域中被执行的,所以 this 指向 window 对象。要解决浏览器兼容性问题,可以使用 call 或 apply 方法来实现。

setTimeOut (function () {    obj.func.call(obj);}, 100);

登录后复制

【相关推荐:javascript学习教程

以上就是javascript中this什么意思的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2948759.html

(0)
上一篇 2025年3月11日 23:11:38
下一篇 2025年3月8日 08:34:07

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • javascript是编译语言吗

    javascript不是编译型语言,而是解释型的编程语言。javascript源代码在发往客户端运行之前不需经过编译,而是将文本格式的字符代码发送给浏览器由浏览器解释运行。 本教程操作环境:windows7系统、javascript1.8.…

    2025年3月11日
    200
  • javascript中for in语句怎么用

    在javascript中,“for in”语句是for语句的一种特殊形式,用于遍历数组或者对象的属性,即对数组或者对象的属性进行循环操作;语法格式“for (变量 in 对象){在此执行代码}”。 本教程操作环境:windows7系统、ja…

    2025年3月11日
    200
  • HTML引入外部javascript是什么属性

    HTML引入外部javascript是script标签的src属性,该属性规定外部脚本文件的URL;语法“”。 本教程操作环境:windows7系统、HTML5&&javascript1.8.5版、Dell G3电脑。 HT…

    2025年3月11日
    200
  • JavaScript的3种注释写法为什么

    JavaScript的3种注释写法:1、多行注释,语法“/* 要注释的内容 */”;2、单行注释,语法“// 要注释的内容”;3、“ 本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。 JavaSc…

    2025年3月11日
    200
  • javascript算后端么

    javascript不算后端,是前端开发语言,是一种动态类型、弱类型、基于原型的语言;javascript经常与html、css技术一起构成前端开发;javascript一般通过ajax与后台进行数据交互。 本文操作环境:windows7系…

    2025年3月11日
    200
  • html中js是什么

    在html中,js全称JavaScript,是面向Web的编程语言,是一种属于网络的脚本语言,被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果。 本教程操作环境:windows7系统、HTML5&…

    2025年3月11日
    200
  • javascript最初是为了实现什么

    javascript最初是为了实现“网页更生动”,javascript这种编程语言写出来的程序被称为“脚本”,它们可以被直接写在网页的HTML中,在页面加载的时候自动执行;脚本被以纯文本的形式提供和执行,它们不需要特殊的准备或编译即可运行。…

    2025年3月11日
    200
  • javascript中方法和函数是什么

    在javascript中,函数是可以执行的javascript代码块,需要通过名字来进行调用;而方法是通过对象调用的javascript函数,即方法是比较特殊的函数。 本教程操作环境:windows7系统、javascript1.8.5版、…

    2025年3月11日
    200
  • javascript语法是什么

    JavaScript语法是一套规则,它定义了JavaScript的语言结构;而JavaScript就是一个脚本语言,也是一个轻量级,但功能强大的编程语言。 本文操作环境:windows7系统、javascript1.8.5版、Dell G3…

    2025年3月11日
    200
  • javascript最后怎么表示

    javascript最后可以用分号表示,但是分号加与不加完全取决于个人习惯,不过为了代码稳定,还是建议使用分号断句。 本文操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。 javascript最后怎么表…

    2025年3月11日
    200

发表回复

登录后才能评论