当前位置: 首页 > news >正文

成都电商网站制作长沙网络公司营销推广

成都电商网站制作,长沙网络公司营销推广,衢州新建,做网站开发要注册总结:谁调用我,我就指向谁(es6箭头函数不算) 一、ES6之前 每一个函数内部都有一个关键字是 this ,可以直接使用 重点: 函数内部的 this 只和函数的调用方式有关系,和函数的定义方式没有关系 …

总结:谁调用我,我就指向谁(es6箭头函数不算)

一、ES6之前

  • 每一个函数内部都有一个关键字是 this ,可以直接使用

  • 重点: 函数内部的 this 只和函数的调用方式有关系,和函数的定义方式没有关系

1、 函数内部的 this 指向谁,取决于函数的调用方式

1.1、全局定义的函数直接调用,this => window
 function fn() {console.log(this)}fn()// 此时 this 指向 window
1.2、 对象内部的方法调用,this => 调用者
var obj = {fn: function () {console.log(this)}
}
obj.fn()
// 此时 this 指向 obj
1.3、 定时器的处理函数,this => window
setTimeout(function () {console.log(this)
}, 0)
// 此时定时器处理函数里面的 this 指向 window
1.4、事件处理函数,this => 事件源
div.onclick = function () {console.log(this)
}
// 当你点击 div 的时候,this 指向 div
1.5、自调用函数,this => window
(function () {console.log(this)
})()
// 此时 this 指向 window

2、改变this指向

call 和 apply 和 bind

  • 刚才我们说过的都是函数的基本调用方式里面的 this 指向
  • 我们还有三个可以忽略函数本身的 this 指向转而指向别的地方
  • 这三个方法就是 call / apply / bind
  • 是强行改变 this 指向的方法
call
  • call 方法是附加在函数调用后面使用,可以忽略函数本身的 this 指向

  • 语法: 函数名.call(要改变的 this 指向,要给函数传递的参数1,要给函数传递的参数2, ...)

    var obj = { name: 'Jack' }
    function fn(a, b) {console.log(this)console.log(a)console.log(b)
    }
    fn(1, 2)
    fn.call(obj, 1, 2)
    
    • fn() 的时候,函数内部的 this 指向 window
    • fn.call(obj, 1, 2) 的时候,函数内部的 this 就指向了 obj 这个对象
    • 使用 call 方法的时候
      • 会立即执行函数
      • 第一个参数是你要改变的函数内部的 this 指向
      • 第二个参数开始,依次是向函数传递参数
apply
  • apply 方法是附加在函数调用后面使用,可以忽略函数本身的 this 指向

  • 语法: 函数名.apply(要改变的 this 指向,[要给函数传递的参数1, 要给函数传递的参数2, ...])

    var obj = { name: 'Jack' }
    function fn(a, b) {console.log(this)console.log(a)console.log(b)
    }
    fn(1, 2)
    fn.apply(obj, [1, 2])
    
    • fn() 的时候,函数内部的 this 指向 window
    • fn.apply(obj, [1, 2]) 的时候,函数内部的 this 就指向了 obj 这个对象
    • 使用 apply 方法的时候
      • 会立即执行函数
      • 第一个参数是你要改变的函数内部的 this 指向
      • 第二个参数是一个 数组,数组里面的每一项依次是向函数传递的参数
bind
  • bind 方法是附加在函数调用后面使用,可以忽略函数本身的 this 指向

  • 和 call / apply 有一些不一样,就是不会立即执行函数,而是返回一个已经改变了 this 指向的函数

  • 语法: var newFn = 函数名.bind(要改变的 this 指向); newFn(传递参数)

    var obj = { name: 'Jack' }
    function fn(a, b) {console.log(this)console.log(a)console.log(b)
    }
    fn(1, 2)
    var newFn = fn.bind(obj)
    newFn(1, 2)
    
    • bind 调用的时候,不会执行 fn 这个函数,而是返回一个新的函数
    • 这个新的函数就是一个改变了 this 指向以后的 fn 函数
    • fn(1, 2) 的时候 this 指向 window
    • newFn(1, 2) 的时候执行的是一个和 fn 一摸一样的函数,只不过里面的 this 指向改成了 obj
方法this 指向参数传递方式执行时机
call指定逐个传递立即执行
apply指定数组形式传递立即执行
bind指定逐个传递(可选)返回新函数,需手动调用

二、ES6之后的箭头函数

箭头函数内部没有 this,箭头函数的 this 是上下文的 this

const input = document.getElementById('input');
const btn = document.getElementById('btn');const obj = {value: 'Hello',printWithRegularFunction: function() {setTimeout(function() {console.log('普通函数:', this.value); // 这里的 this 指向全局对象(window)}, 1000);},printWithArrowFunction: function() {setTimeout(() => {console.log('箭头函数:', this.value); // 这里的 this 指向 obj 对象}, 1000);}};btn.addEventListener('click', () => {obj.value = input.value; // 将输入框的值赋值给 obj.valueobj.printWithRegularFunction();obj.printWithArrowFunction();});

运行结果 在这里插入图片描述

注意对象中的箭头函数

虽然箭头函数不能用于定义对象方法(因为它没有自己的 this),但可以在对象中定义箭头函数作为普通属性。

const obj = {name: 'Alice',sayHello: () => {console.log(`Hello, ${this.name}`); // 这里的 this 指向外层作用域}
};obj.sayHello(); // Hello, undefined

注意:箭头函数不适合用于对象方法,因为它会丢失对对象 this 的绑定。

http://www.khdw.cn/news/46931.html

相关文章:

  • 织梦后台如何做网站地图seo黑帽优化
  • 滨湖网站建设seo推广平台服务
  • wordpress熊掌号自动推送上海关键词排名优化公司
  • 如何将qq音乐链接到wordpressseo如何优化关键词排名
  • 做网站开发要学多久黄页引流推广
  • 武汉最好的网站建设前十深圳关键词排名seo
  • 网站后台模板关联自己做的网站百度免费资源网站
  • 网站导航栏下拉框怎么做优秀网站设计网站
  • 成品网站定制产品推广方式都有哪些
  • 企业网站推广的线上渠道有哪些seo标题优化
  • 聚云测网站怎么做的唐山seo推广公司
  • 哪个网站做任务可以赚钱网络广告有哪些形式
  • 南宁网站建设蓝云企业推广app
  • 做网站吗石家庄seo报价
  • 网站优化的代码如何在百度发布文章
  • 做网站哪个服务器好app优化推广
  • 国外网站模版免费下载不属于网络推广方法
  • 苍南县龙港哪里有做网站腾讯竞价广告
  • 有啥创意可以做商务网站的网络品牌推广
  • 做简历的网站都有哪些内容网站设计培训
  • 新疆电商网站建设公司自建网站流程
  • 自助建站模板使用方法做企业网站建设的公司
  • 现在有哪些推广平台seo搜索引擎优化薪资
  • 响应式网站的设计尺寸百度关键词搜索量排行
  • 成都建设网站指数平台
  • 东莞疫情进出最新政策seo优化软件免费
  • 做设计找素材那个网站最好用百度推广的价格表
  • 网站如何做竞价抖音seo排名
  • 外国人爱做视频网站google 推广优化
  • 投资者教育网站建设微指数