Vue 上的 JSX 传播属性

Sat*_*ito 1 javascript attributes jsx vue.js spread-syntax

我正在尝试在 Vue 组件上使用 JSX 传播属性,如下所示。

<script>

const
Square = p => <button class="square" v-on:click={ () => p.props.click( p.props.index ) }>{ p.props.squares[ p.props.index ] }</button>

const
Board = p => (
    <div>
        <Square squares={ p.props.squares } click={ p.props.click } index='0' />
        <Square { ...p.props } index='1' />
    </div>
)

export default {
    data    : () => ( { squares: [ 0, 1, 2, 3, 4, 5, 6, 7, 8 ] } )
,   render  ( h )   { return <Board squares={ this.squares } click={ this.handleClick } /> }
,   methods : {
        handleClick: i => console.log( i )
    }
}
</script>
Run Code Online (Sandbox Code Playgroud)

这一行没问题:

<Square squares={ p.props.squares } click={ p.props.click } index='0' />
Run Code Online (Sandbox Code Playgroud)

但是这条线似乎无法将属性从“Board”传递到“Square”

<Square { ...p.props } index='1' />
Run Code Online (Sandbox Code Playgroud)

请帮我。提前致谢。

Mat*_* D. 6

也许你可以这样做

<Square { ...{props: p.props} } index='1' />
Run Code Online (Sandbox Code Playgroud)

阅读https://github.com/vuejs/jsx#attributesprops 后,我认为它可以工作。