20個(gè)實(shí)用的JavaScript技巧分享
眾所周知,JavaScript是一門非常流行的編程語(yǔ)言,開發(fā)者用它不僅可以開發(fā)出炫麗的Web程序,還可以用它來開發(fā)一些移動(dòng)應(yīng)用程序(如PhoneGap或Appcelerator),它還有一些服務(wù)端實(shí)現(xiàn),比如NodeJS、Wakanda以及其它實(shí)現(xiàn)。此外,許多開發(fā)者都會(huì)把JavaScript選為入門語(yǔ)言,使用它來做一些彈出窗口等小東西。
在這篇文章中,作者將會(huì)向大家分享JavaScript開發(fā)的小技巧、最佳實(shí)踐等非常實(shí)用的內(nèi)容,不管你是前端開發(fā)者還是服務(wù)端開發(fā)者,都應(yīng)該來看看這些小技巧,它們絕對(duì)會(huì)讓你受益的。
文中所提供的代碼片段都已經(jīng)過最新版的Chrome 30測(cè)試,該瀏覽器使用V8 JavaScript引擎(V8 3.20.17.15)。
1.第一次給變量賦值時(shí),別忘記var關(guān)鍵字
給一個(gè)未聲明的變量賦值,該變量會(huì)被自動(dòng)創(chuàng)建為全局變量,在JS開發(fā)中,應(yīng)該避免使用全局變量。
2.使用===替換==
并且永遠(yuǎn)不要使用=或!=。
[10] === 10 // is false
[10] == 10 // is true
'10' == 10 // is true
'10' === 10 // is false
[] == 0 // is true
[] === 0 // is false
'' == false // is true but true == "a" is false
'' === false // is false
3.使用分號(hào)來作為行終止字符
在行終止的地方使用分號(hào)是一個(gè)很好的習(xí)慣,即使開發(fā)人員忘記加分號(hào),編譯器也不會(huì)有任何提示,因?yàn)樵诖蠖鄶?shù)情況下,JavaScript解析器會(huì)自動(dòng)加上。
4.創(chuàng)建構(gòu)造函數(shù)
function Person(firstName, lastName){
this.firstName = firstName;
this.lastName = lastName;
}
var Saad = new Person("Saad", "Mousliki");
5.應(yīng)當(dāng)小心使用typeof、instanceof和constructor
var arr = ["a", "b", "c"];
typeof arr; // return "object"
arr instanceof Array // true
arr.constructor(); //[]
6.創(chuàng)建一個(gè)Self-calling函數(shù)
這通常會(huì)被稱為自我調(diào)用的匿名函數(shù)或立即調(diào)用函數(shù)表達(dá)式(LLFE)。當(dāng)函數(shù)被創(chuàng)建的時(shí)候就會(huì)自動(dòng)執(zhí)行,好比下面這個(gè):
(function(){
// some private code that will be executed automatically
})();
(function(a,b){
var result = a+b;
return result;
})(10,20)
7.給數(shù)組創(chuàng)建一個(gè)隨機(jī)項(xiàng)
var items = [12, 548 , 'a' , 2 , 5478 , 'foo' , 8852, , 'Doe' , 2145 , 119];
var randomItem = items[Math.floor(Math.random() * items.length)];
8.在特定范圍里獲得一個(gè)隨機(jī)數(shù)
下面這段代碼非常通用,當(dāng)你需要生成一個(gè)假的數(shù)據(jù)用來測(cè)試時(shí),比如在最低工資和最高之前獲取一個(gè)隨機(jī)值。
var x = Math.floor(Math.random() * (max - min + 1)) + min;
9.在數(shù)字0和最大數(shù)之間生成一組隨機(jī)數(shù)
var numbersArray = [] , max = 100;
for( var i=1; numbersArray.push(i++) < max;); // numbers = [0,1,2,3 ... 100]
10.生成一組隨機(jī)的字母數(shù)字字符
function generateRandomAlphaNum(len) {
var rdmstring = "";
for( ; rdmString.length < len; rdmString += Math.random().toString(36).substr(2));
return rdmString.substr(0, len);
}
11.打亂數(shù)字?jǐn)?shù)組
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] */
12.字符串tim函數(shù)
trim函數(shù)可以刪除字符串的空白字符,可以用在Java、C#、PHP等多門語(yǔ)言里。
String.prototype.trim = function(){return this.replace(/^\s+|\s+$/g, "");};
13.數(shù)組追加
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] */
14.將參數(shù)對(duì)象轉(zhuǎn)換為數(shù)組
var argArray = Array.prototype.slice.call(arguments);
15.驗(yàn)證一個(gè)給定參數(shù)是否為數(shù)字
function isNumber(n){
return !isNaN(parseFloat(n)) && isFinite(n);
}
16.驗(yàn)證一個(gè)給定的參數(shù)為數(shù)組
function isArray(obj){
return Object.prototype.toString.call(obj) === '[object Array]' ;
}
注意,如果toString()方法被重寫了,你將不會(huì)得到預(yù)期結(jié)果。
或者你可以這樣寫:
Array.isArray(obj); // its a new Array method
同樣,如果你使用多個(gè)frames,你可以使用instancesof,如果內(nèi)容太多,結(jié)果同樣會(huì)出錯(cuò)。
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
17.從數(shù)字?jǐn)?shù)組中獲得最大值和最小值
var numbers = [5, 458 , 120 , -215 , 228 , 400 , 122205, -85411];
var maxInNumbers = Math.max.apply(Math, numbers);
var minInNumbers = Math.min.apply(Math, numbers);
18.清空數(shù)組
var myArray = [12 , 222 , 1000 ];
myArray.length = 0; // myArray will be equal to [].
19.不要用delete從數(shù)組中刪除項(xiàng)目
開發(fā)者可以使用split來代替使用delete來刪除數(shù)組項(xiàng)。與其刪除數(shù)組中未定義項(xiàng)目,還不如使用delete來替代。
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方法應(yīng)該刪除一個(gè)對(duì)象屬性。
20.使用length屬性縮短數(shù)組
如上文提到的清空數(shù)組,開發(fā)者還可以使用length屬性縮短數(shù)組。
var myArray = [12 , 222 , 1000 , 124 , 98 , 10 ];
myArray.length = 4; // myArray will be equal to [12 , 222 , 1000 , 124].
如果你所定義的數(shù)組長(zhǎng)度值過高,那么數(shù)組的長(zhǎng)度將會(huì)改變,并且會(huì)填充一些未定義的值到數(shù)組里,數(shù)組的length屬性不是只讀的。
myArray.length = 10; // the new array length is 10
myArray[myArray.length - 1] ; // undefined
相關(guān)文章
JS簡(jiǎn)單模擬觸發(fā)按鈕點(diǎn)擊功能的方法
這篇文章主要介紹了JS簡(jiǎn)單模擬觸發(fā)按鈕點(diǎn)擊功能的方法,涉及JavaScript事件調(diào)用機(jī)制及事件觸發(fā)的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11jquery操作下拉列表、文本框、復(fù)選框、單選框集合(收藏)
jquery操作拉列表、文本框、復(fù)選框、單選框集合。各種對(duì)下拉列表、文本框、復(fù)選框、單選框的jquery的相關(guān)操作。做為記錄和收藏的最好方法2014-01-01詳解JS如何實(shí)現(xiàn)文字溢出時(shí)用省略號(hào)...顯示
這篇文章主要為大家詳細(xì)介紹了JavaScript如何實(shí)現(xiàn)當(dāng)文本內(nèi)容過長(zhǎng)時(shí),中間顯示省略號(hào)...,兩端正常展示,有需要的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02超詳細(xì)小程序定位地圖模塊全系列開發(fā)教學(xué)
這篇文章主要介紹了超詳細(xì)小程序定位地圖模塊全系列開發(fā)教學(xué),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11javascript實(shí)現(xiàn)在下拉列表中顯示多級(jí)樹形菜單的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)在下拉列表中顯示多級(jí)樹形菜單的方法,涉及javascript屬性菜單的定義、構(gòu)造及遍歷等技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08JS實(shí)現(xiàn)的DOM插入節(jié)點(diǎn)操作示例
這篇文章主要介紹了JS實(shí)現(xiàn)的DOM插入節(jié)點(diǎn)操作,結(jié)合實(shí)例形式分析了javascript針對(duì)頁(yè)面dom元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-04-04獲取今天,昨天,本周,上周,本月,上月時(shí)間(實(shí)例分享)
本篇文章主要分享了獲取今天,昨天,本周,上周,本月,上月時(shí)間實(shí)例代碼,具有一定的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01