<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • javascript中for/in循環(huán)以及常見的使用技巧

    時間:2024-06-24 16:28:29 JavaScript 我要投稿
    • 相關(guān)推薦

    javascript中for/in循環(huán)以及常見的使用技巧

      JavaScript 支持不同類型的循環(huán):

      for - 循環(huán)代碼塊一定的次數(shù)

      for/in - 循環(huán)遍歷對象的屬性

      while - 當(dāng)指定的條件為 true 時循環(huán)指定的代碼塊

      do/while - 同樣當(dāng)指定的條件為 true 時循環(huán)指定的代碼塊

      1. in運算符:要求其左邊的運算數(shù)是一個字符串,或可以被轉(zhuǎn)換為字符串,右邊的運算數(shù)是一個對象或數(shù)組。如果該運算符左邊的值是右邊對象的一個屬性名,則返回true。

      例如:

      var point={x:1,y:2}; //對象直接量   var has_x="x" in point; //返回true   var has_z="z" in point; //返回false   var ts="toString" in point;//返回true,toString為繼承方法

      2. for/in語句:語法,

      for (variable in object)

      statement;

      提供了一種遍歷對象屬性的方法。

      例:

      for(var prop in my_object) {    document.write("name:"+prop+";value:"+my_object[prop],"
    ");  }

      javascript的數(shù)組是一種特殊的對象,因此for/in循環(huán)可以像枚舉對象屬性一樣枚舉數(shù)組下標(biāo)。

      可以把一個對象的所有屬性名復(fù)制到一個數(shù)組中,

      例:

      var o= {x:1,y:2,z:3};  var a=new Array();  var i=0;  for (a[i++] in o)   ;//空語句,用于初始化數(shù)組

      3. in運算符與for/in語句不同,for/in語句in的左邊可以是聲明一個變量的var語句,數(shù)組的一個元素或者是對象的一個屬性,不能使字符串。

      4. 數(shù)組常用的存取屬性運算符是“[]”,而不是“.”。使用“[]”來命名屬性名師字符串值,是動態(tài)的,可以在運行時改變,而不是一個標(biāo)識符“.”。

      例:

      var stock_name= get_stock_name_from_user();//從用戶處獲取股票名  var share= get_number_of_shares();//得到股票數(shù)量  portfolio[stock_name]= share;//動態(tài)地創(chuàng)建數(shù)組股票,并為每支股票賦值  將該例子與for/in循環(huán)一起使用,當(dāng)用戶輸入了他的投資組合,可以計算當(dāng)前總值  var value= 0;  for (stock in portfolio) {    value +=get_share_value(stock)*portfolio[stock];  }

      stock存取的是每支股票的名字。

      portfolio[stock]存取的是每支股票的數(shù)量。

      for-in循環(huán)

      功能:遍歷對象屬性,把屬性名和屬性值都提出來

      var obj = { "key1":"value1", "key2":"value2", "key3":"value3"};function EnumaKey(){ for(var key in obj ){  alert(key); }}function EnumaVal(){ for(var key in obj ){  alert(obj[key]); }}EnumaKey(obj)//key1 key2 key3EnumaVal(obj)//value1 value2 value3

      數(shù)組也可以這樣遍歷,但不推薦,因為不能保證順序,而且如果在Array的原型上添加了屬性,這個屬性也會被遍歷出來。

      for-in循環(huán)應(yīng)該用在非數(shù)組對象的遍歷上,使用for-in進行循環(huán)也被稱為“枚舉”。

      從技術(shù)上將,你可以使用for-in循環(huán)數(shù)組(因為JavaScript中數(shù)組也是對象),但這是不推薦的。因為如果數(shù)組對象已被自定義的功能增強,就可能發(fā)生邏輯錯誤。另外,在for-in中,屬性列表的順序(序列)是不能保證的。所以最好數(shù)組使用正常的for循環(huán),對象使用for-in循環(huán)。

    【javascript中for/in循環(huán)以及常見的使用技巧】相關(guān)文章:

    詳解JavaScript中的splice()使用方法04-01

    Javascript中arguments對象的詳解和使用方法03-31

    高效編寫JavaScript代碼的技巧03-10

    使用ajax操作JavaScript對象的方法03-08

    在Java中執(zhí)行JavaScript代碼04-01

    Javascript中typeof 用法歸納04-01

    JavaScript中的with關(guān)鍵字03-25

    perl- javascript中class的機制03-25

    JavaScript中的三種對象04-01

    主站蜘蛛池模板: 欧洲精品一区二区三区在线观看| 无码国内精品人妻少妇| 亚洲欧美日韩久久精品第一区| 久久精品国产99国产精品澳门| 亚洲av永久无码精品表情包| 国产精品原创巨作?v网站| jiucao在线观看精品| 亚洲国产一二三精品无码| 国产精品制服丝袜亚洲欧美| 亚洲精品高清国产一久久| 国产成人无码久久久精品一| 综合精品欧美日韩国产在线| 国产午夜精品久久久久九九| 日韩一级精品视频在线观看| 国产精品毛片VA一区二区三区| 中文字幕亚洲精品无码| 免费精品精品国产欧美在线欧美高清免费一级在线 | 国产欧美精品一区二区色综合| 99久久久精品免费观看国产| 亚洲精品无码午夜福利中文字幕| 拍国产真实乱人偷精品| 久久精品国产一区二区三区不卡| 国产成人1024精品免费| 亚洲精品免费视频| 久久精品男人影院| 久久精品视频网| 亚洲国产成人久久精品动漫 | 精品一区二区三区免费观看| 国产乱人伦精品一区二区在线观看 | 国产精品福利在线观看免费不卡| 国产欧美久久久精品| 国内精品91最新在线观看| 国产精品电影在线观看| 国产精品欧美日韩| 九九热在线精品视频| 九九热精品在线| 99久久国产综合精品五月天喷水 | 国产精品日本一区二区在线播放 | 99久久亚洲综合精品网站| 成人一区二区三区精品| 国产精品无码v在线观看|