`
isiqi
  • 浏览: 16495248 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

JavaScript的9个陷阱

阅读更多

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

  1、最后一个逗号

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

  <script>

  var theObj = {

  city : "Boston",

  state : "MA",

  }

  </script>

  2、this的引用会改变

  如这段代码:

  <input type="button" value="Gotcha!" id="MyButton" >

  <script>

  var MyObject = function () {

  this.alertMessage = "Javascript rules";

  this.ClickHandler = function() {

  alert(this.alertMessage );

  }

  }();

  document.getElementById(”theText”).onclick = MyObject.ClickHandler

  </script>并不如你所愿,答案并不是”JavaScript rules”。在执行MyObject.ClickHandler时,代码中红色这行,this的引用实际上指向的是document.getElementById("theText")的引用。可以这么解决:

  <input type="button" value="Gotcha!" id="theText" >

  <script>

  var MyObject = function () {

  var self = this;

  this.alertMessage = “Javascript rules”;

  this.OnClick = function() {

  alert(self.value);

  }

  }();

  document.getElementById(”theText”).onclick = MyObject.OnClick

  </script>实质上,这就是JavaScript作用域的问题。如果你看过,你会发现解决方案不止一种。

  3、标识盗贼

  在JavaScript中不要使用跟HTML的id一样的变量名。如下代码:

  <input type="button" id="TheButton">

  <script>

  TheButton = get("TheButton");

  </script>IE会报对象未定义的错误。我只能说:IE sucks.

  4、字符串只替换第一个匹配

  如下代码:

  <script>

  var fileName = "This is a title".replace(" ","_");

  </script>而实际上,结果是”This_is a title“. 在JavaScript中,String.replace的第一个参数应该是正则表达式。所以,正确的做法是这样:

  var fileName = "This is a title".replace(/ /g,"_");


  5、mouseout意味着mousein

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

  6、parseInt是基于进制体系的

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

  7、for...in...会遍历所有的东西

  有一段这样的代码:

  var arr = [5,10,15]

  var total = 1;

  for ( var x in arr) {

  total = total * arr[x];

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

  for ( var x = 0; x < arr.length; x++) {

  total = total * arr[x];

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

  8、事件处理器的陷阱

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

  YAHOO.util.Event.addListener(window, "click", MyOnClickMethod);这应该也属于常识问题,但新手可能容易犯错。

  9、Focus Pocus

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

  var newInput = document.createElement("input");

  document.body.appendChild(newInput);

  newInput.focus();

  newInput.select();但是IE会报错(sucks again and again)。理由可能是当你执行fouce()的时候,元素尚未可用。因此,我们可以延迟执行:

  var newInput = document.createElement("input");

  newInput.id = "TheNewInput";

  document.body.appendChild(newInput);

  setTimeout(function(){ //这里我使用闭包改写过,若有兴趣可以对比原文

  document.getElementById('TheNewInput').focus();

  document.getElementById('TheNewInput').select();}, 10);在实践中,JavaScript的陷阱还有很多很多,大多是由于解析器的实现不到位而引起。这些东西一般都不会在教科书中出现,只能靠开发者之间的经验分享。谢天谢地,我们生活在网络时代,很多碰到的问题,一般都可以在Google中找到答案。

分享到:
评论

相关推荐

    JavaScript的9个陷阱及评点

    ### JavaScript的9个陷阱及评点 #### 1. 对象属性访问的陷阱 在JavaScript中,通过点符号(`.`)或方括号符号(`[]`)来访问对象属性时,需要注意一些细节。例如: ```javascript var theObj = { city: "Boston...

    Javascript中的陷阱大集合【译】

    本文将详细探讨一些常见的JavaScript陷阱,并提供相应的解决方案。 #### 双等号(==)与类型强制转换 在JavaScript中,双等号`==`操作符在比较两个值时会进行类型转换,这意味着即使两边的数据类型不同,也会尝试...

    Effective JavaScript 编写高质量JavaScript代码的68个有效方法1

    《Effective JavaScript:编写高质量JavaScript代码的68个有效方法》是David Herman撰写的一本JavaScript编程指南,该书基于作者在Ecma的JavaScript标准化委员会的工作经验,深入探讨了JavaScript的内部工作机制、...

    JavaScript设计模式+JavaScript模式+JavaScript异步编程

    - Promise:解决回调地狱,提供链式调用,但仍有回调陷阱。 - Generator:通过yield关键字实现异步流程控制,配合co库使用。 - async/await:基于Promise,提供同步式的异步编程体验,使得代码更易读和维护。 ...

    JavaScript性能陷阱小结(附实例说明)

    JavaScript性能优化是每个开发者在编写高效代码时必须关注的关键领域。由于JavaScript的动态特性,一些编程习惯可能导致不必要的性能损耗。以下是一些常见的JavaScript性能陷阱及其优化建议: 1. **避免使用`eval`...

    JavaScript的9个陷阱及评点分析

    JavaScript是一种广泛应用于网页和网络应用开发的脚本语言,它具有独特的语法特性和陷阱,对于初学者或经验丰富的开发者来说,...了解并避免这些JavaScript陷阱,有助于编写更健壮、可维护的代码,让编程生活更加轻松。

    javascript权威指南 epub书及源码

    JavaScript还具有动态类型和弱引用的特点,这使得它在处理数据时具有灵活性,但也可能导致一些陷阱。书中会讨论这些特性的使用和潜在问题,帮助开发者避免常见的错误。 事件驱动模型是JavaScript在Web开发中的一个...

    JavaScript API

    这个压缩包包含了几个关键的学习资源,帮助我们深入理解和掌握JavaScript API的应用。 首先,"JavaScript使用手册.chm" 是一份详尽的JavaScript参考文档,可能包含了JavaScript语法、内置对象、函数、DOM操作以及...

    JavascriptAPI.rar_javascriptAPI手册_javascriptapi

    特别的是,书中还深入讲解了JavaScript的一些陷阱和最佳实践,有助于开发者写出更健壮、更高效的代码。 在JavaScript API中,DOM API是关键部分。它将HTML或XML文档结构化为一个节点树,开发者可以通过这个树形结构...

    JavaScript 秘密花园.pdf

    一个常见的误区认为数字字面量不是对象,这实际上是JavaScript解析器的一个设计缺陷,它尝试将点操作符视为浮点数字面量的一部分,导致`2.toString()`这样的表达式产生语法错误。然而,有多种变通方法可以使数字字面...

    错误剖析之JavaScript的9个陷阱及评点

    来自Nine Javascript Gotchas, 以下是JavaScript容易犯错的九个陷阱。虽然不是什么很高深的技术问题,但注意一下,会使您的编程轻松些,即所谓make life easier. 笔者对某些陷阱会混杂一些评点。 1、最后一个...

    JavaScript经典进阶系列-Effective JavaScript英文原版

    本书通过68个条目,将这些关键知识点逐一展开,帮助读者深入理解JavaScript的核心机制。 1. **动态类型与强类型**:JavaScript是一种动态类型的语言,理解如何处理变量类型的变化对优化代码至关重要。书中会讲解...

    Effective JavaScript.2014.pdf

    对于那些有其他编程语言背景,希望快速掌握JavaScript的开发者来说,这本书同样是一个快速入门的良师益友。 7. 掌握JavaScript语言的细节:通过阅读本书,读者可以达到对JavaScript的深入、系统且实用的理解,这...

    javascript garden

    ### JavaScript Garden:深入探讨JavaScript中的陷阱与注意事项 #### 引言 《JavaScript Garden》是一份不断更新、详尽记录了JavaScript编程语言中最易犯错误、陷阱及细微问题的指南。该文档不仅帮助开发者规避常见...

    JavaScript中常见陷阱小结

    然而,在实际开发过程中,由于语言的灵活性和某些特性,JavaScript也会给开发者带来一些难以察觉的陷阱。本文将对JavaScript中常见的陷阱进行小结,以帮助开发者在项目中避免这些潜在问题。 首先,需要明确的是...

    JavaScript入门学习资料包

    对于每个概念,不仅要理解其含义,还要了解其使用场景和潜在的陷阱。随着学习的深入,可以尝试挑战更复杂的问题,如构建交互式的网页应用,或者利用JavaScript进行服务器端开发(Node.js)。 总之,这个"JavaScript...

    JavaScript the good parts

    《JavaScript the Good Parts》是著名的计算机科学家Douglas Crockford所著的一本书,它深入探讨了JavaScript编程语言中最有价值、最稳定的部分,旨在帮助开发者避开语言中的陷阱,充分利用其优势。这本书对于理解和...

    JavaScript语言精粹pdf

    通过阅读《JavaScript语言精粹》,读者不仅能掌握JavaScript的基本语法和高级特性,还能了解到最佳实践和常见陷阱,从而提升编程技能,成为一名更优秀的JavaScript开发者。书中的书签将帮助读者快速定位到重要章节,...

    JavaScript the good parts 经典课程

    通过深入学习"JavaScript the Good Parts",开发者可以避开JavaScript的一些陷阱,充分利用其优势,写出更安全、更高效的代码。这本书和相关课程将带你领略JavaScript的魅力,让你在Web开发领域更加游刃有余。

Global site tag (gtag.js) - Google Analytics