乱码乱a∨中文字幕,在线免费激情视频,亚洲欧美久久夜夜潮,国产在线网址

  1. <sub id="hjl7n"></sub>

    1. <sub id="hjl7n"></sub>

      <legend id="hjl7n"></legend>

      當前位置:首頁 >  站長 >  編程技術 >  正文

      for……in for……of 區(qū)別

       2020-11-05 16:13  來源: 田珊珊個人博客   我來投稿 撤稿糾錯

        阿里云優(yōu)惠券 先領券再下單

      1 遍歷數(shù)組通常用for循環(huán)

      ES5的話也可以使用forEach,ES5具有遍歷數(shù)組功能的還有map、filter、some、every、reduce、reduceRight等,只不過他們的返回結果不一樣。但是使用foreach遍歷數(shù)組的話,使用break不能中斷循環(huán),使用return也不能返回到外層函數(shù)。

      Array.prototype.method=function(){

      console.log(this.length);

      }

      var myArray=[1,2,4,5,6,7]

      myArray.name="數(shù)組"

      for (var index in myArray) {

      console.log(myArray[index]);

      }

      2 for in遍歷數(shù)組的毛病

      1.index索引為字符串型數(shù)字,不能直接進行幾何運算

      2.遍歷順序有可能不是按照實際數(shù)組的內部順序

      3.使用for in會遍歷數(shù)組所有的可枚舉屬性,包括原型。例如上栗的原型方法method和name屬性

      所以for in更適合遍歷對象,不要使用for in遍歷數(shù)組。

      那么除了使用for循環(huán),如何更簡單的正確的遍歷數(shù)組達到我們的期望呢(即不遍歷method和name),ES6中的for of更勝一籌.

      Array.prototype.method=function(){

      console.log(this.length);

      }

      var myArray=[1,2,4,5,6,7]

      myArray.name="數(shù)組";

      for (var value of myArray) {

      console.log(value);

      }

      for in遍歷的是數(shù)組的索引(即鍵名),而for of遍歷的是數(shù)組元素值。

      for of遍歷的只是數(shù)組內的元素,而不包括數(shù)組的原型屬性method和索引name

      3 遍歷對象

      遍歷對象 通常用for in來遍歷對象的鍵名

      Object.prototype.method=function(){

      console.log(this);

      }

      var myObject={

      a:1,

      b:2,

      c:3

      }

      for (var key in myObject) {

      console.log(key);

      }

      for in 可以遍歷到myObject的原型方法method,如果不想遍歷原型方法和屬性的話,可以在循環(huán)內部判斷一下,hasOwnPropery方法可以判斷某屬性是否是該對象的實例屬性

      for (var key in myObject) {

      if(myObject.hasOwnProperty(key)){

      console.log(key);

      }

      }

      同樣可以通過ES5的Object.keys(myObject)獲取對象的實例屬性組成的數(shù)組,不包括原型方法和屬性

      Object.prototype.method=function(){

      console.log(this);

      }

      var myObject={

      a:1,

      b:2,

      c:3

      }

      for..of適用遍歷數(shù)/數(shù)組對象/字符串/map/set等擁有迭代器對象的集合.但是不能遍歷對象,因為沒有迭代器對象.與forEach()不同的是,它可以正確響應break、continue和return語句

      for-of循環(huán)不支持普通對象,但如果你想迭代一個對象的屬性,你可以用for-in循環(huán)(這也是它的本職工作)或內建的Object.keys()方法:

      for (var key of Object.keys(someObject)) {

      console.log(key + ": " + someObject[key]);

      }

      遍歷map對象時適合用解構,例如;

      for (var [key, value] of phoneBookMap) {

      console.log(key + "'s phone number is: " + value);

      }

      附:跳出循環(huán)

      foreach 不能終止或跳過循環(huán)

      for of 支持跳出循環(huán)

      const fruits = ['Apple','Banana','Orange','Mango'];

      for(let fruit of fruits){

      if(fruit === 'Orange'){

      break;  //終止

      }

      console.log(fruit);  // Apple Banana

      }

      for(let fruit of fruits){

      if(fruit === 'Orange'){

      continue;  //跳出循環(huán)

      }

      console.log(fruit);  // Apple Banana Mango

      }

      文章來源:田珊珊個人博客

      來源地址:http://www.tianshan277.com/756.html

      申請創(chuàng)業(yè)報道,分享創(chuàng)業(yè)好點子。點擊此處,共同探討創(chuàng)業(yè)新機遇!

      相關文章

      熱門排行

      信息推薦