[JS]this关键字以及call()、apply()、bind()比较

2024-08-20 22:48
文章标签 比较 js bind 关键字 call apply

本文主要是介绍[JS]this关键字以及call()、apply()、bind()比较,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

面向对象语言中 this 表示当前对象的一个引用。
但在 JavaScript 中 this 不是固定不变的,它会随着执行环境的改变而改变。

1、在方法中,this 表示该方法所属的对象。
2、如果单独使用,this 表示全局对象。
3、在函数中,this 表示全局对象。
4、在函数中,在严格模式下,this 是未定义的(undefined)。
5、在事件中,this 表示接收事件的元素。
6、类似 call() 和 apply() 方法可以将 this 引用到任何对象。

先看一下正常情况下this的绑定对象情况
例一

var postcode = "400000";
function lookPostcode () {console.log(this.postcode); // this指向window
}
lookPostcode(); // 输出:400000

例二

var province = "重庆市";
var city = "重庆";
var area = "82402平方千米";var tempObj = new Object();
tempObj.city = "成都";
tempObj.province = this.province;           // this指向window
tempObj.tempFun = function () {console.log(this.city+" 面积:"+this.area); // this指向tempObj
}console.log(tempObj.province);  // 输出:重庆市
tempObj.tempFun();              // 输出:成都 面积:undefined

在JS中函数也是对象有方法,apply()和call()就是函数对象的方法。他们允许切换函数执行时this绑定的对象。
call()apply()bind() 重新定义this比较
bind返回的是一个函数需要加”()“去执行

var newObj = new Object();
newObj.city = "武汉";
newObj.area = "8569.15平方千米";tempObj.tempFun.call(newObj);   // 输出:武汉 面积:8569.15平方千米
tempObj.tempFun.apply(newObj);  // 输出:武汉 面积:8569.15平方千米
tempObj.tempFun.bind(newObj)(); // 输出:武汉 面积:8569.15平方千米

 call()apply()bind() 传参比较

1.

var province = "重庆市";
var city = "重庆";
var area = "82402平方千米";var tempObj = new Object();
tempObj.city = "成都";
tempObj.province = this.province;
tempObj.tempFun = function (code,direction) {console.log(this.city+" 面积:"+this.area+" 邮政编码:"+code+" 方位:"+direction);
}var newObj = new Object();
newObj.city = "武汉";
newObj.area = "8569.15平方千米";tempObj.tempFun.call(newObj,"430000","中南部");     // 输出:武汉 面积:8569.15平方千米 邮政编码:430000 方位:中南部
tempObj.tempFun.apply(newObj,["430000","中南部"]);  // 输出:武汉 面积:8569.15平方千米 邮政编码:430000 方位:中南部
tempObj.tempFun.bind(newObj,"430000","中南部")();   // 输出:武汉 面积:8569.15平方千米 邮政编码:430000 方位:中南部

2.

var tempArr = [2,53,63,34,24,75];
// 返回 x,y,z,...,n 中的最高值
console.log(Math.max.apply(null,tempArr)); // 输出:75
// 返回 x,y,z,...,n 中的最小值
console.log(Math.min.apply(null,tempArr)); // 输出:2console.log(Math.max.call(null,75,2)); // 输出:75
console.log(Math.min.call(null,75,2)); // 输出:2console.log(Math.max.bind(null,75,2)()); // 输出:75
console.log(Math.min.bind(null,75,2)()); // 输出:2

 

这篇关于[JS]this关键字以及call()、apply()、bind()比较的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JS常用组件收集

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

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

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

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

Node.js学习记录(二)

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

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>

Oracle Start With关键字

Oracle Start With关键字 前言 旨在记录一些Oracle使用中遇到的各种各样的问题. 同时希望能帮到和我遇到同样问题的人. Start With (树查询) 问题描述: 在数据库中, 有一种比较常见得 设计模式, 层级结构 设计模式, 具体到 Oracle table中, 字段特点如下: ID, DSC, PID; 三个字段, 分别表示 当前标识的 ID(主键), DSC 当

关键字synchronized、volatile的比较

关键字volatile是线程同步的轻量级实现,所以volatile性能肯定比synchronized要好,并且volatile只能修饰于变量,而synchronized可以修饰方法,以及代码块。随着JDK新版本的发布,synchronized关键字的执行效率上得到很大提升,在开发中使用synchronized关键字的比率还是比较大的。多线程访问volatile不会发生阻塞,而synchronize

js react 笔记 2

起因, 目的: 记录一些 js, react, css 1. 生成一个随机的 uuid // 需要先安装 crypto 模块const { randomUUID } = require('crypto');const uuid = randomUUID();console.log(uuid); // 输出类似 '9b1deb4d-3b7d-4bad-9bdd-2b0d7b3dcb6d'