亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

20個實用的JavaScript技巧分享

2019-11-20 13:51:34
字體:
來源:轉載
供稿:網友

眾所周知,JavaScript是一門非常流行的編程語言,開發者用它不僅可以開發出炫麗的Web程序,還可以用它來開發一些移動應用程序(如PhoneGap或Appcelerator),它還有一些服務端實現,比如NodeJS、Wakanda以及其它實現。此外,許多開發者都會把JavaScript選為入門語言,使用它來做一些彈出窗口等小東西。

在這篇文章中,作者將會向大家分享JavaScript開發的小技巧、最佳實踐等非常實用的內容,不管你是前端開發者還是服務端開發者,都應該來看看這些小技巧,它們絕對會讓你受益的。

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

1.第一次給變量賦值時,別忘記var關鍵字

給一個未聲明的變量賦值,該變量會被自動創建為全局變量,在JS開發中,應該避免使用全局變量。

2.使用===替換==

并且永遠不要使用=或!=。

復制代碼 代碼如下:

[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.使用分號來作為行終止字符

在行終止的地方使用分號是一個很好的習慣,即使開發人員忘記加分號,編譯器也不會有任何提示,因為在大多數情況下,JavaScript解析器會自動加上。

4.創建構造函數

復制代碼 代碼如下:

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

5.應當小心使用typeof、instanceof和constructor

復制代碼 代碼如下:

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

6.創建一個Self-calling函數

這通常會被稱為自我調用的匿名函數或立即調用函數表達式(LLFE)。當函數被創建的時候就會自動執行,好比下面這個:

復制代碼 代碼如下:

(function(){ 
    // some private code that will be executed automatically 
})();   
(function(a,b){ 
    var result = a+b; 
    return result; 
})(10,20) 

7.給數組創建一個隨機項

復制代碼 代碼如下:

var items = [12, 548 , 'a' , 2 , 5478 , 'foo' , 8852, , 'Doe' , 2145 , 119]; 
 
var  randomItem = items[Math.floor(Math.random() * items.length)]; 

8.在特定范圍里獲得一個隨機數

下面這段代碼非常通用,當你需要生成一個假的數據用來測試時,比如在最低工資和最高之前獲取一個隨機值。

復制代碼 代碼如下:

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

9.在數字0和最大數之間生成一組隨機數

復制代碼 代碼如下:

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

10.生成一組隨機的字母數字字符

復制代碼 代碼如下:

function generateRandomAlphaNum(len) { 
    var rdmstring = ""; 
    for( ; rdmString.length < len; rdmString  += Math.random().toString(36).substr(2)); 
    return  rdmString.substr(0, len); 
 

11.打亂數字數組

復制代碼 代碼如下:

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函數

trim函數可以刪除字符串的空白字符,可以用在Java、C#、PHP等多門語言里。

復制代碼 代碼如下:

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

13.數組追加

復制代碼 代碼如下:

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.將參數對象轉換為數組

復制代碼 代碼如下:

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

15.驗證一個給定參數是否為數字

復制代碼 代碼如下:

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

16.驗證一個給定的參數為數組

復制代碼 代碼如下:

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

注意,如果toString()方法被重寫了,你將不會得到預期結果。
或者你可以這樣寫:

復制代碼 代碼如下:

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

同樣,如果你使用多個frames,你可以使用instancesof,如果內容太多,結果同樣會出錯。

復制代碼 代碼如下:

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.從數字數組中獲得最大值和最小值

復制代碼 代碼如下:

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.清空數組

復制代碼 代碼如下:

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

19.不要用delete從數組中刪除項目

開發者可以使用split來代替使用delete來刪除數組項。與其刪除數組中未定義項目,還不如使用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方法應該刪除一個對象屬性。

20.使用length屬性縮短數組

如上文提到的清空數組,開發者還可以使用length屬性縮短數組。

復制代碼 代碼如下:

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

如果你所定義的數組長度值過高,那么數組的長度將會改變,并且會填充一些未定義的值到數組里,數組的length屬性不是只讀的。

復制代碼 代碼如下:

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情久久久| 成人免费网视频| 97国产精品免费视频| 欧美最猛性xxxxx亚洲精品| 日韩av大片在线| 美女少妇精品视频| 成人在线视频网| 成人黄色片网站| 日韩高清欧美高清| 日韩欧美亚洲范冰冰与中字| 国产精品色婷婷视频| 亚洲黄页视频免费观看| 亚洲欧洲在线播放| 久久91亚洲人成电影网站| 日韩在线免费观看视频| 日韩av在线资源| 91免费在线视频| 欧美日韩在线一区| 国产精品xxxxx| 精品一区精品二区| 国产精品视频yy9099| 亚洲第一福利视频| 国产精品ⅴa在线观看h| 精品视频在线播放免| 宅男66日本亚洲欧美视频| 久久777国产线看观看精品| 精品视频久久久久久| 国产精品欧美亚洲777777| 26uuu日韩精品一区二区| 国产精品高潮呻吟久久av黑人| 中文国产成人精品| 久久琪琪电影院| 亚洲天堂av在线免费观看| 亚洲va国产va天堂va久久| 欧美在线观看网站| 在线精品播放av| 欧美极度另类性三渗透| 日韩网站免费观看| 久久精品精品电影网| 91精品国产91久久久久久最新| 97香蕉久久夜色精品国产| 国产精品稀缺呦系列在线| 青青在线视频一区二区三区| 一区二区三区无码高清视频| 国产97色在线| 91精品国产777在线观看| 国产精品久久在线观看| 亚洲视频在线看| 欧美精品www在线观看| 欧美视频在线视频| 欧美午夜影院在线视频| 亚洲国产欧美一区二区三区同亚洲| 亚洲综合精品一区二区| 国产精品91在线| 亚洲永久免费观看| 日本午夜人人精品| 久久久久久久亚洲精品| 美女福利精品视频| 色综合久综合久久综合久鬼88| 欧美黄色小视频| 日韩av日韩在线观看| 亚洲自拍小视频| 国产亚洲精品激情久久| 国产小视频国产精品| 亚洲欧洲日产国产网站| 国产精品一区二区在线| 亚洲区bt下载| 日韩欧美国产高清91| 久久九九免费视频| 国产精品视频资源| 91精品国产91久久久久久久久| 欧美日韩国产综合视频在线观看中文| 久久噜噜噜精品国产亚洲综合| 久久综合伊人77777蜜臀| 久久这里有精品视频| 热久久这里只有| 亚洲a级在线播放观看| 亚洲天堂男人天堂女人天堂| 国产91精品久久久久久久| 日韩在线观看免费高清完整版| 北条麻妃一区二区三区中文字幕| 国产精品中文字幕在线观看| 4k岛国日韩精品**专区| 91在线中文字幕| 精品少妇一区二区30p| 日韩高清免费观看| 欧美性视频精品| 亚洲综合自拍一区| 国产亚洲欧美日韩美女| 精品日韩美女的视频高清| 亚洲乱码av中文一区二区| 亚洲精品综合久久中文字幕| www.日韩不卡电影av| 亚洲香蕉成人av网站在线观看| 欧美精品在线免费| 91精品久久久久久久| 国产成人在线亚洲欧美| 国内伊人久久久久久网站视频| 国产精品福利无圣光在线一区| 最近中文字幕2019免费| 欧美日韩国产专区| 一区二区三区美女xx视频| 97在线免费观看| 成人免费视频网| 国产亚洲精品久久久优势| 亚洲精品自产拍| 中文字幕久热精品在线视频| 国产日韩精品入口| 亚洲国产91色在线| 久久久久久久久91| 精品久久久免费| 日韩一区av在线| 国产精品视频公开费视频| 国产精品一区二区三区成人| 青青在线视频一区二区三区| 九色91av视频| 久久久久久久久久婷婷| 亚洲国产精品女人久久久| 亚洲精品国产综合久久| 亚洲一区二区国产| 日韩视频免费看| 欧美激情中文网| 亚洲剧情一区二区| 欧美肥老妇视频| 亚洲男人天堂2023| 欧美激情精品久久久久久黑人| 91精品国产色综合久久不卡98口| 亚洲欧美另类自拍| 久久久精品免费| 日韩欧美综合在线视频| 久久精品夜夜夜夜夜久久| 亚洲精品免费一区二区三区| 91sao在线观看国产| 2020久久国产精品| 日本成人黄色片| 91精品久久久久久综合乱菊| 成人高h视频在线| 国产精品久久一区| 激情成人中文字幕| 久久精品99国产精品酒店日本| 欧美电影在线观看网站| 91中文在线观看| 日本精品视频在线播放| 91久久精品国产| 亚洲午夜av电影| 精品动漫一区二区| 亚洲精品成人久久电影| 亚洲老板91色精品久久| 亚洲三级黄色在线观看| 亚洲乱码国产乱码精品精| 久久香蕉精品香蕉| 57pao成人永久免费视频| 日本精品久久久| 大桥未久av一区二区三区| 91性高湖久久久久久久久_久久99| 日韩av一区在线观看| 久久亚洲国产精品成人av秋霞| 久久久av亚洲男天堂| 欧美亚洲国产视频小说| 裸体女人亚洲精品一区| 久久99国产综合精品女同| 日韩视频免费中文字幕| 日韩亚洲欧美中文高清在线| 欧美成人精品一区二区|