JS開發中的一些小技巧和方法

來源:互聯網
上載者:User

標籤:最大   轉化   class   oms   ==   導致   fixed   布爾   瀏覽器   

產生指定範圍內的隨機數

    當我們需要擷取指定範圍(min,max)內的整數的時候,下面的代碼非常適合;這段代碼用的還挺多的。

function setRadomNum(min,max){    return  Math.floor(Math.random() * (max - min + 1)) + min;}
json轉url參數

當我們進行http請求時,可能需要把json轉化為url參數,這時下面這段代碼就派上用場了。

function json2url(json) {    var arr=[];    for(var name in json){        arr.push(name+‘=‘+json[name]);    }    return arr.join(‘&‘);}

 

驗證是否為數組
function isArray(obj){    return Array.isArray(obj) || Object.prototype.toString.call(obj) === ‘[object Array]‘;}//先檢驗本地是否有Array.isArray函數,沒有就執行後面的方法檢測

 

清空數組
方式一 通過將長度設定為0var arr=[1,2,3,4,5];arr.length=0;方式二 通過splice方法 var arr=[1,2,3,4,5];arr.splice(0,arr.length);//方式三var arr=[1,2,3,4,5];arr=[];

 

方式三將一個新的數組的引用賦值給變數,其他引用並不受影響。 這意味著以前數組的內容被引用的話將依舊存在於記憶體中,這將導致記憶體流失。最高效的方法是第一種,所以推薦使用第一種方法清空數組。

保留指定小數位

這個需求在項目中也是很常見的,可以toFixed()方法

var num =3.1415926;num = num.toFixed(4); //toFixed()方法可把 Number 四捨五入為指定小數位元的數字,括弧裡面取值0~20(包括0和20)console.log(num); //3.1416

 

打亂數組的順序
方式一arr.sort(function(){return Math.random()-0.5});方式二function shuffle(arr) {    var i,         j,        temp;    for (i = arr.length - 1; i > 0; i--) {        j = Math.floor(Math.random() * (i + 1));        temp = arr[i];        arr[i] = arr[j];        arr[j] = temp;    }    return arr;    };

 

方式一使用了數組的內建排序方法:sort,而方式二是藉助了一個中間量,隨機數組裡的兩個值,讓它們交換位置。

使用 === 而不是 ==

== (或者 !=) 操作在需要的情況下自動進行了類型轉換。=== (或 !==)操作不會執行任何轉換。===在比較值和類型時,可以說比==更快。

[10] ==  10      // 為 true[10] === 10      // 為 false‘10‘ ==  10      // 為 true‘10‘ === 10      // 為 false []  ==  0       // 為 true []  === 0       // 為 false ‘‘  ==  false   // 為 true 但 true == "a" 為false ‘‘  === false   // 為 false

 

妙用“&&”和“||”

||&&運算子妙用,可用於精簡代碼,降低程式的可讀性。

用於賦值
&&:從左往右依次判斷,噹噹前值為true則繼續,為false則返回此值(是返回未轉換為布爾值時的原值哦)
|| : 從左往右依次判斷,噹噹前值為false則繼續,為true則返回此值(是返回未轉換為布爾值時的原值哦)

var attr = true && 4 && "aaa"; //aaa;var attr = true && 0 && "aaa"; //0var attr = 100 || 12; //100var attr = "e" || "hahaha" //‘e‘var attr = "" || "hahaha" //‘hahaha‘

 

用於條件執行語句

// 普通的if語句if(test){  isTrue();}// 上面的語句可以使用 ‘&&‘ 寫為:( test && isTrue() );test = false;if(!test){  isFalse();}// 上面的語句可以使用 ‘||‘ 寫為:( test || isFalse());

用於多次判斷後的賦值

var add_level = 0; if(add_step == 5){     add_level = 1; } else if(add_step == 10){     add_level = 2; } else if(add_step == 12){     add_level = 3; } else if(add_step == 15){     add_level = 4; } else {     add_level = 0; }//可以寫成var add_level = (add_step==5 && 1) || (add_step==10 && 2) || (add_step==12 && 3) || (add_step==15 && 4) || 0;
擷取數組中的最大值或最小值
function maxAndMin(arr){    return {       max:Math.max.apply(null,arr.join(‘,‘).split(‘,‘)),       min:Math.min.apply(null,arr.join(‘,‘).split(‘,‘))    }}

 

該方法適合一維或者多維陣列。

隨機擷取數組裡的元素
function getRadomFromArr(arr){    return arr[Math.floor(Math.random()*arr.length)];}
從數組裡尋找指定的值

查到了返回true,沒查到返回false

function findInArr(arr, value){    for (var i=0; i<arr.length; i++){        if (arr[i] == value){            return true;        }    }        return false;}
產生指定長度的隨機數字字母字串
function getRandomStr(len) {    var str = "";    for( ; str.length < len; str  += Math.random().toString(36).substr(2));    return  str.substr(0, len);}

 

去除字串的空格

雖然在ECMAScript5中已經實現了trim方法,它對低版本瀏覽器並不支援,所以有時候我們需要自己實現

去除首尾空格

function trim(str){    return str.replace(/(^\s*)|(\s*$)/g, "");}trim(‘  hello world    ‘); //"hello world"

 

去除所有空格

function trimAll(str){    return str.replace(/\s+/g,"");}trimAll(‘   he ll o  wo  r ld    ‘); //"helloworld"

 

JS開發中的一些小技巧和方法

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.