javascript的9个陷阱及评点

      以下是javascript容易犯错的九个陷阱。虽然不是什么很高深的技术问题,但注意一下,会使您的编程轻松些,即所谓make life easier. 以及对某些陷阱会混杂一些评点。

  如这段代码,注意最后一个逗号,按语言学角度来说应该是不错的(python的类似数据类型辞典dictionary就允许如此)。ie会报语法错误,但语焉不详,你只能用人眼从几千行代码中扫描。

  事实上,这是由于事件冒泡导致的。ie中有mouseenter和mouseleave,但不是标准的。在此建议大家使用库比如yui来解决问题。

  这个是常识,可是很多人给忽略了parseint还有第二个参数,用以指明进制。比如,parseint("09"),如果你认为答案是9,那就错了。因为,在此,字符串以0开头,parseint以八进制来处理它,在八进制中,09是非法,返回false,布尔值false转化成数值就是0. 因此,正确的做法是parseint("09", 10).

  运行得好好的,不是吗?但是有一天它不干了,返回的值变成了nan,。只不过引入了一个库而已。原来是这个库改写了array的prototype,这样,我们的arr平白无过多出了一个属性(方法),而for...in...会把它给遍历出来。所以这样做才是比较安全的:

  其实,这也是污染基本类的prototype会带来危害的一个例证。

  这其实只会存在使用作为对象属性的事件处理器才会存在的问题。比如window.onclick = myonclickmethod这样的代码,这会复写掉之前的window.onclick事件,还可能导致ie的内容泄露(sucks again)。在ie还没有支持dom 2的事件注册之前,建议使用库来解决问题,比如使用yui:

  这应该也属于常识问题,但新手可能容易犯错。

  新建一个input文本元素,然后把焦点挪到它上面,按理说,这样的代码应该很自然:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值