稳扎稳打JS——this
时间:2022-05-03
本文章向大家介绍稳扎稳打JS——this,主要内容包括this的值是在运行时确定的、2. 函数中的this、3. 对象中的this、4. 用call和apply函数给this开挂、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。
this的值是在运行时确定的
JS中的this究竟代表什么,这是在程序运行时根据上下文环境确定,可以分为以下几种情况。
1. 全局作用域中的this
在全局作用域中,this指向window对象。
console.log(this);//指向window对象
this.x = 5//在全局作用域内创建一个x
//与this.x = 5的等价情况:
//var x = 5;
//x = 5;
- 在全局作用域中执行var x=5,其实是为window对象创建一个属性x,并令其等于5。
- 若定义变量时不加var,JS会认为该变量为全局变量,会将其当作window对象的属性。
2. 函数中的this
JS中函数有两种,直接调用的函数称为普通函数,通过new创建对象的函数称为构造函数。
2.1 构造函数中的this
构造函数的this指向它所创建的对象,如:
function Person(name){
this.name = name;//this指向该函数创建的对象person
}
var person = new Person("chaimm");
2.2 普通函数中的this
普通函数的this指向window对象。 若上述例子,直接执行Perosn函数,则其中this代表window对象,因此该函数执行后会创建一个全局的name。
function Person(name){
this.name = name;//this指向window
}
Person("chai");//当作普通函数执行,this指向window对象
3. 对象中的this
对象中的this指向当前对象,如:
var person = {
name : "chaimm",
getName : function(){
return this.name;
}
}
上述代码中this指向函数getName所属的对象。 但是,如果一个对象的函数中又嵌套了一个函数,这个函数的this指向的却是window,而并不是其外层的对象。
var person = {
name : "chaimm",
setName : function(name){
(function(name){
this.name = name; //此时this并不代表person对象,而是代表window对象
})(name);
}
}
上述示例中,person对象中有一个getName函数,而getName函数内部又有一个函数,这个函数内部的this指向window对象,而非person对象,这是JS的一个bug!一般作如下处理,规避这个bug:
var person = {
name : "chaimm",
setName : function(name){
var thar = this;//将this赋给that
(function(name){
that.name = name;//此时that指向person对象
})(name);
}
}
我们在person对象的第一层函数中,将this赋给局部变量that,然后在第二层函数中使用that,此时that指向person对象,可对person的属性进行操作。
- 注意:若将一个对象中的函数赋给一个变量后,再通过该变量调用这个函数,此时该函数中的this指向window,而非该对象,如下所示:
var person = {
name : "chaimm",
getName : function(){
return this.name;
}
}
//将getName函数赋给一个新的变量
var newGetName = person.getName;
//通过新的变量调用这个函数,这个函数中的this将指向window
newGetName();//若全局作用域中没有name,则将返回undefined
4. 用call和apply函数给this开挂
这两个函数都能手动指定被调用函数内部的this指向哪个对象。
//定义一个构造函数
var Person = function(name){
this.name = "";
this.setName = function(name){
this.name = name;
}
}
//创建两个对象
var personA = new Person("A");
var personB = new Person("B");
//使用personA的setName函数去修改personB的name属性
personA.setName.apply(personB,["C"]);
- apply用法 对象A.函数名.apply(对象B, 参数列表); 当对象B作为apply的第一个参数传给apply时,对象A的函数中this就指向了对象B,此时对象A的该函数对this的操作将会作用在对象B上,由此实现了用对象A去调用对象B的函数。
- 《Android基础:Fragment,看这篇就够了》
- Android 7.0中ContentProvider实现原理
- 《iOS APP 性能检测》
- iOS 11 安全区域适配总结
- Linux下巧用chattr、watch命令的实例
- 【特斯拉组件】iOS高性能PageController
- SUSE Linux系统在线安装软件命令zypper参数详解
- Linux下通过rdesktop连接Windows远程桌面
- 微信iOS收款到账语音提醒开发总结
- React Native按需加载 手Q狼人杀探索之路
- nginx日志切割及7天前的历史日志删除脚本
- 《ios爆内存问题解决方案-OOMDetector组件》
- Linux/SUSE安装svn客户端的问题记录
- 《广研Android卡顿监控系统》
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 使用laravel的migrate创建数据表的方法
- 解决laravel session失效的问题
- php7下的filesize函数
- PHP-FPM 设置多pool及配置文件重写操作示例
- laravel实现登录时监听事件,添加登录用户的记录方法
- php更新cookie内容的详细方法
- php实现映射操作实例详解
- Laravel 已登陆用户再次查看登陆页面的自动跳转设置方法
- yii框架数据库关联查询操作示例
- laravel-admin的多级联动方法
- Laravel数据库读写分离配置的方法
- php给数组赋值的实例方法
- php实现分页功能的详细实例方法
- 浅谈Laravel中的三种中间件的作用
- laravel 使用auth编写登录的方法