React.js 迭代对象而不是 Object.entries 的正确方法

IT技术 javascript reactjs ecmascript-6
2021-04-27 00:11:09

我不喜欢使用,Object.entries(object).map((key, i)因为我发现这是 ECMAScript 7 的一项实验性技术,我觉得在生产中可能会出现问题。是否有任何原生 javascript 替代品?

我对 name、price、description 的值没有任何问题,因为我确切地知道它们应该在何处呈现并且我可以使用 Populate.key 访问它们,但是对于特征,我需要对对象进行读写并同时呈现键和值。

我尝试使用Object.keys(priceChars).map(function(key, i)但不明白如何将键与值分开。就像,它正在渲染“性能 500”,但我需要将性能词放在图标类中,而 500 是要显示的实际值。

我的 JSON 结构

const Populate = {
  'name': "Product",
  'price': "1000",
  'description': "Product description",
  'characteristics': {
    'performance': '500',
    'pressure': '180',
    'engine': '4',
    'size': '860*730*1300',
    'weight': '420'
  }
}

和组件

class PriceBlock extends Component {
  render() {
    const {priceName, priceDesc, priceVal, priceChars} = this.props;
    const characteristics = Object.entries(priceChars).map((key, i) => {
      return (
        <div className="price__icon-row" key={i}>
          <i className={'ico ico-' + key[0]}></i> <span>{key[1]}</span>
        </div>
      );
    });
    return (
      <div className="col-5 price__block">
        <div className="price__name">{priceName}</div>
        <div className="price__description">{priceDesc}</div>
        <div className="price__icons">
          {characteristics}
        </div>
        <div className={ managePriceClass(priceVal) }>{priceVal}</div>
      </div>
    );
  }
}
2个回答
a = { 
  a: 1,
  b: 2,
  c: 3
}

Object.keys(a).map(function(keyName, keyIndex) {
  // use keyName to get current key's name
  // and a[keyName] to get its value
})

较新的版本,使用解构和箭头函数。我会将这个用于新代码:

a = { 
  a: 1,
  b: 2,
  c: 3
}

Object.entries(a).map(([key, value]) => {
    // Pretty straightforward - use key for the key and value for the value.
    // Just to clarify: unlike object destructuring, the parameter names don't matter here.
})

在react中完成功能渲染

const renderbase = ({datalist}) => {
        if(datalist){
            return  Object.keys(datalist).map((item,index) => {
                return(
                  <option value={datalist[item].code} key={index}>
                      {datalist[item].symbol}
                  </option>
                )
            })
        }  
    }