广州蓝景分享—「JavaScript」this关键字的五个重要事项
citgpt 2024-11-25 10:02 6 浏览 0 评论
首先this 关键字是 JavaScript 中最令人困惑的部分之一,今天通过介绍有关它的五个重要事项来阐明其目的和用法。
1、它允许访问同一对象上的其他属性
在 JavaScript 中,函数可以是独立的单元,但它们也可以用作对象的值。
考虑下一个对象。
const obj = {
msg: 'Hi',
logMessage: function(){}
}
logMessage 属性存储一个函数,logMessage 是一种方法。
logMessage 函数如何访问同一对象上的其他成员?
这是这个伪参数变得有用的地方,它允许访问同一对象上的其他成员。
const obj = {
msg: 'Hi',
logMessage: function(){
console.log(this.msg);
}
}
obj.logMessage();
//'Hi'
在 logMessage 方法中,this 关键字用于访问同一对象的 msg 属性。
基本上,这就是在 JavaScript 中使用 this 关键字的原因,它允许访问其他拥有或继承的属性。
这种行为只有一个条件,函数应该作为方法调用,而不是作为函数调用。
2、它取决于函数的调用方式而不是函数的定义位置
考虑以下访问 this 参数的函数。
this.msg = "Parent";
function logMessage(){
console.log(this.msg);
}
在下一个示例中,对两个对象使用相同的函数。
const obj = {
msg: 'Hi',
logMessage
}
const newObj = {
msg: 'Hello',
logMessage
}
这个变量引用的对象是什么?
这取决于函数的调用方式,而不是函数的定义位置。
当 logMessage 作为 obj 对象上的方法调用时,它引用该对象。
obj.logMessage();
//'Hi'
当它作为 newObj 对象上的方法被调用时,它指向它。
newObj.logMessage();
//'Hello'
请考虑以下示例,其中 logMessage 属性存储在 obj 对象内定义的函数。
const obj = {
msg: 'Hi',
logMessage: function(){
console.log(this.msg);
}
}
logMessage 中的 this 参数是否总是引用 obj 对象,因为它是在该对象中定义的?
答案是,NO。
下面是调用 logMessage 并使用 call 方法传递由 this 参数引用的不同对象的示例。
const newObj = {
msg: 'Hello'
}
obj.logMessage.call(newObj);
//'Hello'
同样可以使用 apply 方法来完成,我们甚至可以强制它使用空对象运行,这次函数记录未定义。
obj.logMessage.apply({});
//undefined
3、与函数形式一起使用时,它指向其他东西
函数不一定是对象的一部分,它们可以是独立的单元,因此,可以用函数形式调用。
考虑下一个例子。
const obj = {
msg: 'Hi',
logMessage: function(){
console.log(this.msg);
}
}
const logMessage = obj.logMessage;
logMessage();
//undefined
logMessage 中的 this 不依赖于函数的定义位置,在这种情况下是在 obj 对象中。
这取决于如何调用 logMessage,在前面的示例中,logMessage 被调用为函数而不是方法。这指向了一些意想不到的东西,this.msg 给出了未定义的内容。
这是另一个例子。
const obj = {
msg: '',
logMessage: function(){
this.msg = 'Hi';
function logSomething(){
console.log(this.msg);
}
logSomething();
}
}
obj.logMessage();
//undefined
logMessage 作为方法调用(obj.logMessage()),但 logSomething 作为函数调用。因为 logSomething 不是作为方法调用,而是作为函数调用,所以,在其中 this 指向未例外的东西。在这种情况下,this.msg 给出未定义。
如果您希望 this 引用正确的对象,请确保始终将 logMessage 作为方法调用。
4 、箭头函数没有this
确实箭头函数没有自己的 this。它们实际上是用来解决我们之前在方法内部调用内部函数时遇到的问题。
检查下一个示例。
const obj = {
logMessage: function(){
const msg = 'Hi';
const logSomething = ()=>{
console.log(msg);
}
logSomething();
}
}
obj.logMessage();
//'Hi'
logSomething 是否将 msg 作为变量?不。
logSomething 在尝试访问它没有的变量时会发生什么?
它向下看它的父级元素来找到变量并使用它。
据说箭头函数没有自己的 this,它实际上是什么意思?
这意味着它看不起它的父级元素来找到变量并使用它。
看下面的例子。
const obj = {
msg: '',
logMessage: function(){
this.msg = 'Hi';
const logSomething = ()=>{
console.log(this.msg);
}
logSomething();
}
}
obj.logMessage();
//'Hi'
logSomething 没有这个参数,与从外部环境中使用的其他变量和参数一样,它向下查看链并在其父级中找到它并使用它。
logSomething 中的 this 与 logMessage 中的对象相同。
5、应用程序可以在不使用它的情况下编写
除非应用程序已经以这种方式编写,否则无需使用 this 关键字编写应用程序。
像 React Hooks、VueJs Composition API 和 Svelte 这样的 UI 框架允许在不使用 this 关键字的情况下编写组件。
我们可以使用闭包来编写封装对象,这是一个例子。
const obj = (function(){
let msg = '';
function logMessage(){
msg = 'Hi';
const logSomething = ()=>{
console.log(msg);
}
logSomething();
}
return {
logMessage
}
})();
obj.logMessage();
//'Hi'
logMessage 是在自执行函数内部定义的内部函数。logMessage 是一个闭包。它从外部函数引用 msg 变量。即使在自执行函数返回后,它也可以访问此变量。
现在它不关心我们是否将 logMessage 作为函数或作为方法调用,它总是引用正确的 msg 变量。
const logMessage = obj.logMessage;
logMessage();
//'Hi'
总结
如果您真的想使用 this 关键字,或者受限于应用程序内部已经做出的决定,请记住该函数应作为方法调用以指向正确的对象。如果真的不喜欢使用 this 关键字,您也可以考虑使用闭包实现对象并完全避免使用 this。以上就是今天所分享的知识点,希望对你有所帮助,可以点个赞,或者关注我们。
相关推荐
- 外贸网站建设要多少钱?外贸网站建设周期要多久
-
大家好,我是【无锡柠萌网络lemon56.com】的小美,今天分享:外贸网站建设要多少钱?外贸网站建设周期要多久您关注的问题·FAQ外贸网站建设中遇到的常见问题,让您少走弯路,提高效率!...
- 500块搭建一个可以卖货的跨境电商独立站,包括服务器和域名吗?
-
用500元搭建一个可以卖货的跨境电商独立站,虽然有一定挑战性,但通过精打细算和选择合适的工具和服务,仍然是有可能的。以下是一些建议,帮助你在预算范围内实现这个目标,包括服务器和域名的选择。...
- 无锡网络公司设计搭建阀门网站一般要多少钱?
-
无锡网络公司设计搭建阀门网站一般要多少钱?这是一个涉及多方面因素的复杂问题,其费用因网站规模、功能需求、设计复杂度及后续维护等因素而异。首先,从基础成本出发,域名注册是搭建网站的第一步,费用通常在几十...
- 定制化网站开发大概多少钱
-
定制化网站开发的价格因项目的复杂性、功能需求、设计要求和开发时间等因素而异。以下是一些常见的定制化网站开发价格范围,供参考:1.简单的定制化网站开发:一般来说,一个简单的定制化网站开发项目可能需要花...
- 9月安卓手机性能排行榜出炉:前十名差距仅为7%
-
时间已经进入9月,按照安兔兔目前的安卓手机性能榜单显示,红魔9SPro+依旧力压其他热销手机成为榜首,可见游戏定位的这款手机,在性能上确实非常的出色。不过,笔者也发现了一个问题,其中前十名中得分最高...
- 装修公司怎么在网络平台接单?实现高效获客
-
装修行业正经历着深刻的变革,随着消费者需求的日益多样化与个性化,传统的线下获客方式已难以满足装修公司的业务需求。因此,装修公司必须紧跟时代步伐,充分利用网络平台实现高效获客。1、入驻装修接单平台:壹品...
- 企业如何利用二维码进行线上营销?
-
#企业如何利用二维码进行线上营销?#企业利用二维码进行线上营销,可以从以下几个方面入手:?1.设计创意二维码?:...
- 家电销售该怎么线上拓客
-
社交媒体平台:利用微信、微博、抖音等平台,定期发布家电产品的信息、使用心得、促销活动等内容。引流靠手动一定是不行的,所以一般使用点软件肯定没错,最近用了款比较冷门的APP,"里德助手Plus...
- pop社交软件,脱单软件排行榜
-
在交友软件里面脱单是非常明确的一件事,各年龄各社交平台上的女人都是有所不同的,具体问题具体分析一下。接下来就说说又哪些比较优质的恋爱脱单软件。...
- 手机处理器最新跑分排行榜,你的手机什么水平?
-
手机处理器最新跑分排行榜,你的手机什么水平?第1名:天玑9300第2名:骁龙8Gen3第3名:A17Pro第4名:天玑9200第5名:骁龙8Gen2第6名:骁龙8Gen1...
- 继番茄小说后,字节再推免费网文 App“蛋花小说”和“常读小说”
-
据Tech星球报道,字节跳动公司近期推出了两款全新的免费网文App,分别是“蛋花小说”和“常读小说”。这两款产品的开发公司分别为湖北福瑞兴网络科技有限公司和湖北聚合润网络科技有限公司,均为字节跳动的1...
- 全世界最好用的AI软件排名是?
-
Hey小伙伴们,今天咱们来聊聊那些让人爱不释手的AI神器!在这个智能化时代,谁还没几个拿得出手的AI软件呢?别急,我这就给你盘点一波全球超火的AI软件,保证让你大开眼界!...
- 手机root软件哪个成功率高?手机root软件排行榜2025
-
作为游戏玩家,欲在手游中畅玩无阻,root权限不可或缺,可优化画质、启用辅助。2025年已至,究竟哪些手机root软件能脱颖而出?哪款软件的root成功率会独占鳌头?一、手机root软...
- 独立站新手教程引流篇:如何优化谷歌广告投放效果?
-
随着谷歌广告单价的持续上涨,如何在提升投放效果的同时,降低推广费用成为每一个独立站卖家的必修课。因此新手卖家在完成初步的广告投放流程后,最重要的就是了解一下谷歌广告优化的基础策略。设置转化跟踪即利用G...
- 云媒易:干货知识分享!海外推广的渠道有哪些,如何正确的选择?
-
越来越多的海外企业或国内的跨境商家认识到海外的网络营销的作用,开展线上外贸营销,渠道是非常的重要,那么海外的推广渠道有哪些?企业应该如何选择呢?1、社交媒体推广社交媒体推广是现在海外推广方式中最热门的...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracleclient (56)
- springbatch (59)
- oracle恢复数据 (56)
- 简单工厂模式 (68)
- 函数指针 (72)
- fill_parent (135)
- java配置环境变量 (140)
- linux文件系统 (56)
- 计算机操作系统教程 (60)
- 静态ip (63)
- notifyicon (55)
- 线程同步 (58)
- xcode 4 5 (60)
- 调试器 (60)
- c0000005 (63)
- html代码大全 (61)
- header utf 8 (61)
- 多线程多进程 (65)
- require_once (60)
- 百度网盘下载速度慢破解方法 (72)
- 谷歌浏览器免费入口 (72)
- npm list (64)
- 网站打开速度检测 (59)
- 网站建设流程图 (58)
- this关键字 (67)