11 – 生成一个随机的数字字母字符串 代码如下:
function generateRandomAlphaNum(len) { var rdmstring = ""; for( ; rdmString.length return rdmString.substr(0, len); }
12 – 打乱一个数字数组 代码如下:
var numbers = [5, 458 , 120 , -215 , 228 , 400 , 122205, -85411]; numbers = numbers.sort(function(){ return Math.random() - 0.5}); /* the array numbers will be equal for example to [120, 5, 228, -215, 400, 458, -85411, 122205] */
13 – String的trim函数 在Java、C#、PHP和很多其他语言中都有一个经典的 trim 函数,用来去除字符串中的空格符,而在Javascript中并没有,所以我们需要在String对象上加上这个函数。 代码如下:
String.prototype.trim = function(){return this.replace(/^\s+|\s+$/g, "");};//去掉字符串的前后空格,不包括字符串内部空格
14 – 附加(append)一个数组到另一个数组上 代码如下:
var array1 = [12 , "foo" , {name: "Joe"} , -2458]; var array2 = ["Doe" , 555 , 100]; Array.prototype.push.apply(array1, array2); /* array1 will be equal to [12 , "foo" , {name "Joe"} , -2458 , "Doe" , 555 , 100] */ //其实concat可以直接实现两个数组的连接,但是它的返回值是一个新的数组。这里是直接改变array1
15 – 将arguments对象转换成一个数组
代码如下:
var argArray = Array.prototype.slice.call(arguments); arguments对象是一个类数组对象,但不是一个真正的数组
16 – 验证参数是否是数字(number) 代码如下:
function isNumber(n){ return !isNaN(parseFloat(n)) && isFinite(n); }
17 – 验证参数是否是数组 代码如下:
function isArray(obj){ return Object.prototype.toString.call(obj) === '[object Array]' ; }
注意:如果toString()方法被重写了(overridden),你使用这个技巧就不能得到想要的结果了。或者你可以使用: 代码如下:
Array.isArray(obj); // 这是一个新的array的方法
如果你不在使用多重frames的情况下,你还可以使用 instanceof 方法。但如果你有多个上下文,你就会得到错误的结果。 代码如下:
var myFrame = document.createElement('iframe'); document.body.appendChild(myFrame); var myArray = window.frames[window.frames.length-1].Array; var arr = new myArray(a,b,10); // [a,b,10] // instanceof will not work correctly, myArray loses his constructor // constructor is not shared between frames arr instanceof Array; // false
18 – 获取一个数字数组中的最大值或最小值 代码如下:
var numbers = [5, 458 , 120 , -215 , 228 , 400 , 122205, -85411]; var maxInNumbers = Math.max.apply(Math, numbers); var minInNumbers = Math.min.apply(Math, numbers); //译者注:这里使用了Function.prototype.apply方法传递参数的技巧
19 – 清空一个数组 代码如下:
var myArray = [12 , 222 , 1000 ]; myArray.length = 0; // myArray will be equal to [].
20 – 不要使用 delete 来删除一个数组中的项。
使用 splice 而不要使用 delete 来删除数组中的某个项。使用 delete 只是用 undefined 来替换掉原有的项,并不是真正的从数组中删除。
不要使用这种方式:
代码如下:
var items = [12, 548 ,'a' , 2 , 5478 , 'foo' , 8852, , 'Doe' ,2154 , 119 ]; items.length; // return 11 delete items[3]; // return true items.length; // return 11 /* items will be equal to [12, 548, "a", undefined × 1, 5478, "foo", 8852, undefined × 1, "Doe", 2154, 119] */
而使用: 代码如下:
var items = [12, 548 ,'a' , 2 , 5478 , 'foo' , 8852, , 'Doe' ,2154 , 119 ]; items.length; // return 11 items.splice(3,1) ; items.length; // return 10 /* items will be equal to [12, 548, "a", 5478, "foo", 8852, undefined × 1, "Doe", 2154, 119] */
delete 方法应该被用来删除一个对象的某个属性。21 – 使用 length 来截短一个数组
跟上面的清空数组的方式类似,我们使用 length 属性来截短一个数组。
代码如下:
var myArray = [12 , 222 , 1000 , 124 , 98 , 10 ]; myArray.length = 4; // myArray will be equal to [12 , 222 , 1000 , 124].
此外,如果你将一个数组的 length 设置成一个比现在大的值,那么这个数组的长度就会被改变,会增加新的 undefined 的项补上。 数组的 length 不是一个只读属性。 代码如下:
myArray.length = 10; // the new array length is 10 myArray[myArray.length - 1] ; // undefined
22 – 使用逻辑 AND/OR 做条件判断 代码如下:
var foo = 10; foo == 10 && doSomething(); // 等价于 if (foo == 10) doSomething(); foo == 5 || doSomething(); // 等价于 if (foo != 5) doSomething();
逻辑 AND 还可以被使用来为函数参数设置默认值 代码如下:
function doSomething(arg1){ Arg1 = arg1 || 10; // 如果arg1没有被设置的话,Arg1将被默认设成10 }
23 – 使用 map() 方法来遍历一个数组里的项 代码如下:
var squares = [1,2,3,4].map(function (val) { return val * val; }); // squares will be equal to [1, 4, 9, 16]
24 – 四舍五入一个数字,保留N位小数 代码如下:
var num =2.443242342; num = num.toFixed(4); // num will be equal to 2.4432
25 – 浮点数问题 代码如下:
0.1 + 0.2 === 0.3 // is false 9007199254740992 + 1 // is equal to 9007199254740992 9007199254740992 + 2 // is equal to 9007199254740994
为什么会这样? 0.1+0.2等于0.30000000000000004。你要知道,所有的Javascript数字在内部都是以64位二进制表示的浮点数,符合IEEE 754标准。更多的介绍,可以阅读这篇博文。你可以使用 toFixed() 和 toPrecision() 方法解决这个问题。26 – 使用for-in遍历一个对象内部属性的时候注意检查属性
下面的代码片段能够避免在遍历一个对象属性的时候访问原型的属性
代码如下:
for (var name in object) { if (object.hasOwnProperty(name)) { // do something with name } }
27 – 逗号操作符 代码如下:
var a = 0; var b = ( a++, 99 ); console.log(a); // a will be equal to 1 console.log(b); // b is equal to 99
28 – 缓存需要计算和查询(calculation or querying)的变量
对于jQuery选择器,我们最好缓存这些DOM元素。
代码如下:
var navright = document.querySelector('#right'); var navleft = document.querySelector('#left'); var navup = document.querySelector('#up'); var navdown = document.querySelector('#down');
29 – 在调用 isFinite()之前验证参数 代码如下:
isFinite(0/0) ; // false isFinite("foo"); // false isFinite("10"); // true isFinite(10); // true isFinite(undifined); // false isFinite(); // false isFinite(null); // true !!!
30 – 避免数组中的负数索引(negative indexes) 代码如下:
var numbersArray = [1,2,3,4,5]; var from = numbersArray.indexOf("foo") ; // from is equal to -1 numbersArray.splice(from,2); // will return [5]
确保调用 indexOf 时的参数不是负数。
31 – 基于JSON的序列化和反序列化(serialization and deserialization)
代码如下:
var person = {name :'Saad', age : 26, department : {ID : 15, name : "R&D"} }; var stringFromPerson = JSON.stringify(person); /* stringFromPerson is equal to "{"name":"Saad","age":26,"department":{"ID":15,"name":"R&D"}}" */ var persOnFromString= JSON.parse(stringFromPerson); /* personFromString is equal to person object */
32 – 避免使用 eval() 和 Function 构造函数 使用 eval 和 Function 构造函数是非常昂贵的操作,因为每次他们都会调用脚本引擎将源代码转换成可执行代码。 代码如下:
var func1 = new Function(functionCode); var func2 = eval(functionCode);
33 – 避免使用 with() 使用 with() 会插入一个全局变量。因此,同名的变量会被覆盖值而引起不必要的麻烦。34 – 避免使用 for-in 来遍历一个数组 避免使用这样的方式: 代码如下:
var sum = 0; for (var i in arrayNumbers) { sum += arrayNumbers[i]; }
更好的方式是: 代码如下:
var sum = 0; for (var i = 0, len = arrayNumbers.length; i sum += arrayNumbers[i]; }
附加的好处是,i 和 len 两个变量的取值都只执行了一次,会比下面的方式更高效: 代码如下:
for (var i = 0; i
为什么?因为arrayNumbers.length每次循环的时候都会被计算。35 – 在调用 setTimeout() 和 setInterval() 的时候传入函数,而不是字符串。 如果你将字符串传递给 setTimeout() 或者 setInterval(),这个字符串将被如使用 eval 一样被解析,这个是非常耗时的。 不要使用: 代码如下:
setInterval('doSomethingPeriodically()', 1000); setTimeOut('doSomethingAfterFiveSeconds()', 5000)
而用: 代码如下:
setInterval(doSomethingPeriodically, 1000); setTimeOut(doSomethingAfterFiveSeconds, 5000);
36 – 使用 switch/case 语句,而不是一长串的 if/else 在判断情况大于2种的时候,使用 switch/case 更高效,而且更优雅(更易于组织代码)。但在判断的情况超过10种的时候不要使用 switch/case。37 – 在判断数值范围时使用 switch/case 在下面的这种情况,使用 switch/case 判断数值范围的时候是合理的: 代码如下:
function getCategory(age) { var category = ""; switch (true) { case isNaN(age): category = "not an age"; break; case (age >= 50): category = "Old"; break; case (age <= 20): category = "Baby"; break; default: category = "Young"; break; }; return category; } getCategory(5); // will return "Baby" //一般对于数值范围的判断,用 if/else 会比较合适。 switch/case 更适合对确定数值的判断
38 – 为创建的对象指定prototype对象 写一个函数来创建一个以指定参数作为prototype的对象是有可能: 代码如下:
function clone(object) { function OneShotConstructor(){}; OneShotConstructor.prototype= object; return new OneShotConstructor(); } clone(Array).prototype ; // []
39 – 一个HTML转义函数 代码如下:
function escapeHTML(text) { var replacements= {"<": "<", ">": ">","&": "&", "\"": """}; return text.replace(/[<>&"]/g, function(character) { return replacements[character]; }); }
40 – 避免在循环内部使用 try-catch-finally 在运行时,每次当 catch 从句被执行的时候,被捕获的异常对象会赋值给一个变量,而在 try-catch-finally 结构中,每次都会新建这个变量。
避免这样的写法:
代码如下:
var object = ['foo', 'bar'], i; for (i = 0, len = object.length; i try { // do something that throws an exception } catch (e) { // handle exception } }
而使用: 代码如下:
var object = ['foo', 'bar'], i; try { for (i = 0, len = object.length; i // do something that throws an exception } } catch (e) { // handle exception }
41 – 为 XMLHttpRequests 设置超时。 在一个XHR请求占用很长时间后(比如由于网络问题),你可能需要中止这次请求,那么你可以对XHR调用配套使用 setTimeout()。 代码如下:
var xhr = new XMLHttpRequest (); xhr.Onreadystatechange= function () { if (this.readyState == 4) { clearTimeout(timeout); // do something with response data } } var timeout = setTimeout( function () { xhr.abort(); // call error callback }, 60*1000 /* timeout after a minute */ ); xhr.open('GET', url, true); xhr.send();
此外,一般你应该完全避免同步的Ajax请求。42 – 处理WebSocket超时 通常,在一个WebSocket连接创建之后,如果你没有活动的话,服务器会在30秒之后断开(time out)你的连接。防火墙也会在一段时间不活动之后断开连接。
为了防止超时的问题,你可能需要间歇性地向服务器端发送空消息。要这样做的话,你可以在你的代码里添加下面的两个函数:一个用来保持连接,另一个用来取消连接的保持。通过这个技巧,你可以控制超时的问题。
使用一个 timerID:
代码如下:
var timerID = 0; function keepAlive() { var timeout = 15000; if (webSocket.readyState == webSocket.OPEN) { webSocket.send(''); } timerId = setTimeout(keepAlive, timeout); } function cancelKeepAlive() { if (timerId) { cancelTimeout(timerId); } }
keepAlive()方法应该被添加在webSOcket连接的 onOpen() 方法的最后,而 cancelKeepAlive() 添加在 onClose() 方法的最后。43 – 牢记,原始运算符始终比函数调用要高效。使用VanillaJS。 举例来说,不使用: 代码如下:
var min = Math.min(a,b); A.push(v);
而用: 代码如下:
var min = a A[A.length] = v;
44 – 编码的时候不要忘记使用代码整洁工具 。在上线之前使用JSLint和代码压缩工具(minification)(比如JSMin)。《省时利器:代码美化与格式化工具》
45 – Javascript是不可思议的。 总结
我知道还有很多其他的技巧,窍门和最佳实践,所以如果你有其他想要添加或者对我分享的这些有反馈或者纠正,请在评论中指出。
推荐阅读
本文介绍了如何使用jQuery和AJAX来实现动态更新两个div的方法。通过调用PHP文件并返回JSON字符串,可以将不同的文本分别插入到两个div中,从而实现页面的动态更新。 ...
[详细]
蜡笔小新 2023-12-11 10:07:32
本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ...
[详细]
蜡笔小新 2023-12-12 12:45:59
RT之前做了一次灵越7590黑苹果炒作业的文章,希望能够分享给更多不想折腾的人。kawauso:教你如何给灵越7590黑苹果抄作业zhuanlan.z ...
[详细]
蜡笔小新 2023-12-10 19:11:07
为什么80%的码农都做不了架构师?JQuery1.2后getJSON方法支持跨域读取json数据,原理是利用一个叫做jsonp的概念。当然 ...
[详细]
蜡笔小新 2023-12-09 18:24:55
本文介绍了影响网站打开时间的两个因素,即网页加载速度和网站页面大小。重点讲解了如何通过压缩网站页面来减少页面加载时间。具体包括图片压缩、Javascript压缩、CSS压缩和HTML压缩等方法,并推荐了相应的压缩工具。此外,还提到了一款Google Chrome插件——网页加载速度分析工具Speed Tracer。 ...
[详细]
蜡笔小新 2023-12-09 09:17:00
web前端|js教程off-canvas,部分,超出web前端-js教程mui框架中off-canvas侧滑的一个缺点就是无法出现滚动条,因为它主要用途是设置类似于qq界面的那种格 ...
[详细]
蜡笔小新 2023-10-17 20:40:03
本文由编程笔记#小编为大家整理,主要介绍了markdown[软件代理设置]相关的知识,希望对你有一定的参考价值。 ...
[详细]
蜡笔小新 2023-10-17 18:19:28
题目描述http:acm.nyist.netJudgeOnlineproblem.php?pid306Dr.Kong设计的机器人卡多非常爱玩,它常常偷偷跑出实验室,在某个游乐场 ...
[详细]
蜡笔小新 2023-10-16 16:57:46
HybridApp在过去的两年中已经成为移动界的核心话题,但是作为一名Web开发者来说要如何站在移动互联网的浪潮之巅呢?是选择学习原生开发,研究Java、Object-C、C#等语言,还是 ...
[详细]
蜡笔小新 2023-09-25 19:22:47
本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ...
[详细]
蜡笔小新 2023-12-13 17:36:52
本文介绍了在VS写C#项目导入MySQL数据源时出现报错“You have a usable connection already”的问题,并给出了正确的解决方法。详细描述了问题的出现情况和报错信息,并提供了解决该问题的步骤和注意事项。 ...
[详细]
蜡笔小新 2023-12-13 16:31:57
本文介绍了使用switch语句时的一些用法和注意事项,包括如何实现"fall through"、default语句的作用、在case语句中定义变量时可能出现的问题以及解决方法。同时也提到了C#严格控制switch分支不允许贯穿的规定。通过本文的介绍,读者可以更好地理解和使用switch语句。 ...
[详细]
蜡笔小新 2023-12-13 14:47:39
本文介绍了JavaScript的起源和发展历程,以及其在前端验证和服务器端开发中的应用。同时,还介绍了ECMAScript标准、DOM对象和BOM对象的作用及特点。最后,对JavaScript作为解释型语言和编译型语言的区别进行了说明。 ...
[详细]
蜡笔小新 2023-12-10 17:45:49
fin7,后门,工具,伪装,成,白, ...
[详细]
蜡笔小新 2023-10-17 15:15:23
1.淘宝模拟登录2.天猫商品数据爬虫3.爬取淘宝我已购买的宝贝数据4.每天不同时间段通过微信发消息提醒女友5.爬取5K分辨率超清唯美壁纸6.爬取豆瓣排行榜电影数据(含GUI界面版) ...
[详细]
蜡笔小新 2023-10-16 18:29:34
粉红的少女
网络借贷平台http://www.kljie.com/