- 浏览: 272649 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
zhuzhuhenzhencheng:
密码是什么啊
Ext表格(Grid)上面的悬浮提示 -
鹿惊_:
确实如雪中送炭般温暖!
Ext扩展整理后吐血奉献 -
ortega1_2_3:
该版本貌似有bug,当sockIOPool的自平衡线程self ...
Java MemCached Window简单实现 -
q6952592:
好。解决了我的兼容模式下出现的问题。
Ext表格(Grid)上面的悬浮提示 -
fei33423:
请参考 fei33423的文章 java中直接调用groovy ...
Groovy应用(Java与Groovy间相互调用)
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);
这里有两个不同的问题。首先,开发者尝试创建一个包含10项的数组,这将创建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 }
发表评论
-
JSON查看工具
2012-03-09 22:26 0Eclipse 的json插件: 这款插件主要功能是把jso ... -
gzip压缩JavaScript
2012-02-13 17:14 5691为了提高客户端的体验效果,RIA开发逐渐兴起。这样 ... -
Ext扩展整理后吐血奉献
2012-01-19 13:58 7111对 Ext 扩展的一些小总结 1、multicombo (多 ... -
JSON LIB转化时间
2011-11-02 09:32 1324Ext Grid显示Json lib 转化时间为object的 ... -
JS计算日期差
2011-09-24 14:04 1547function Computation(sDate1,sDa ... -
将Air文件转换为EXE进行部署
2011-06-14 17:21 1683如果你的air sdk还没有升级到2.0 那显然是不行的. ... -
禁止IE的backspace键(退格键),但输入文本框时不禁止
2011-06-09 09:59 3655Ext实现方式: Ext.getDoc().on('keyd ... -
Ext中集成在线编辑器Ext.ux.TinyMCE
2011-05-31 15:46 3061Ext.ux.TinyMCE第三方对Ext 在线编辑器的扩展, ... -
Ex的Ajax请求实现同步
2011-05-31 15:29 1326Ext2,.x的Ajax实现同步 Ext.lib.Ajax. ... -
JS实现将XML转化为JSON
2011-05-31 15:09 5548直接上代码 xmlToJson={ parser: ... -
Ext表格(Grid)上面的悬浮提示
2011-05-30 16:36 7531方法一 使用render //鼠标放在Grid上面显示提示 ... -
Ext皮肤切换
2011-04-22 10:46 3315/** * @author JLee * @since ... -
JS获取屏幕大小
2011-04-18 16:56 1216<html> <script> f ... -
在js中对中文和特殊字符转码
2011-04-14 14:21 3909直接上代码 js对文字进行编码涉及3个函数:escape,e ... -
Aptana 构建 Air 项目(集成ExtJS)
2011-03-17 01:00 34321、安装Aptana IDE ... -
XTemplate
2011-03-16 14:07 4532Ext XTemplate的应用: template. ... -
读取Properties文件中的内容填充本地combo
2011-03-10 16:24 1819首先定义一个properties文件放到classpath路径 ... -
汉字转换为拼音
2011-03-09 10:11 4557首先定义一个html页面: ... -
Ext Grid 实现批量添加或者修改
2011-03-02 22:30 4422将ExtJS Grid 中的record逐一转化为Bean,实 ... -
ExtJS中submit与Ajax的success
2010-11-12 23:10 7871Ajax中使用Success使用response接收后台传来的 ...
相关推荐
PHP开发者最常犯的11个MySQL错误编程小技巧共4页.pdf.zip
在平时的工作中,Python开发者很容易犯一些小错误,这些错误都很容易避免,本文总结了Python开发者最常犯的10个错误,一起来看下,不知你中枪了没有。Python允许开发者指定一个默认值给函数参数,虽然这是该语言的一...
这个资源是java 开发者容易犯的10个错误,是每个java初学者的必看内容
有经验的Java开发者和架构师容易犯的10个错误(上)Java开发Java经验技巧共8页.pdf.zip
有经验的Java开发者和架构师容易犯的10个错误(下)Java开发Java经验技巧共6页.pdf.zip
数据库开发者常犯的十大错误.doc数据库开发者常犯的十大错误.doc数据库开发者常犯的十大错误.doc
介绍AngularJS是如今最受欢迎的JS框架之一,简化开发过程是它的目标之一,这使得它非常适合于元型较小的apps的开发,但也扩展到具有全部特征的客户端应用的
详细介绍了web开发相关的javascript技术,读完本书基本上就系统掌握了javascript
prototype.js是一个非常优雅的javascript基础类库,对javascript做了大量的扩展,而且很好的支持Ajax,国外有多个基于此类库实现的效果库,也做得很棒。 prototype.js不仅是一个有很大实用价值的js库,而且有很高...
AngularJS是如今最受欢迎的JS框架之一,简化开发过程是它的目标之一,这使得它非常适合于元型较小的apps的开发,但也扩展到具有全部特征...下面给大家总结了AngularJS开发者最常犯的十个错误,有需要的可以参考学习下。
JavaScript开发者必备的10个超级实用工具.zip
JAVA开发者最常去的20个英文网站.JAVA开发者最常去的20个英文网站.JAVA开发者最常去的20个英文网站.JAVA开发者最常去的20个英文网站.JAVA开发者最常去的20个英文网站.
该资源是对javascript语言的系统性介绍,写作首要原则是准确、全面,但每个知识点简明,将庞大的js知识压缩为仅A4纸45页的简明教程(约6万字)。主要面向的读者是PHP开发人员,文中附带对比了php与js,帮助PHPer快速...
ie F12 开发者工具 错误分析 包含大部分使用ie开发的时候 进行F12调试报错的进行相关的错误的分析
文章列出了Java开发者常犯的是个错误。 1.将数组转换为ArrayList 为了将数组转换为ArrayList,开发者经常会这样做: List<String> list = Arrays.asList(arr); Arrays.asList()会返回一个ArrayList,但...
统信uos开启开发者模式软件
vue开发者工具最新版,vue-devtools6.1.4 使用方法: 打开chorme浏览器的设置,选择扩展程序,把下载好的.crx 文件拖进去即可。...这个是vue开发者工具的最新版本,亲测能用! 欢迎大家下载使用!