全国服务热线:18980020603 成都热线:028-86633922
新闻中心网站专题联系我们
行业新闻 建站经验 网站建设资讯 手机网站资讯 微信网站建设资讯 APP开发资讯 商城网站资讯

成都网站制作:开发者最容易犯的13个JavaScript错误

发布人:桔子科技    发布时间:2015-09-30 07:34:25    分享到:
开发者最容易犯的JavaScript错误,总结出13个。这些当中可能少不了你犯的错误^_^。我们描述了这些陋习,并列出来解决办法,希望对开发者有帮助。
  1.for.. 数组迭代的用法 Usage of for..in to iterate Arrays
解决办法:一直使用规则的for循环来遍历数组。
         2. 数组维度 Array dimensions
这里有两个不同的问题。首先,开发者尝试创建一个包含10项的数组,这将创建10个空槽的阵列。然而,如果你试图得到一数组项,你将得到未定义的结果。换 句话说,效果就像你没有保存内存空间。没有真正的好原因来预定义数组长度。第二个问题是开发者使用数组构成器来创建数组,技术上是正确的,然而会比文字符 号(literal notation)慢
解决办法:使用文字符号来初始化数组,不要预定义数组长度。3. 未定义属性 Undefined properties
  3.未定义属性,将在对象中创建元素( 键’someOtherProperty’ 和 值 ‘undefined’.
解决办法: 如果你想明确声明对象中的未初始化的属性,标记它们为Null(空)。
       4. 闭包的滥用 Misuse of Closures
这里开发者使用两个函数来传递参数a、b、c到onclick handler。双函数根本不需要,徒增代码的复杂性。变量abc已经在局部函数中被定义,因为他们已经在主函数中作为参数被声明。局部函数中的任何函数 都可创建主函数中定义的所有变量的闭包。因此不需要再次传递它们。
解决办法:使用闭环来简化你的代码。
  5. 循环中的闭包 Closures in loops
当用户点击不同的divs时,我们想触发一个动作(显示Div number 1, Div number 2… 等) 。然而,如果你在页面有10个divs,他们全部都会显示 Div number 10。问题是当我们使用局部函数创建一个闭包时,函数中的代码可以访问变量i。关键是函数内部i和函数外部i涉及同样的变量。当我们的循环结束,i指向了 值10,所以局部函数中的i的值将是10。
解决办法:使用第二函数来传递正确的值。
     6. DOM对象的内测泄漏 Memory leaks with DOM objects
变量元素包含函数的引用(归于onclick属性)。同时,函数保持一个DOM元素的引用(提示函数内部可以访问元素, 因为闭包。)。所以JavaScript垃圾收集器不能清除元素或是函数,因为他们被相互引用。大部分的JavaScript引擎对于清除循环应用都不够 聪明。
解决办法:避免那些闭包,或者不去做函数内的循环引用。
     7. 区别整数数字和浮点数字 Differentiate float numbers from integer numbers
在JavaScript中,浮点与整数间没有区别。事实上,JavaScript中的每个数字都表示使用双精度64位格式IEEE 754。简单理解,所有数字都是浮点。
解决办法:不要使用小数(decimals),转换数字(numbers)到浮点(floats)。
       8. with()作为快捷方式的用法 Usage of with() as a shortcut
讨论with()之前,要明白JavaScript contexts 如何工作的。每个函数都有一个执行 context(语句),简单来说,包括函数可以访问的所有的变量。因此 context 包含 arguments 和定义变量。with() 真正是做什么?是插入对象到 context 链,它在当前 context 和父级 context间植入。就像你看到的with()的快捷方式会非常慢。
解决办法:不要使用with() for shortcuts,仅for context injection,如果你确实需要时。
       9.setTimeout/setInterval 字符串的用法 Usage of strings with setTimeout/setInterval
setTimeout() 和 setInterval() 可被或一个函数或一个字符串作为首个参数。如果你传递一个字符串,引擎将创建一个新函数(使用函数构造器),这在一些浏览器中会非常慢。相反,传递函数本身作为首个参数,更快、更强大、更干净。
解决办法: 一定不要使用 strings for setTimeout() 或 setInterval()。
       10.setInterval() 的用法 Usage of setInterval() for heavy functions
setInterval() 将一函数列入计划被执行,仅是在没有另外一个执行在主执行队列中等待。JavaScript 引擎只增加下一个执行到队列如果没有另外一个执行已在队列。这可能导致跳过执行或者运行2个不同的执行,没有在它们之间等待200ms的情况下。一定要搞 清,setInterval() 没有考虑进多长时间domOperations() 来完成任务。
解决办法:避免 setInterval(),使用 setTimeout()
    11. this的滥用 Misuse of ‘this’
这个常用错误,没有例子,因为非常难创建来演示。this的值在JavaScript中与其他语言有很大的不同。函数中的this值被定义是在当函数被调用时,而非声明的时间,这一点非常重要。
   12. eval()访问动态属性的用法 Usage of eval() to access dynamic properties
主要问题在于使用eval() 开始一个新的执行语句,会非常的慢。
解决办法:使用方括号表示法(square bracket notation)代替 eval()。
      13. 未定义(undefined)作为变量的用法 Usage of undefined as a variable
未定义实际上是一变量。所有的JavaScript引擎会创建初始化的变量window.undefined 给未定义作为值。然而注意的是变量不仅是可读,任何其他的代码可以刚改它的值。很奇怪能找到window.undefined 有来自未定义的不同的值的场景,但是为什么冒险呢?
本文来源于成都网站建设公司、成都网站设计制作公司与成都APP开发公司-桔子科技公司!
成都网站建设,成都网站设计,成都网站制作,成都网页设计,成都网站建设公司 ,成都网站设计公司, 成都网站制作公司,成都网页设计公司,成都手机网站建设,手机网站建设,成都APP开发,APP开发,成都建网站,成都做网站,成都商城网站建设,集团网站建设,网站建设,高端网站建设,品牌网站建设,成都平台网站建设,成都响应式网站建设,成都微信网站建设,成都微商城网站建设,成都微信营销,成都网站优化,成都网络公司。

下一篇:成都网站制作:网站标准之Flash页面如何通过校验 上一篇:成都网站制作:网站建设之标题分析

最新案例
手机/微网站
  1. [成都]微信网站建设:微信分销系统能为商铺带来哪些特色服务
  2. [成都]微信网站建设:如何通过微信公众号来推广产品
  3. [成都]微信网站建设:微信开发都有些什么功能
  4. [成都]手机网站:手机网站设计需要达到什么效果
  5. [成都]手机网站:手机网站响应式网站解决方案
  6. [成都]手机网站:手机网站响应式网站解决方案
网络营销
  1. APP开发: APP网页评分功能设计
  2. APP开发:手机APP开发前这4点必须要了解
  3. APP开发:为什么企业要做手机APP
  4. APP开发:你可以更好的留住APP用户
  5. APP开发:开发时间的长短主要由哪些因素决定
  6. APP开发:电子商务类APP开发的4点建议
img

7x24小时售后服务

img

5倍故障时长赔付

img

15天无理由退款

img

N对一管家服务

让我们的顾问联系您

  • 电话:4006-028-024 028-86633922

    邮箱:Service@orangeapp.cn

    成都市成华区崔家店路789号上城国际1-24-9号

qq sina