js的call和this指向系列

2024-06-10 04:48
文章标签 js 系列 call 指向

本文主要是介绍js的call和this指向系列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在我理解call主要有2层意思
  • 实现继承:

    • 继承属性和方法

      function Fun1(sex) {this.sex = sex,this.say = function() {console.log(this.sex);}
      }function Fun2(sex) {//this.sex = 'female';// #1Fun1.call(this, sex);//this.sex = 'female';// #2
      }var f2 = new Fun2("male");
      f2.say();// male

      (1) 以上Fun2继承了Fun1的所有属性和方法,所以Fun2的实例f2可以调用say方法输出male。 (2) 如果仅取消注释#1,将输出male,如果仅取消注释#2,将输出female,请体会其中区别

    • 组合继承

      function A() {this.name = 'a'
      }A.prototype = {say() {console.log(this.name)}
      }function B() {A.call(this)// 构造函数继承
      }B.prototype = Object.create(A.prototype)// 原型继承
      B.prototype.constructor = B// 改变constructor指向var b = new B()b.say()// a
      console.log(b.constructor)// B
  • 改变this指向

    • 关于this

      var sex = 'male';
      function Foo() {console.log(this.sex);
      }
      Foo();// => male // 直接调用,Foo就是普通函数,所以Foo内部的this指向的就是全局(因为函数本身也是挂载到window下面的),可以向上搜索到male
      Foo.call({sex: 'female'});// female // 同上,但是使用call改变this指向到了传入的对象,所以输出female
      var f = new Foo();// undefined // new关键字生成实例f,Foo就是构造函数,所以Foo内部的this指向实例f本身,f是没有sex这个属性的,输出undefined
      var a = 10function foo() {a = 100console.log(a)console.log(this.a)// 被当做普通函数调用,this指向全局)var a// 变量提升
      }
      foo()// 100 10
    • 简单示例

      function Fun1() {this.sex= "male",this.say = function() {console.log(this.sex);}
      }function Fun2() {this.sex= "female";
      }var f1 = new Fun1();
      var f2 = new Fun2();f1.say();// male
      f1.say.call(f2);// female // f1.say调用时的this指向被改成了指向f2,所以输出**female**(注意这里并不是继承,f2也没有say这个方法,f2.say()是会报错的)
    • 深入示例

      function foo(cb) {var self = this;this.sex = 'male';setTimeout(function() {cb && cb.call(self, 22);// 在这里调用回调函数cb时,this指向foo这个构造函数本身})
      }
      var f = new foo(function(age) {console.log(this.sex, age);// male 22
      })
      function Foo() {this.sex = 'male';this.say = function() {setTimeout(function() {console.log(this.sex);// 定时器普通回调函数中的this指向window}, 0)}this.speak = function() {setTimeout(() => {console.log(this.sex);// 箭头函数没有自己的this,它的this继承自外部函数的作用域。所以,定时器箭头回调函数中的this指向构造函数Foo本身}, 0)}
      }
      var f = new Foo()
      f.say()// undefined
      f.speak()// male
call和apply的区别
  • call([thisObj[, arg1[, arg2[, …[, argN]]]]])
  • apply([thisObj[, argArray]])
参考文章
  • call和apply实现继承
  • Javascript 中的 call 和 apply
  • JS Call()与Apply()

这篇关于js的call和this指向系列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1047251

相关文章

js+css二级导航

效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Con

JavaWeb系列二十: jQuery的DOM操作 下

jQuery的DOM操作 CSS-DOM操作多选框案例页面加载完毕触发方法作业布置jQuery获取选中复选框的值jQuery控制checkbox被选中jQuery控制(全选/全不选/反选)jQuery动态添加删除用户 CSS-DOM操作 获取和设置元素的样式属性: css()获取和设置元素透明度: opacity属性获取和设置元素高度, 宽度: height(), widt

C语言入门系列:探秘二级指针与多级指针的奇妙世界

文章目录 一,指针的回忆杀1,指针的概念2,指针的声明和赋值3,指针的使用3.1 直接给指针变量赋值3.2 通过*运算符读写指针指向的内存3.2.1 读3.2.2 写 二,二级指针详解1,定义2,示例说明3,二级指针与一级指针、普通变量的关系3.1,与一级指针的关系3.2,与普通变量的关系,示例说明 4,二级指针的常见用途5,二级指针扩展到多级指针 小结 C语言的学习之旅中,二级

JavaWeb系列六: 动态WEB开发核心(Servlet) 上

韩老师学生 官网文档为什么会出现Servlet什么是ServletServlet在JavaWeb项目位置Servlet基本使用Servlet开发方式说明快速入门- 手动开发 servlet浏览器请求Servlet UML分析Servlet生命周期GET和POST请求分发处理通过继承HttpServlet开发ServletIDEA配置ServletServlet注意事项和细节 Servlet注

js小题:通过字符串执行同名变量怎么做

在JavaScript中,你不能直接使用一个字符串来直接引用一个变量,因为JavaScript是一种静态类型语言(尽管它的类型在运行时可以变化),变量的名字在编译时就被确定了。但是,有几种方法可以实现类似的功能: 使用对象(或Map)来存储变量: 你可以使用一个对象来存储你的变量,然后使用字符串作为键来访问这些变量。 let myVars = { 'var1': 'Hello', 'var

图形编辑器基于Paper.js教程03:认识Paper.js中的所有类

先来认一下Paper的资源对象,小弟有哪些,有个整体的认识。认个脸。 在Paper.js的 官方文档中类大致有如下这些: 基类: ProjectViewItemPointToolSizeSegmentRectangleCurveCurveLocationMatrixColorStyleTweenToolEventGradientGradientStopEvent 二级或三级类 继承Ite

HTML文档插入JS代码的几种方法

在HTML文档里嵌入客户端JavaScript代码有4中方法: 1.内联,放置在< script>和标签对之间。 2.放置在由< script>标签的src属性指定的外部文件中。 3.放置在HTML事件处理程序中,该事件处理程序由onclick或onmouseover这样的HTML属性值指定。 4.放在一个URL里,这个URL使用特殊的“javascript:”协议。 在JS编程中,主张

C语言入门系列:初识函数

文章目录 一,C语言函数与数学函数的区别1,回忆杀-初中数学2,C语言中的函数 二, 函数的声明1,函数头1.1,函数名称1.2,返回值类型1.3,参数列表 2,函数体2.1,函数体2.2,return语句 三,main函数四,函数的参数与传递方式1,实参和形参1.1,函数定义(含形参)1.2,函数调用(使用实参) 2,参数传递方式2.1,值传递2.2,引用传递 五,函数原型与预声明1,

js 正则表达式出现问题

帮同事写个页面,出现正则表达式不管怎么改都没法匹配的情况。。。。 reg = /^sy[0-9]+$/i; if(rtx.match(reg) == null){ alert("请输入正确的RTX账号!"); return false; } 因为之前一直用的是 reg ="/^sy[0-9]+$/i"; 写PHP写习惯了。。外面多写了两个双引号……T.T 改

bootstrap和JS相关

下表列出了模态框中要用到事件。这些事件可在函数中当钩子使用。 bootstrap 显示隐藏div $('.show-info').click(function () {var show = $(this).data('show');if(show =='all'){$('#creative').show();$('#plan').show();$('#plan').attr('class','