zoukankan      html  css  js  c++  java
  • JavaScript

    JS this 关键字

    • 面向对象语言中 this 表是当前对象的一个引用
    • 但是,在 JS 环境中 this 不是固定不变的,它会随着执行环境的改变而改变
      • 在方法中,this 表示该方法所属的对象
      • 单独使用,this 表示全局对象
      • 在函数中,this 表示全局对象
      • 在函数中,严格模式下,this 是未定义的(undefined)
      • 在事件中,this 表示接收事件的元素
      • 类似 call() 和 apply() 方法可以将 this 引用到任何对象

    实例:

    var person = {
        firstName:"John",
        lastName:"Doe",
        id:555,
        fullName:function() {
            return this.firsstName + " " + this.lastName;
        }
    };
    // 这里的 this 用在方法中,表示该方法所属的对象 person
    

    方法中的 this

    • 在对象方法中,this 指向调用它所在的方法的对象
    • 在以上实例中,this 表示 person 对象
    • fullName 方法所属的对象就是 person
    fullName:function() {
        return this.firstName + " " + this.lastName;
    }
    

    单独使用 this

    • 单独使用 this,则指向全局(Global)对象
    • 在浏览器中,window 就是该全局对象 [object Window]
    var x = this;
    
    • 在严格模式下,如果单独使用,this 也是指向全局(Global)对象
    "use strict"
    var x = this;
    

    函数中使用 this(默认)

    • 在函数中,函数的所属者默认绑定到 this 上
    • 在浏览器中,window 就是该全局对象 [object Window]
    function myFunction() {
        return this;
    }
    

    函数中使用 this(严格模式下)

    • 严格模式下,函数是没有绑定到 this 上的,这时候 this 是 undefined
    "use strict"
    function myFunction() {
        return this;
    }
    

    事件中的 this

    • 在 HTML 事件的句柄中,this 指向了接收事件的 HTML 元素
    • 以下 this 指向的是接收 onclick 事件的 button 元素
    <button onclick="this.style.display='none'">
        点我后我就消失了
    </button>
    

    对象方法中绑定

    • 下面实例中,this 是 person 对象,person 对象是函数的所有者:
    var person = {
        firstName:"John",
        lastName:"Doe",
        id:555,
        myFunction:function() {
            return this;	// this 指向了 fullName 方法所属的对象 person
        }
    }
    

    显示函数绑定

    • 在 JS 中,函数也是对象,对象则有方法,apply 和 call 就是函数对象的方法
    • 这两个方法异常强大,他们允许切换函数执行的上下文环境(context),即 this 绑定的对象
    • 在下面的实例中,当我们使用 person2 作为参数来调用 person1.fullName 方法时,this 将指向 pereson2,即便它是 person1 的方法
    var person1 = {
        fullName:function() {
            return this.firstName + " " + lastName;
        }
    };
    var person2 = {
        firstName:"John",
        lastName:"Doe",
    }
    person1.fullName.call(person2);	// 返回 "John Doe"
    
  • 相关阅读:
    普通文本(.txt)篇章排版样式参考 [文档说明][日志]
    C++基础练习案例
    Markdown 编写技巧汇总(二)
    Markdown 编写技巧汇总(一)
    有关C++程序设计基础的各种考题解答参考汇总
    有关算法与数据结构的考题解答参考汇总 [C++] [链表] · 第三篇
    有关算法与数据结构的考题解答参考汇总 [C++] [链表] · 第二篇
    有关算法与数据结构的考题解答参考汇总 [C++] [链表]
    DOS批处理小案例应用分享
    基于Processing图像序列处理保存导出的流程梳理
  • 原文地址:https://www.cnblogs.com/xdy-/p/13544312.html
Copyright © 2011-2022 走看看