Web前端新手都应该了解的JavaScript 开发技巧

对于初学web前端的人而言,JavaScript都是他们学习中不可绕开知识点,Javascript 的很多扩展的特性是的它变得更加的犀利, 同时也给予程序员机会创建更漂亮并且更让用户喜欢的网站。对于从事web前端工作的小伙伴们来说JavaScript是必备技能,为了大家提高工作技能,小编为大家准备了这篇JavaScript 开发技巧,我们一起来看一看吧! 1、在使用 javascript 类库之前先学习 javascript互联网充斥着很多的 javascript 类库,很多程序员都往往使用 js 类库而不理解负面影响。强烈建议你在使用第三方类库之前学习基本的 JS 代码,否则,你就准备着倒霉吧。2、思考后再修改 prototypes添加新的属性到对象 prototype 中是导致脚本出错的常见原因。yourObject.prototype.anotherFunction = 'Hello';yourObject.prototype.anotherMethod = function(){...}在上面代码中,所有的变量都会被影响,因为他们都继承于 yourObject。这样的使用会导致意想不到的行为。所以建议在使用完后删除类似的修改。yourObject.prototype.anotherFunction = 'Hello';yourObject.prototype.anotherMethod = function () { … };test.anotherMethod();delete yourObject.prototype.anotherFunction = 'Hello';delete yourObject.prototype.anotherMethod = function () { … };3、Debug Javascript 代码即使最好的开发人员都会犯错。为了最大化的减少类似错误,请在你的 debugger 中运行你的代码,确认你没有遇到任何细微的错误。4、避免 Eval你的 JS 在没有 eval 方法的时候也可以很好的工作。eval 允许访问 javascript 编译器。如果一个字符串作为参数传递到 eval,那么它的结果可以被执行。这会很大的降低代码的性能。尽量避免在产品环境中使用 eval。5、 最小化 DOM 访问DOM 是最复杂的 API,会使得代码执行过程变慢。有时候 web 页面可能没有加载或者加载不完整。最好避免 DOM。6、尽可能的保持代码简洁可能大家都听到过了N遍这个代码简洁问题了。作为一个开发人员你可能在你的代码开发过程中使用了很多次,但千万不要在 js 开发中忘记这点。§ 尽量在开发模式中添加注释和空格,这样保持代码的可读性§ 在发布到产品环境前请将空格和注释都删除,并且尽量缩写变量和方法名使用第三方工具帮助你实现压缩 javascript。7、不要用 “SetTimeOut” 和 “Setinterval” 方法来作为 “Eval” 的备选setTimeOut( "document.getID('value')", 3000);在以上代码中 document.getID(‘value’) 在 setTimeOut 方法中被作为字符串来处理。 这类似于 eval 方法,在每个代码执行中来执行一个字符串,因此会降低性能,因此,建议在这些方法中传递一个方法。setTimeOut(yourFunction, 3000);8、[] 比 new Array(); 更好一个常犯的错误在于使用当需要数组的时候使用一个对象或者该使用对象的时候使用一个数组。但是使用原则很简单:“当属性名称是小的连续整数,你应该使用数组。否则,使用一个对象” – Douglas Crockford, JavaScript: Good Parts 的作者.建议:var a = ['1A','2B'];避免:var a = new Array();a[0] = "1A";a[1] = "2B";9、尽量不要多次使用 var在初始每一个变量的时候,程序员都习惯使用 var 关键字。相反,建议你使用逗号来避免多余的关键字,并且减少代码体积。 如下:var variableOne = 'string 1',variableTwo = 'string 2',variableThree = 'string 3';10、不要忽略分号 “;”这往往是大家花费数个小时进行 debug 的原因之一。我很确信你肯定也在其它的文章中阅读过以上相关的内容,但是大家可能往往都忽略了很多基本的规则。 你是不是也曾经忽略过分号。是不是也遇到过 eval 关键字问题导致性能问题?

本文章由javascript技术分享原创和收集

发表评论 (审核通过后显示评论):