概念:
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. Rsync反弹shell

    vulhub环境靶机 : 192.168.91.130 攻击机:kali 192.168.91.128 一.环境搭建 vulhub环境靶机环境搭建 ​ 在纯净ubuntu中部署vulhub环境: 1. ...

  2. Linux 下命令有哪几种可使用的通配符?分别代表什么含义?

    "?"可替代单个字符. "*"可替代任意多个字符. 方括号"[charset]"可替代 charset 集中的任何单个字符,如[a-z],[ ...

  3. nginx简介&nginx基本配置和优化

    一.nginx简介 1.nginx的发展 Nginx是俄罗斯人编写的一款高性能HTTP和反向代理服务器.Nginx能够选择高效的epoll(Linux2.6内核).kqueue(FreeBSD).ev ...

  4. Springboot添加静态资源映射addResourceHandlers,可实现url访问

    @Configuration //public class WebMvcConfiger extends WebMvcConfigurerAdapter { public class WebMvcCo ...

  5. docker安装部署、fastDFS文件服务器搭建与springboot项目接口

    一.docker安装部署 1.更新yum包:sudo yum update 2.安装需要的软件包,yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动 ...

  6. 哪一个List实现了最快插入?

    LinkedList和ArrayList是另个不同变量列表的实现.ArrayList的优势在于动态的增长数组,非常适合初始时总长度未知的情况下使用.LinkedList的优势在于在中间位置插入和删除操 ...

  7. mysql行锁、表锁。乐观锁,悲观锁

    锁定用于确保事务完整性和数据库一致性. 锁定可以防止用户读取其他用户正在更改的数据,并防止多个用户同时更改相同的数据. 如果不使用锁定,数据库中的数据可能在逻辑上变得不正确,而针对这些数据进行查询可能 ...

  8. BeanFactory – BeanFactory 实现举例?

    Bean 工厂是工厂模式的一个实现,提供了控制反转功能,用来把应用的配置和依赖从正真的应用代码中分离. 最常用的BeanFactory 实现是XmlBeanFactory 类.

  9. 如何在网上找java包

    如图所示 在java api后面输入你要找包的名称就可以了

  10. 记一次 Nuxt 3 在 Windows 下的打包问题

    0. 背景 之前用 Nuxt 3 写了公司的官网,包括了样式.字体图标.图片.视频等,其中样式和字体图标放在了 assets/styles 和 assets/fonts 目录下,而图片和视频则放在了 ...