JS 中的with语法现象

本文介绍了JavaScript中较少使用的with语法,解释了其功能和使用场景,并通过示例展示了如何简化对同一对象属性的多次访问。同时也指出了with语法可能带来的性能问题及调试困难。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这是一个较少用到的语法:关于with(A){...}

功能:关联对象A属性,在with代码块内部,每个变量首先被认为是一个局部变量,如果局部变量与A对象的某个属性同名,则这个局部变量会指向A对象属性。

示例代码:

var qs = location.search.substring(1);
var hostName = location.hostname;
var url = location.href;
//可以简写为:
with (location){
  var qs = search.substring(1);
  var hostName = hostname;
  var url = herf;
优点:简化多次编写访问同一对象的工作。

不足:

1. 性能问题,js引擎在初始化时,无法确定with内的属性所属对象,所以无法对代码优化;

2. 语义不明,难以调试

总得来说,还是不建议使用,了解这个语法现象就好!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值