with语句性能优化

学习javascript 时在语句里面看见了with语句,兴之所至仔细看了下。

在一位前辈的博客看见十分详细的介绍,本着原汁原味的原则特摘录下来。

举一个实际例子吧:

 

Js代码   收藏代码
  1. with(document.forms[0]){  
  2.        name.value = "lee king";  
  3.        address.value = "Peking";  
  4.        zipcode.value = "10000";  
  5. }  

与之对应的传统的写法是:

 

Js代码   收藏代码
  1. document.forms[0].name.value = "lee king";  
  2. document.forms[0].address.value = "Peking";  
  3. document.forms[0].zipcode.value = "10000";  

可以看出with语句的简洁明了,不过在代码的世界里是很难找到真正的完美。

 

js的解释器需要检查with块中的变量是否属于with包含的对象,这将使with语句执行速度大大下降,并且导致js语句很难被优化。为了兼顾速度与代码量可以找到一个比较折衷的方案:

 

Js代码   收藏代码
  1. var  form = document.forms[0];  
  2. form.name.value = "lee king";  
  3. form.address.value = "Peking";  
  4. form.zipcode.value = "10000";  

 

 所以在以后的高效代码开发中我们应该尽可能的避免使用with语句。

博客原地址:http://tjuking.iteye.com/blog/1419964
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值