在 ReactJS 中渲染数据

Render data in ReactJS

我正在尝试学习 ReactJS。在这个 HelloWorld 脚本中

<!DOCTYPE html>
<html>
<head>
    <title>React JS Hello World</title>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <link rel="stylesheet" href="style.css" />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/react/0.13.3/react.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/react/0.13.3/JSXTransformer.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
</head>
<body>

<div id="content"></div>
<script type="text/jsx">
    var data=[{name: "nthhtn", text: "Sample text"}];
    var DataBlock = React.createClass({
        render: function() {
            var entry=this.props.data.map(function (entry){
                return (
                        <h3 name={entry.name}>
                        {entry.text}
                        </h3>
                );
            });
            return (
                    <div className="data" data={this.props.data}>
                            <h1>Sample data block</h1>
                    {entry}
                    </div>
            );
        }
    });
    React.render(
            <DataBlock data={data}/>,
            document.getElementById('content')
    );
</script>


</body>
</html>

我不知道为什么我在浏览器中运行脚本时,data中的name字段不显示,只有text字段

这是因为您混合了具有相同变量名的东西 "entry"

  render: function() {
            var entryBlock=this.props.data.map(function (entry){
                return (
                        <h3 name={entry.name}>
                        {entry.text}
                        </h3>
                );
            });
            return (
                    <div className="data" data={this.props.data}>
                            <h1>Sample data block</h1>
                    {entryBlock}
                    </div>
            );
        }

例如将条目更改为 entryBlock(参见上面的代码)。如果不是,请检查 entry.text.

中是否有内容

希望对您有所帮助。

您将数据传递给 getInitialState() 检查此 fiddle https://jsfiddle.net/bs65w2hs/

var data=[{name: "nthhtn", text: "Sample text"}];
var DataBlock  = React.createClass({
    getInitialState: function getInitialState() {
        return {
            reactdata: data[0]  
        };
    },
    render: function() {
        var entrydata = this.state
        return <div>
                 <ul>
                   <li>name: {entrydata.reactdata.name}</li> 
                   <li>text: {entrydata.reactdata.text}</li>
                </ul>
               </div>
    }
 });

 React.render(<DataBlock />, document.getElementById('container'));