JavaScript實現的in_array函數,javascriptin_array

來源:互聯網
上載者:User

JavaScript實現的in_array函數,javascriptin_array

在JS中要判斷一個值是否在數組中並沒有函數直接使用,如PHP中就有in_array()這個函數。但我們可以寫一個類似in_array()函數來判斷是一個值否在函數中。

/** * JS判斷一個值是否存在數組中 */ // 定義一個判斷函數var in_array = function(arr){  // 判斷參數是不是數組  var isArr = arr && console.log(      typeof arr==='object' ? arr.constructor===Array ? arr.length ? arr.length===1 ? arr[0]:arr.join(','):'an empty array': arr.constructor: typeof arr     );   // 不是數組則拋出異常  if(!isArr){    throw "arguments is not Array";   }   // 遍曆是否在數組中  for(var i=0,k=arr.length;i<k;i++){    if(this==arr[i]){      return true;      }  }   // 如果不在數組中就會返回false  return false;} // 給字串添加原型String.prototype.in_array = in_array;// 給數字類型添加原型Number.prototype.in_array = in_array; // 聲明一個數組var arr = Array('blue','red','110','120'); // 字串測試var str = 'red';var isInArray = str.in_array(arr);alert(isInArray); // true // 數字測試var num = 119;var isInArray = num.in_array(arr);alert(isInArray); // false

如果傳入的不是數組則會拋出異常

 

/** * JS判斷一個值是否存在數組中 */ // 定義一個判斷函數var in_array = function(arr){  // 判斷參數是不是數組  var isArr = arr && console.log(      typeof arr==='object' ? arr.constructor===Array ? arr.length ? arr.length===1 ? arr[0]:arr.join(','):'an empty array': arr.constructor: typeof arr     );   // 不是數組則拋出異常  if(!isArr){    throw "arguments is not Array";   }   // 遍曆是否在數組中  for(var i=0,k=arr.length;i<k;i++){    if(this==arr[i]){      return true;      }  }   // 如果不在數組中就會返回false  return false;} // 給字串添加原型String.prototype.in_array = in_array;// 給數字類型添加原型Number.prototype.in_array = in_array; // 聲明一個數組var arr = null; // 字串測試var str = 'red';var isInArray = str.in_array(arr);alert(isInArray); // uncaught exception: arguments is not Array

直接報錯:


javascript實現兩個數相加的函數是什?

由於priceArray[i].value是字串,所以你直接相加的話是按字串串連來處理的,應該先把它轉化為數字:
totalPrice = totalPrice+parseInt(priceArray[i].value);
其實標準的javascript寫法是:
totalPrice += parseInt(priceArray[i].value);
 
javascript 裡,怎自訂函數,實現Array對象的push功可以

按照你這段程式
這一行

new_push(arr,"20"); //用自訂函數,實現新數組元素的添加

應改成 arr=new_push(arr,"20");
 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.