0

我想不出办法,但我想要的是:

<ColumnDef key="label" ...createCommonColumnProps.call(this, {somestuff}) />
<ColumnDef key="count" ...createCommonColumnProps.call(this, {someOtherStuff}) />
<ColumnDef key="value" ...createCommonColumnProps.call(this, {yetOtherstuff}) />

我希望它愚蠢地简单,我只是一个白痴,但我找不到不创建变量的方法来做到这一点

<ColumnDef key="label" {...column1} />
<ColumnDef key="count" {...column2} />
<ColumnDef key="value" {...column3} />

大约有 5 个 props,其中一些受到传递给函数的对象的影响。

当我在 chrome devtools 控制台中尝试这个时(只是 js 部分,而不是 jsx 部分),我看到了这样的事情:

> function a() {
   return {a:1, b:2}
 }
undefined
> y = {... a()}
VM341:1 Uncaught SyntaxError: Unexpected token ...
> x = ... a()
VM368:1 Uncaught SyntaxError: Unexpected token ...
> x = {a:1,b:2}
Object {a: 1, b: 2}
> y = {...x}
VM888:1 Uncaught SyntaxError: Unexpected token ...
4

1 回答 1

0

JSX 对象扩展语法如下所示:

{...<expression>}

Whereexpression返回对对象的引用。

所以在你的情况下

<ColumnDef key="label" {... createCommonColumnProps.call(this, {somestuff})} />

UPD以反映您的问题更新:

当我在 chrome devtools 控制台中尝试这个时(只是 js 部分,而不是 jsx 部分),我看到了这样的事情:

发生这种情况是因为尽管 JSX 对象扩展语法看起来类似于非标准化但 ES 对象扩展语法 - 它们不可互换(并且 chrome 尚不支持后者)。

因此,只需完全按照我在上面的示例中演示的方式使用它。

于 2016-10-27T20:44:48.740 回答