- 浏览: 5167440 次
- 性别:
- 来自: 天津
博客专栏
-
实战 Groovy
浏览量:29353
文章分类
- 全部博客 (639)
- 代码之谜 (6)
- JavaScript quirks (5)
- 程序员 (92)
- Java (93)
- BT编程 (7)
- html/css (64)
- Groovy&Grails (42)
- Android (20)
- C/C++ (5)
- PHP/Perl/Python (46)
- 经典文章 (51)
- CodeIgniter (14)
- JQuery (10)
- 笑话 (4)
- 其他 (32)
- javascript (69)
- 云计算 (0)
- html5 (7)
- 面试 (8)
- google (3)
- nosql (2)
- nodejs (11)
- go (5)
- erlang (1)
- 小常识 (3)
- 冷知识 (5)
- database (4)
- web (12)
- 架构 (12)
- Exception (0)
最新评论
-
jqw1992:
https://www.chromefor.com/libra ...
[福利] 开发者必备的 Chrome 插件——ChromeSnifferPlus -
litjerk:
初步算了一下,目前最最精简的Win98版是5M,他5个小时多敲 ...
让人目瞪口呆的三位世界级电脑大师 -
379855529:
。。似乎重点没说NIO啊,前面基础只是铺垫的很好的,可是我要的 ...
Java NIO与IO的详细区别(通俗篇) -
springmvc_springjpa:
spring mvc demo教程源代码下载,地址:http: ...
一步步开发 Spring MVC 应用 -
匡建武:
Good
四个程序员的一天
开发者最容易犯的JavaScript错误,总结出13个。 这些当中可能少不了你犯的错误。 我们描述了这些陋习,并列出来解决办法,希望对开发者有帮助,本文来源http://justjavac.com/javascript/2012/04/05/top-13-javascript-mistakes.html。
1.for…数组迭代的用法 Usage of for..in to iterate Arrays
举例:
var myArray = [ “a”, “b”, “c” ];
var totalElements = myArray.length;
for (var i = 0; i < totalElements; i++) {
console.log(myArray[i]);
}
这里主要的问题是语句中的“for…”不能保证顺序,这意味着你将获得不同的执行结果。 此外,如果有人增加一些其他自定义功能的函数Array.prototype,你的循环将重复遍历这些函数,就像原数组项。
解决办法:一直使用规则的for循环来遍历数组。
var myArray = [ “a”, “b”, “c” ];
for (var i=0; i<myArray.length; i++) {
console.log(myArray[i]);
}
2.数组维度Array dimensions
举例
var myArray = new Array(10);
第二个问题是开发者使用数组构成器来创建数组,技术上是正确的, 然而会比文字符号(literal notation)慢解决办法:使用文字符号来初始化数组, 不要预定义数组长度。
var myArray = [];
3.未定义属性 Undefined properties
举例:
var myObject = {
someProperty: “value”,
someOtherProperty: undefined
}
未定义属性,将在对象中创建元素(键‘someOtherProperty’和值‘undefined’.)。 如果你遍历数组,检测已存在的元素,那么下面的语句将都返回“未定义/undefined”
typeof myObject['someOtherProperty'] // undefined
typeof myObject['unknownProperty'] // undefined
解决办法:如果你想明确声明对象中的未初始化的属性,标记它们为Null(空)。
var myObject = {
someProperty: “value”,
someOtherProperty: null
}
4.闭包的滥用Misuse of Closures
举例:
function(a, b, c) {
var d = 10;
var element = document.getElementById(‘myID’);
element.onclick = (function(a, b, c, d) {
return function() {
alert (a + b + c + d);
}
})(a, b, c, d);
}
这里开发者使用两个函数来传递参数a、b、c到onclick handler。 双函数根本不需要,徒增代码的复杂性。
变量abc已经在局部函数中被定义,因为他们已经在主函数中作为参数被声明。 局部函数中的任何函数都可创建主函数中定义的所有变量的闭包。 因此不需要再次传递它们。
看看这里JavaScript Closures FAQ了解更多。
解决办法:使用闭环来简化你的代码。
function (a, b, c) {
var d = 10;
var element = document.getElementById(‘myID’);
element.onclick = function() {
//a, b, and c come from the outer function arguments.
//d come from the outer function variable declarations.
//and all of them are in my closure
alert (a + b + c + d);
};
}
5.循环中的闭包Closures in loops
举例:
var elements = document.getElementByTagName(‘div’);
for (var i = 0; i<elements.length; i++) {
elements[i].onclick = function() {
alert(“Div number “ + i);
}
}
在这里例子里面,当用户点击不同的divs时,我们想触发一个动作(显示“Div number 1”, “Div number 2”… 等) 。 然而,如果你在页面有10个divs,他们全部都会显示“Div number 10”。
问题是当我们使用局部函数创建一个闭包时,函数中的代码可以访问变量i。 关键是函数内部i和函数外部i涉及同样的变量。 当我们的循环结束,i指向了值10,所以局部函数中的i的值将是10。
解决办法:使用第二函数来传递正确的值。
var elements = document.getElementsByTagName(‘div’);
for (var i = 0; i<elements.length; i++) {
elements[i].onclick = (function(idx) { //Outer function
return function() { //Inner function
alert(“Div number “ + idx);
}
})(i);
}
6.DOM对象的内测泄漏Memory leaks with DOM objects
举例:
function attachEvents() {
var element = document.getElementById(‘myID’);
element.onclick = function() {
alert(“Element clicked”);
}
};
attachEvents();
该代码创建了一个引用循环。 变量元素包含函数的引用(归于onclick属性)。 同时,函数保持一个DOM元素的引用(提示函数内部可以访问元素, 因为闭包。)。
所以JavaScript垃圾收集器不能清除元素或是函数,因为他们被相互引用。 大部分的JavaScript引擎对于清除循环应用都不够 聪明。
解决办法:避免那些闭包,或者不去做函数内的循环引用。
function attachEvents() {
var element = document.getElementById(‘myID’);
element.onclick = function() {
//Remove element, so function can be collected by GC
delete element;
alert(“Element clicked”);
}
};
attachEvents();
7.区别整数数字和浮点数字Differentiate float numbers from integer numbers
举例:
var myNumber = 3.5;
var myResult = 3.5 + 1.0; //We use .0 to keep the result as float
在JavaScript中,浮点与整数间没有区别。 事实上,JavaScript中的每个数字都表示使用双精度64位格式IEEE 754。 简单理解,所有数字都是浮点。
解决办法:不要使用小数(decimals),转换数字(numbers)到浮点(floats)。
var myNumber = 3.5;
var myResult = 3.5 + 1; //Result is 4.5, as expected
8.with()作为快捷方式的用法Usage of with() as a shortcut
举例:
team.attackers.myWarrior = { attack: 1, speed: 3, magic: 5};
with (team.attackers.myWarrior){
console.log ( “Your warrior power is ” + (attack * speed));
}
讨论with()
之前,要明白JavaScript contexts如何工作的。 每个函数都有一个执行context(语句),简单来说,包括函数可以访问的所有的变量。 因此context包含arguments和定义变量。
with()
真正是做什么?是插入对象到context链,它在当前context和父级context间植入。 就像你看到的with()
的快捷方式会非常慢。
解决办法:不要使用with() for shortcuts,仅for context injection,如果你确实需要时。
team.attackers.myWarrior = { attack: 1, speed: 3, magic: 5};
var sc = team.attackers.myWarrior;
console.log(“Your warrior power is ” + (sc.attack * sc.speed));
9.setTimeout/setInterval 字符串的用法 Usage of strings with setTimeout/setInterval
举例:
function log1() { console.log(document.location); }
function log2(arg) { console.log(arg); }
var myValue = “test”;
setTimeout(“log1()”, 100);
setTimeout(“log2(” + myValue + “)”, 200);
setTimeout()
和 setInterval()
可被或一个函数或一个字符串作为首个参数。 如果你传递一个字符串,引擎将创建一个新函数(使用函数构造器),这在一些浏览器中会非常慢。
相反,传递函数本身作为首个参数,更快、更强大、更干净。
解决办法:一定不要使用strings for setTimeout()或setInterval()。
function log1() { console.log(document.location); }
function log2(arg) { console.log(arg); }
var myValue = “test”;
setTimeout(log1, 100); //Reference to a function
setTimeout(function(){ //Get arg value using closures
log2(arg);
}, 200);
10.setInterval()的用法Usage of setInterval() for heavy functions
举例:
function domOperations() {
//Heavy DOM operations, takes about 300ms
}
setInterval(domOperations, 200);
setInterval()
将一函数列入计划被执行,仅是在没有另外一个执行在主执行队列中等待。 JavaScript引擎只增加下一个执行到队列如果没有另外一个执行已在队列。 这可能导致跳过执行或者运行2个不同的执行,没有在它们之间等待200ms的情况下。
一定要搞清,setInterval()
没有考虑进多长时间 domOperations()
来完成任务。
解决办法:避免 setInterval()
,使用 setTimeout()
function domOperations() {
//Heavy DOM operations, takes about 300ms
//After all the job is done, set another timeout for 200 ms
setTimeout(domOperations, 200);
}
setTimeout(domOperations, 200);
11.“this”的滥用Misuse of ‘this’
这个常用错误,没有例子,因为非常难创建来演示。 this的值在JavaScript中与其他语言有很大的不同。 函数中的this值被定义是在当函数被调用时,而非声明的时间,这一点非常重要。
下面的案例中,函数内this有不同的含义。
- Regular function: myFunction(‘arg1’);
this points to the global object, wich is window for all browers.
- Method: someObject.myFunction(‘arg1’);
this points to object before the dot, someObject in this case.
- Constructor: var something = new myFunction(‘arg1’);
this points to an empty Object.
- Using call()/apply(): myFunction.call(someObject, ‘arg1’);
this points to the object passed as first argument.
12.eval()访问动态属性的用法Usage of eval() to access dynamic properties
举例:
var myObject = { p1: 1, p2: 2, p3: 3};
var i = 2;
var myResult = eval(‘myObject.p’+i);
主要问题在于使用 eval()
开始一个新的执行语句,会非常的慢。
解决办法:使用方括号表示法(square bracket notation)代替 eval()
。
var myObject = { p1: 1, p2: 2, p3: 3};
var i = 2;
var myResult = myObject[“p”+i];
13.未定义(undefined)作为变量的用法Usage of undefined as a variable
举例:
if ( myVar === undefined ) {
//Do something
}
在上面的例子中,未定义实际上是一变量。 所有的JavaScript引擎会创建初始化的变量window.undefined给未定义作为值。 然而 注意的是变量不仅是可读,任何其他的代码可以刚改它的值。 很奇怪能找到window.undefined有来自未定义的不同的值的场景,但是为什么冒险呢?
解决办法:检查未定义时,使用typeof。
if ( typeof myVar === “undefined” ) {
//Do something
}
发表评论
-
Lo-Dash 与 underscore,Prototype 与 jQuery,两段恩怨情仇
2015-12-15 09:35 1677这几天更新我的之前写的 Chrome 插件 ChromeSn ... -
开发者必备的 Chrome 扩展
2014-11-03 15:01 2003Firebug:不用多介绍了吧https://chrome. ... -
开发者福利!ChromeSnifferPlus 插件正式登陆 Chrome Web Store
2014-10-30 21:14 106580今天(2014-10-30)下午,ChromeSniffer ... -
Firebase 相关文章索引
2014-10-23 10:21 2195Awesome Firebase 最近谷歌收购Fireb ... -
JSON API:用 JSON 构建 API 的标准指南中文版
2014-10-14 08:26 19860译文地址:https://github. ... -
前端开发,从菜鸟到大牛的取经之路
2014-07-14 15:15 378876以我的经验,大部分技术,熟读下列四类书籍即可。 入门, ... -
JavaScript Puzzlers 解密(一):为什么 ["1", "2", "3"].map(parseInt) 返回 [1, NaN, NaN]?
2014-02-19 10:58 40402JavaScript Puzzlers! 被称为 javas ... -
JavaScript 的怪癖 4:未知变量名创建全局变量
2013-12-02 15:25 1383原文:JavaScript quirk 4: unknown ... -
JavaScript 的怪癖 5:参数的处理
2013-12-02 15:23 3232原文:JavaScript quirk 5: parame ... -
【ghost初级教程】 怎么搭建一个免费的ghost博客
2013-10-28 14:10 6201ghost博客系统无疑是这个月最火热的话题之一,这个号称” ... -
10 个你需要了解的最佳 javascript 开发实践
2013-10-16 13:54 3594Javascript 的很多扩展的特性是的它变得更加的犀利 ... -
基于 canvas 将图片转化成字符画
2013-09-26 15:05 6576猛点 这里 看高清 ... -
详解一下 javascript 中的比较
2013-09-22 09:30 1914代码1: [] == []; // false ... -
谈 javascript 变量声明
2013-06-14 10:35 1885这篇文章还是对基础的复习,对面试经历的一个总结。 之前的 ... -
[译]Javascript 作用域和变量提升
2013-06-13 13:16 5182下面的程序是什么结果? var fo ... -
javascript:可以运行的噪音
2013-06-01 09:34 9268为我的博客做了一个很有 geek 风格的关于页面。运行下面 ... -
【layoutit!】基于 bootstrap 实现可视化布局工具
2013-05-20 11:23 14618Layout It 是一个在线工具,它可以简单而又快速搭建 ... -
回复:浮点数0.57 0.58 造出的坑爹问题
2013-05-09 11:30 25137今天看到 vb2005xu 提到了一个问题 浮点数0.5 ... -
javascript 中强制执行 toString()
2013-04-26 13:25 1538原文:Enforcing toString() 译文:ja ... -
JavaScript 中的“自动分号插入”机制(ASI)
2013-04-24 08:41 8423原文:Automatic semicolon insert ...
相关推荐
标题中的“PHP开发者常犯的10个MySQL错误”指的是在使用PHP进行MySQL数据库操作时,程序员容易犯的常见错误。这些错误不仅影响了代码的稳定性、安全性,还可能降低系统的性能。以下是对这些错误的详细说明: 1. **...
《JavaScript Garden》是一份不断更新、详尽记录了JavaScript编程语言中最易犯错误、陷阱及细微问题的指南。该文档不仅帮助开发者规避常见的误区与微妙的bug,还提供了性能优化建议以及避免不良实践的方法。对于希望...
13. Control the Complexity of Your JavaScript Functions with JSHint(用JSHint控制JavaScript函数的复杂性):JSHint是一个JavaScript代码质量工具,可以检测代码中的语法错误和潜在问题,有助于保持代码质量。...
在学习JavaScript的过程中,新手开发者常常会犯一些影响学习进度和效果的常见错误。这篇文章中列举的九个错误,是学习者在学习JavaScript时经常会遇到的问题,理解并避免这些错误对于提升学习效率、巩固编程基础以及...
6. "开发者最容易犯的13个JavaScript错误.html":这个文件可能列举并解释了开发者在编写JavaScript时常见的错误,是学习和避免常见陷阱的好资源。 7. "index.html":这是每个网站的标准入口文件,通常包含网站的...
- **常见编程错误**:列举了一些初学者容易犯的错误,并提供了解决方案。 - **调试技巧**:介绍了使用浏览器开发者工具进行调试的方法。 - **错误处理机制**:讲解了try-catch-finally语句的用法,以及如何通过异常...
以下是9个常见的错误,jQuery开发者应避免犯这些错误,以确保项目的高效运行。 1. **不使用最新版本的jQuery** 每次jQuery的版本更新都意味着性能提升和bug修复。例如,当前稳定版为1.7.2,但很多项目仍在使用1.6...
- **常见错误**:列出编程过程中容易犯的错误,并给出避免这些错误的建议。 - **调试技巧**:提供调试工具和技术的指导,如使用console.log()进行调试等。 - **错误处理机制**:介绍try...catch语句和其他异常...
在“awesome-bugs-master”这个压缩包中,我们可以猜测它可能包含了一个关于JavaScript错误的集合,或者是记录了一些独特、有趣的编程问题的项目。开发者们通常会将这些案例整理出来,以便于其他人学习和避免重复犯...
然而,许多PHP程序员在使用MySQL时容易犯一些常见错误,这些错误不仅影响了程序的性能,也可能造成安全隐患。以下为详细知识点总结: 1、不恰当的数据库引擎选择:MySQL提供了多种存储引擎,其中MyISAM和InnoDB最为...
例如,错误地使用引号、大括号或小括号是初学者容易犯的错误,但幸运的是,现代浏览器的JavaScript引擎能够自动检测到这些明显的语法错误,并给出提示。然而,一些不易察觉的错误,如变量名或函数名混淆、使用保留字...
这是许多开发者在编写JavaScript代码时容易犯的一个错误,因为在某些语言(如JavaScript、Python等)中,数组或对象的最后元素后面通常可以加上逗号作为可选的语法糖。但在JSON规范中,这样做是不允许的。 例如,...
在IT行业中,TypeScript是一种强大的、静态类型的编程语言,它是JavaScript的一个超集,旨在提供更安全、可维护的代码。"通缉犯"这个标题可能是某个项目或教程的名字,它可能涉及了使用TypeScript来创建复杂的系统...
**LevenSearch:Firefox...对于那些经常处理大量文本信息或者容易犯拼写错误的用户来说,LevenSearch是一个非常实用的工具。同时,其开源的特性也使得开发者能够深入研究其内部机制,并根据自己的需求进行定制和改进。
JavaScript中Array对象的map()方法是一个非常有用的高阶函数,它可以让...开发者在使用时,需要注意到回调函数中提供的三个参数,并妥善处理易犯错误情况。掌握map()方法,无疑会提高编写JavaScript代码的效率和能力。
codeceo 首页问答热门文章RSS订阅 文章首页 Java JavaScript ... iOS ...看过上文的还记得在 HashMap 扩容的时候会调用 resize() 方法,就是这里的并发操作容易在一个桶上形成环形链表;这样当获取...
10. **最佳实践与常见陷阱**:分享在 TypeScript 开发中的最佳实践,以及容易犯的常见错误,帮助开发者避开坑点,提升代码质量。 通过深入学习 "Slides_Issue_Example" 中的内容,开发者可以更好地应对 TypeScript ...