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

相关文章

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

EasyPlayer.js网页H5 Web js播放器能力合集

最近遇到一个需求,要求做一款播放器,发现能力上跟EasyPlayer.js基本一致,满足要求: 需求 功性能 分类 需求描述 功能 预览 分屏模式 单分屏(单屏/全屏) 多分屏(2*2) 多分屏(3*3) 多分屏(4*4) 播放控制 播放(单个或全部) 暂停(暂停时展示最后一帧画面) 停止(单个或全部) 声音控制(开关/音量调节) 主辅码流切换 辅助功能 屏

使用JS/Jquery获得父窗口的几个方法(笔记)

<pre name="code" class="javascript">取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document);如题: $(selector, window.top.document);//获得顶级窗口里面的元素 $(

js异步提交form表单的解决方案

1.定义异步提交表单的方法 (通用方法) /*** 异步提交form表单* @param options {form:form表单元素,success:执行成功后处理函数}* <span style="color:#ff0000;"><strong>@注意 后台接收参数要解码否则中文会导致乱码 如:URLDecoder.decode(param,"UTF-8")</strong></span>