js中this的指向问题归纳总结

绝大部分的新手,在学习JavaScript时都会遇到一个非常常见的问题:无法理解 this 的指向问题。这也是Javascript的一个复杂和有争议性的部分,本攻略旨在帮助读者归纳总结“js中this的指向问题”。

什么是 this

this 是 JavaScript 中的一个关键字,它是一个对象,并且它是由函数来调用的。this 的值在每个函数调用的时候都可能发生变化,具体的指向对象取决于函数的调用方式。

this 的指向问题

在JavaScript中,this 的指向可以分成以下四种情况:

  1. 全局上下文中的this

当函数不作为对象的方法调用时,this 指向全局对象 window。

javascript
console.log(this); // window

  1. 对象方法中的this

当一个函数作为对象的方法被调用时,this会指向该对象。

javascript
var obj = {
name: 'John',
age: 20,
sayName: function(){
console.log(this.name); // John
}
}
obj.sayName();

  1. 构造函数中的 this

在构造函数中,this 指向新创建的对象。

javascript
function Person(name, age){
this.name = name;
this.age = age;
}
var john = new Person('John', 20);
console.log(john.name); // John

  1. 使用 call()、apply()、bind() 显式指定this

call()、apply()、bind() 方法可以显式的指定函数执行时 this 的指向:

```javascript
function sayHello() {
console.log('Hello, ' + this.name);
}

var person = {
name: 'John'
};

sayHello.call(person); // 输出 "Hello, John"
sayHello.apply(person); // 输出 "Hello, John"

var bindedFunction = sayHello.bind(person);
bindedFunction(); // 输出 "Hello, John"
```

总结

本攻略详细总结了JavaScript中this的指向问题,从全局上下文、对象方法、构造函数以及显式指向的角度全面讲解了this的使用方法。对于想要精通JavaScript编程的开发人员来说,理解和掌握this的指向问题是非常重要的。

示例说明

示例一:

var obj = {
    name: 'John',
    age: 20,
    sayName: function() {
        console.log(this.name);
    }
};
obj.sayName(); // John

在这个示例中,this 指向 obj 对象,因此 sayName() 方法被执行时,会输出对象 obj 的属性 name 的值 "John"。

示例二:

function sayHello() {
    console.log('Hello, ' + this.name);
}

var person = {
    name: 'John'
};

var bindedFunction = sayHello.bind(person);
bindedFunction(); // 输出 "Hello, John"

在这个示例中,使用 bind() 方法显式地将函数 sayHello() 绑定到 person 对象上。因此,bindedFunction() 函数被调用时,this 指向了 person 对象,输出 "Hello, John"。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:js中this的指向问题归纳总结 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • JS 中可以提升幸福度的小技巧(可以识别更多另类写法)

    当谈到 JavaScript 的小技巧时,常见的技巧有短路求值、三元表达式等。但本文将介绍更多不常见的技巧,可以提高编码效率,减少代码量。 1. 使用 null 判断空值 当需要判断一个变量是否为空值时,我们通常会采用如下方式: if (x === ” || x === null || x === undefined) { // do something …

    JavaScript 2023年6月10日
    00
  • JS面向对象之多选框实现

    JS面向对象之多选框实现是一个比较基础的JavaScript面向对象应用,它的实现过程也相对简单,下面我将为大家详细讲解其完整攻略。 一、需求分析 在实现之前,我们需要先进行需求分析。在本次多选框实现中,我们需要完成以下几个基本功能: 点击某个多选框实现选中或取消选中该选项的功能; 点击“全选”按钮,所有多选框均被选中; 点击“取消全选”按钮,所有多选框均被…

    JavaScript 2023年6月10日
    00
  • JS中精巧的自动柯里化实现方法

    JS中的柯里化是一种高级的函数式编程技巧,它允许我们将多参数函数转换为单参数函数,这在某些情况下非常方便并且优雅。下面我来详细讲解JS中精巧的自动柯里化实现方法。 基本柯里化方法 在JS中实现柯里化通常需要使用闭包和递归的方法。下面是一种基本柯里化方法: function curry(fn, args) { return function() { var n…

    JavaScript 2023年6月10日
    00
  • JavaScript实现打字游戏

    下面是JavaScript实现打字游戏的完整攻略: 1. 准备工作 在HTML文件中添加一个文本框和一个按钮 引入jQuery库 引入word-list.js文件,该文件包含了所有的单词列表 2. 获取输入的单词 当用户在文本框中进行输入后,点击按钮,会触发事件,调用checkWord()函数,该函数获取文本框中的输入值,将其和随机生成的单词进行比较,判断是…

    JavaScript 2023年5月19日
    00
  • IE DOM实现存在的部分问题及解决方法

    IE是Web开发中经典的浏览器之一,它的DOM实现在早期版本中存在一些问题,主要体现在以下两个方面: 1.慢速浏览器崩溃 IE浏览器在处理DOM时,如果DOM结构过于复杂或是操作过于频繁会导致浏览器崩溃的情况。这是由于IE浏览器的DOM实现存在一些性能问题所导致的。 解决方法:优化DOM结构或在操作DOM时避免频繁重排,可以通过以下几种方式来实现优化: 将对…

    JavaScript 2023年6月10日
    00
  • js本身的局限性 别让javascript做太多事

    JavaScript(以下简称JS)是Web前端开发必不可少的一门语言,它具有动态性、灵活性和可移植性等优点。但是,JavaScript本身存在着一些局限性,它不能完全替代其他语言的功能,也不能处理所有的任务。因此,在开发过程中需要注意不要过度依赖JS,否则会给项目带来一些潜在的风险和问题。 JS本身的局限性 在Web应用程序中,JS主要用于前端的交互效果和…

    JavaScript 2023年5月28日
    00
  • 详解JS实现简单的时分秒倒计时代码

    下面我来详细讲解一下实现简单的时分秒倒计时代码的攻略。 步骤一:HTML布局 在HTML中创建一个div容器,将时分秒倒计时展示在这个容器中。 <div id="countdown"></div> 步骤二:JS编写 1. 获取要倒计时的时间 首先,获取要倒计时的时间,可以通过获取当前的时间戳来计算目标时间戳。 va…

    JavaScript 2023年5月27日
    00
  • Javascript 计算字符串在localStorage中所占字节数

    要计算字符串在localStorage中所占字节数,需要先了解以下几个概念: 字符串长度:字符串中字符的个数。 字符编码:字符在计算机中的储存方式。常见的有ascii码、unicode、utf-8等。 字节:计算机中数据的存储单位。 在localStorage中储存字符串时,它实质上是以字节的形式储存的。因此,计算字符串在localStorage中所占字节数…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部