2017-01-16 8 views
0

マップに「map」を呼び出して他の値のリストに変換できるようにリストに変換したいマップ(文字列 - >文字列)があります。 )今Iterableをjavascript/typescriptのリストに変換する

<input type="select"> 
{props.options.entries().toList().map((type,i) => { 
       return <option value={type[0]} key={i}>{type[1]}</option> 
}) 
} 
</input> 

、エントリー(私iteratableを与える:背景には、私はこのようなreactjsコンポーネントでそれを使用したいということ、です。しかしそれには "toList"はありません。この変換を行うにはどうすればよいですか?

+1

はあなただけ 'エントリを(やってみました) .map(...) '? FYI – mhodges

+1

私はこのコードを理解していません。中かっことかっこが一致しません。 – Ultimater

+0

申し訳ありません、私はそれを修正しました – Nathan

答えて

0

でコンポーネントのrender機能を反応させ、

render: function() { 
    return (
    <Root> 
    ... 
    {props.options.entries().toList().map((type,i) => { 
    return <option value={type[0]} key={i}>{type[1]}</option> 
    }) 
    ... 
    </Root>) 
} 

は異なるものではありません:

render: function() { 
    let optionList = props.options.entries().toList().map((type,i) => { 
    return <option value={type[0]} key={i}>{type[1]}</option> 
    } 

    return (
    <Root> 
    ... 
    {optionList} 
    ... 
    </Root>) 
} 

と異なるnothingから:

render: function() { 
    let optionList = [] 
    // iterate through this iterable(pseudo, as the iterable interface is needed) 
    let entries = props.options.entries() 
    while (entries.hasNext()) { 
    optionList.push(entries.next()) 
    } 
    optionList.map((type,i) => { 
    return <option value={type[0]} key={i}>{type[1]}</option> 
    } 

    return (
    <Root> 
    ... 
    {optionList} 
    ... 
    </Root>) 
} 
関連する問題