国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

20個(gè)實(shí)用的JavaScript技巧分享

2024-05-06 16:11:08
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
這篇文章主要介紹了20個(gè)實(shí)用的JavaScript技巧分享,本文講解的都是開(kāi)發(fā)中總結(jié)出的編碼技巧、和最佳實(shí)踐,需要的朋友可以參考下
 
 

眾所周知,JavaScript是一門(mén)非常流行的編程語(yǔ)言,開(kāi)發(fā)者用它不僅可以開(kāi)發(fā)出炫麗的Web程序,還可以用它來(lái)開(kāi)發(fā)一些移動(dòng)應(yīng)用程序(如PhoneGap或Appcelerator),它還有一些服務(wù)端實(shí)現(xiàn),比如NodeJS、Wakanda以及其它實(shí)現(xiàn)。此外,許多開(kāi)發(fā)者都會(huì)把JavaScript選為入門(mén)語(yǔ)言,使用它來(lái)做一些彈出窗口等小東西。

在這篇文章中,作者將會(huì)向大家分享JavaScript開(kāi)發(fā)的小技巧、最佳實(shí)踐等非常實(shí)用的內(nèi)容,不管你是前端開(kāi)發(fā)者還是服務(wù)端開(kāi)發(fā)者,都應(yīng)該來(lái)看看這些小技巧,它們絕對(duì)會(huì)讓你受益的。

文中所提供的代碼片段都已經(jīng)過(guò)最新版的Chrome 30測(cè)試,該瀏覽器使用V8 JavaScript引擎(V8 3.20.17.15)。

1.第一次給變量賦值時(shí),別忘記var關(guān)鍵字

給一個(gè)未聲明的變量賦值,該變量會(huì)被自動(dòng)創(chuàng)建為全局變量,在JS開(kāi)發(fā)中,應(yīng)該避免使用全局變量。

2.使用===替換==

并且永遠(yuǎn)不要使用=或!=。

 

復(fù)制代碼代碼如下:

[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)來(lái)作為行終止字符

在行終止的地方使用分號(hào)是一個(gè)很好的習(xí)慣,即使開(kāi)發(fā)人員忘記加分號(hào),編譯器也不會(huì)有任何提示,因?yàn)樵诖蠖鄶?shù)情況下,JavaScript解析器會(huì)自動(dòng)加上。

4.創(chuàng)建構(gòu)造函數(shù)

 

復(fù)制代碼代碼如下:

function Person(firstName, lastName){  
    this.firstName =  firstName;  
    this.lastName = lastName;          
}    
  
var Saad = new Person("Saad", "Mousliki");  

 

5.應(yīng)當(dāng)小心使用typeof、instanceof和constructor

 

復(fù)制代碼代碼如下:

var arr = ["a", "b", "c"];  
typeof arr;   // return "object"   
arr  instanceof Array // true  
arr.constructor();  //[]  

 

6.創(chuàng)建一個(gè)Self-calling函數(shù)

這通常會(huì)被稱(chēng)為自我調(diào)用的匿名函數(shù)或立即調(diào)用函數(shù)表達(dá)式(LLFE)。當(dāng)函數(shù)被創(chuàng)建的時(shí)候就會(huì)自動(dòng)執(zhí)行,好比下面這個(gè): 

復(fù)制代碼代碼如下:

(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)

 

復(fù)制代碼代碼如下:

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ù)用來(lái)測(cè)試時(shí),比如在最低工資和最高之前獲取一個(gè)隨機(jī)值。

復(fù)制代碼代碼如下:

var x = Math.floor(Math.random() * (max - min + 1)) + min;  

 

9.在數(shù)字0和最大數(shù)之間生成一組隨機(jī)數(shù)

 

復(fù)制代碼代碼如下:

var numbersArray = [] , max = 100;  
  
for( var i=1; numbersArray.push(i++) < max;);  // numbers = [0,1,2,3 ... 100]  

 

10.生成一組隨機(jī)的字母數(shù)字字符

 

復(fù)制代碼代碼如下:

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ù)組

 

復(fù)制代碼代碼如下:

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等多門(mén)語(yǔ)言里。

 

復(fù)制代碼代碼如下:

String.prototype.trim = function(){return this.replace(/^/s+|/s+$/g, "");};

 

13.數(shù)組追加

 

復(fù)制代碼代碼如下:

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ù)組

 

復(fù)制代碼代碼如下:

var argArray = Array.prototype.slice.call(arguments);  

 

15.驗(yàn)證一個(gè)給定參數(shù)是否為數(shù)字

 

復(fù)制代碼代碼如下:

function isNumber(n){  
    return !isNaN(parseFloat(n)) && isFinite(n);  
}  

 

16.驗(yàn)證一個(gè)給定的參數(shù)為數(shù)組

 

復(fù)制代碼代碼如下:

function isArray(obj){  
    return Object.prototype.toString.call(obj) === '[object Array]' ;  
}  

 

注意,如果toString()方法被重寫(xiě)了,你將不會(huì)得到預(yù)期結(jié)果。 
或者你可以這樣寫(xiě):

復(fù)制代碼代碼如下:

Array.isArray(obj); // its a new Array method  

 

同樣,如果你使用多個(gè)frames,你可以使用instancesof,如果內(nèi)容太多,結(jié)果同樣會(huì)出錯(cuò)。

 

復(fù)制代碼代碼如下:

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ù)組中獲得最大值和最小值

 

復(fù)制代碼代碼如下:

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ù)組

 

復(fù)制代碼代碼如下:

var myArray = [12 , 222 , 1000 ];    
myArray.length = 0; // myArray will be equal to [].  

 

19.不要用delete從數(shù)組中刪除項(xiàng)目

開(kāi)發(fā)者可以使用split來(lái)代替使用delete來(lái)刪除數(shù)組項(xiàng)。與其刪除數(shù)組中未定義項(xiàng)目,還不如使用delete來(lái)替代。

 

復(fù)制代碼代碼如下:

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]   */  

也可以……
復(fù)制代碼代碼如下:

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ù)組,開(kāi)發(fā)者還可以使用length屬性縮短數(shù)組。

復(fù)制代碼代碼如下:

var myArray = [12 , 222 , 1000 , 124 , 98 , 10 ];    
myArray.length = 4; // myArray will be equal to [12 , 222 , 1000 , 124].  

 

如果你所定義的數(shù)組長(zhǎng)度值過(guò)高,那么數(shù)組的長(zhǎng)度將會(huì)改變,并且會(huì)填充一些未定義的值到數(shù)組里,數(shù)組的length屬性不是只讀的。

 

復(fù)制代碼代碼如下:

myArray.length = 10; // the new array length is 10   
myArray[myArray.length - 1] ; // undefined  

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 凌源市| 南岸区| 山丹县| 封开县| 凤城市| 桦南县| 星座| 富源县| 淮滨县| 平谷区| 松滋市| 德令哈市| 旌德县| 宜昌市| 古蔺县| 西乌| 西城区| 巴林右旗| 商河县| 襄城县| 高密市| 福泉市| 永顺县| 马关县| 尉氏县| 会昌县| 海城市| 裕民县| 巫溪县| 安图县| 永川市| 喀什市| 鄂州市| 绥江县| 万荣县| 如东县| 穆棱市| 涟水县| 美姑县| 平度市| 白朗县|