forEach over es6 Map in JSX

后端 未结 4 2003
情深已故
情深已故 2021-02-19 02:22

I had a javascript array that was rendering components using array.map. I switched this array to an es6 Map in order to be able to use key-value pairs

相关标签:
4条回答
  • 2021-02-19 02:28

    You are correct, forEach doesn't return anything, use map instead, it will return an array of JSX components.

    Map will allow you to access the key as well: resultsByGuid.map((item, key) => { })

    Edit I apologize for jumping the gun and not reading that you were using a Map data structure. forEach won't render anything because you need the return value, you could implement your own Array.map like iterator:

    const mapIterator = (map, cb) => {
      const agg = [];
      for(let [key, value] of map) {
        agg.push(cb(value, key));
      }
      return agg;
    };
    
    <div className='gallery__items'>
      {mapIterator(resultsByGuid, (result, index) => {
        key++;
        return this.renderGalleryItem(result, key);
      })}
    </div>
    

    Edit 2 And thanks to @zerkms for pointing out what should've been obvious to me:

    <div className='gallery__items'>
      {Array.from(resultsByGuid.values()).map((result, index) => {
        key++;
        return this.renderGalleryItem(result, key);
      })}
    </div>
    
    0 讨论(0)
  • 2021-02-19 02:32

    another option, where options is an es6 Map() ..

    <select>
      {
        [...options].map((entry) => {
          let key = entry[0]
          let value = entry[1]
          return <option key={ key } value={ key }>{ value }</option>
        })
      }
    </select>
    
    0 讨论(0)
  • 2021-02-19 02:34

    Just a slight improvement on danday74's example using array destructuring. With options the ES6 Map:

    <select>
        {[...options].map(([key, value]) => (
            <option key={key} value={key}>
                {value}
            </option>
        ))}
    </select>;
    
    0 讨论(0)
  • 2021-02-19 02:50

    If you call .entries() on your map you will get an iterator object which for every key/value pair contains an array with the structure: [key, value] as mentioned here.

    So you could just do:

    <div className='gallery__items'>
      {resultsByGuid.entries().map((result) => {
        return this.renderGalleryItem(result[1], result[0]);
      })}
    </div>
    

    I am still wondering, if there's a simpler solution though.

    0 讨论(0)
提交回复
热议问题