概念:
this是运行环境下的一个系统变量, 由于this在不同的执行环境下有不同的值, 所以在使用this时,多加注意 (使用this之前,先打印)
1,在全局作用域下,this默认指向window(前端运行环境),{}(后端运行环境).
2,在事件函数中,this指向绑定事件的目标
3,在构造函数中,this指向构造函数将要创建的对象
4,在对象中,this指向对象本身
特殊情况:(1) 有函数嵌套时,内层的函数this不会继承外层函数的this的值,会被还原成window
如果像让内层函数的this和外层函数this统一指向, 内层函数请使用箭头函数(因为箭头函数没有自己的this,会在上下文查找
(2)在ajax回调函数中, this指向window
 
修改this指向
修改this指向:   三种方法    call   apply    bind
 
function add(a, b) {
            console.log(8, this, a + b)
        }
        add(3, 4)
1, 通过call函数修改this指向, 用函数直接调用call(),
第一个参数是this修改后的指向(支持引用类型,如果传入值类型会自动装箱),
后边的参数是函数add的原始参数, 调用call时会直接执行add函数。
  add.call("李四", 5, 6)
 
2,通过apply函数修改this指向, 用函数直接调用apply(),
第一个参数是this修改后的指向(支持引用类型,如果传入值类型会自动装箱),
后边的参数是函数add的原始参数所在的数组,
调用apply时会直接执行add函数
  add.apply(false, [5, 6])
 
3,通过bind函数修改this指向,用函数不会直接调用bind(),
第一个参数是this修改后的指向(支持引用类型,如果传入值类型会自动装箱),
后边的参数是函数add的原始参数, 调用bind时不会直接执行add函数
  var obj = { name: "思聪", age: 10 }
      调用bind后会返回一个新的函数
   var newAdd = add.bind(obj, 5, 6)
      调用新的函数得到修改后的this
   newAdd()
 
3,call和apply和bind的异同点:
            (一), call和apply 修改this指向时会立即调用函数, bind修改指向不会立即调用函数会, 返回一个新函数
            (二), call,bind的第二个参数是函数的原始参数写法, apply的第二个参数必须是数组, 数组中放的是原始参数
 4,使用场景:
        (一), call 适合在调用函数时修改this指向, 直接使用call或apply修改即可
            (二), bind 适合在修改this指向时, 不立即调用函数, 而是时机成熟时在调用的情况,  如: 计时器, ajax请求等异步回调函数的修改

注意:事件函数修改this时,一定要用bind

btn6.onclick = function () {
            console.log(9, this)
        }.bind(document.body)
 
 
 

this的指向问题及改变this指向的更多相关文章

  1. JS中this指向问题和改变this指向

    首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然 ...

  2. Javasript中this指向问题和改变this指向的方法

    在学习javascript中我们往往会被this的指向问题弄的头昏转向,今天我们就来学习一下this的指向问题,和改变this指向的方法. 一.this的指向问题 在学习this的指向问题之前我们需要 ...

  3. 可以改变this指向的方法

    this一般指向的是当前被调用者,但也可以通过其它方式来改变它的指向,下面将介绍三种方式: 1.call用作继承时: function Parent(age){ this.name=['mike',' ...

  4. call()与apply() 改变this指向

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 15.0px Consolas; color: #a5b2b9 } span.Apple-tab-span ...

  5. this指向及改变this指向的方法

    一.函数的调用方式决定了 this 的指向不同,但总的原则,this指的是调用函数的那个对象: 1.普通函数调用,此时 this 指向 全局对象window function fn() { conso ...

  6. 改变this指向的三种方法

    call.apply.bind三者为改变this指向的方法. 共同点:第一个参数都为改变this的指针.若第一参数为null/undefined,this默认指向window call(无数个参数) ...

  7. js中改变this指向的call、apply、bind 方法使用

    前言: 由于js 中this的指向受函数运行环境的影响,指向经常改变,使得开发变得困难和模糊,所以在封装sdk,写一些复杂函数的时候经常会用到this 指向绑定,以避免出现不必要的问题,call.ap ...

  8. $.on()方法和addEventListener改变this指向

    jQuery $.on()方法和addEventListener改变this指向 标签(空格分隔): jQuery JavaScript jQuery $.on() jq的绑定事件使用$([selec ...

  9. (三十七)js改变this指向的方法

    最近又遇到了JacvaScript中的call()方法和apply()方法,而在某些时候这两个方法还确实是十分重要的,那么就让我总结这两个方法的使用和区别吧. 1.改变函数内部的this指向的三种方法 ...

随机推荐

  1. 关于深搜dps

    哈哈,我又来了! 但是!今天我又带来了让人开心到窒息的 ----深搜dps 其实关于深搜,概念没啥可讲的,总结一句话概括就是:一直往下搜,直到满足条件的,再回来,沿着下一条路搜,直到把路全走完为止.. ...

  2. Linux下swap(交换分区)的增删改

    swap介绍 Linux 的交换分区(swap),或者叫内存置换空间(swap space),是磁盘上的一块区域,可以是一个分区,也可以是一个文件,或者是他们的组合.交换分区的作用是,当系统物理内存吃 ...

  3. 输入URL回车之后,究竟发生了什么

    https://blog.csdn.net/androidstarjack/article/details/107031771 在浏览器输入URL回车之后发生了什么?(超详细版)   前言 这个问题已 ...

  4. org.apache.kafka.common.errors.SerializationException: Error deserializing... Caused by: org.apache.kafka.common.errors.SerializationException: Size of data received by IntegerDeserializer is not 4

    原因,最近开发的kafka消息接收,突然报如下错: org.apache.kafka.common.errors.SerializationException: Error deserializing ...

  5. 用maven建立一个工程2

    下载之后把下载的包解压出来

  6. 学习Nginx(二)

    Nginx支持四层代理 http://nginx.org/en/docs/stream/ngx_stream_core_module.html 该ngx_stream_core_module模块自1. ...

  7. js获取一周前日期

    项目中需要设定默认开始时间为一周前,结束时间为现在,现在写一下如何用js获取一周前日期. 1 var time=(new Date).getTime()-7*24*60*60*1000; 2 var ...

  8. AutoValue —— Generated immutable value classes

    本文参考 在<Effective Java>第三版第十条"Obey the general contract when overriding equals"中提到goo ...

  9. 错误问题之“Apache Log4j 漏洞,在版本为包含2.14以内!”

    漏洞概述 Apache Log4j是一个用于Java的日志记录库,其支持启动远程日志服务器. Log4j 1.2 中包含一个 SocketServer 类,该类容易受到不可信数据反序列化的影响,当侦听 ...

  10. js 关于setTimeout和Promise执行顺序问题

    js 关于setTimeout和Promise执行顺序问题 异步 -- Promise和setTimeout 执行顺序   Promise 和 setTimeout 到底谁先执行 定时器的介绍 Jav ...