-6ren">
gpt4 book ai didi

javascript - ReactCompositeComponent.render() : A valid ReactComponent must be returned. 您可能返回了未定义的数组或其他一些无效对象

转载 作者:行者123 更新时间:2023-11-30 12:03:33 24 4
gpt4 key购买 nike

我在控制台中收到上述错误,即使我正确地返回了要渲染的组件。以下代码中 errorTexts = ["email is invalid"] 的值

if(@state.errorTexts.length>0)
dangerouslySetInnerHTML: {
__html: ReactDOMServer.renderToString(
React.createElement AdminError, errorTexts: @state.errorTexts
)
}

AdminError 组件包含以下代码:

#app/assets/javascripts/components/adminerror.js.coffee
@AdminError = React.createClass

getDefaultProps: ->
errorTexts: []

render: ->
for errorText in @props.errorTexts
dom.div
className: 'help-block'
errorText

这个组件的 JS 等价物是:

(function() {
this.AdminError = React.createClass({
getDefaultProps: function() {
return {
errorTexts: []
};
},
render: function() {
var errorText, i, len, ref, results;
ref = this.props.errorTexts;
results = [];
for (i = 0, len = ref.length; i < len; i++) {
errorText = ref[i];
results.push(dom.div({
className: 'help-block'
}, errorText));
}
return results;
}
});

}).call(this);

从 AdminError 组件返回的结果值显示在下面的屏幕截图中,但是,我不确定返回的对象类型是否可以接受,因为它在 for 循环中: enter image description here

更新:修改 AdminError 组件中的代码以修复此 error

#app/assets/javascripts/components/adminerror.js.coffee
@AdminError = React.createClass

getDefaultProps: ->
errorTexts: []

render: ->
dangerouslySetInnerHTML: {
__html: marked((
dom.div null,
for errorText, index in @props.errorTexts
dom.div
key: index
className: 'help-block'
errorText

).toString())
}

再次出现这个错误:

Uncaught Invariant Violation: ReactCompositeComponent.render(): A valid ReactComponent must be returned. You may have returned undefined, an array or some other invalid object.invariant

最佳答案

React 只接受一个从 render 返回的父元素。从代码看来您要返回几个。试试这个:

// your code ...
return (
<div>
{results}
</div>
)

我不太确定在 coffee 脚本中会是什么,但基本思想是您需要将返回包装在单个父元素中。

关于javascript - ReactCompositeComponent.render() : A valid ReactComponent must be returned. 您可能返回了未定义的数组或其他一些无效对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35990362/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com