我一直在尝试从
JSON文件中获取数据并使用ReactJS将其绑定到我的页面
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title>Demo Fetch</title> <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="js/jquery-2.1.4.min.js"></script> </head> <body> <div id="content"></div> <script type="text/jsx"> var DataBlock = React.createClass({ getInitialState:function(){ return {}; },loadData:function() { var a=this; $.getJSON(this.props.url,function (obj) { a.setState({data: obj}) }); },render: function() { return ( <div className="dataBlock" data={this.state.data}> <h1>Sample data block</h1> {this.loadData()} <h3>{data.runtime}</h3> </div> ); } }); React.render( <DataBlock url="small_data.json"/>,document.getElementById('content') ); </script> </body> </html>
但是当我尝试显示页面时没有显示任何内容.我的代码出了什么问题?它的错误在哪里?为什么我不能将getJSON中的数据绑定到我的React组件的状态?
这是我的small_data.json文件:
{ "movies": [ { "abridged_cast": [ { "characters": [ "Dominic Toretto" ],"id": "162652472","name": "Vin Diesel" },{ "characters": [ "Brian O'Conner" ],"id": "162654234","name": "Paul Walker" } ],"runtime": 140,"synopsis": "Continuing the global exploits in the unstoppable franchise built on speed,Vin Diesel,Paul Walker and Dwayne Johnson lead the returning cast of Fast & Furious 7. James Wan directs this chapter of the hugely successful series that also welcomes back favorites Michelle Rodriguez,Jordana Brewster,Tyrese Gibson,Chris \"Ludacris\" Bridges,Elsa Pataky and Lucas Black. They are joined by international action stars new to the franchise including Jason Statham,Djimon Hounsou,Tony Jaa,Ronda Rousey and Kurt Russell.","title": "Furious 7","year": 2015 } ],"runtime": 140 }
解决方法
你需要使用componentDidMount:function(){
加载数据
加载数据
import React from 'react'; import ReactDOM from 'react-dom'; const data = { "movies": [ { "abridged_cast": [ { "characters": [ "Dominic Toretto" ],"runtime": 140 } const DataBlock = React.createClass({ getInitialState: () => { return { data: null }; },componentDidMount: () => { this.setState({ data: this.props.url }); },render() { return <div> <h3>runtime: {data.runtime}</h3> <h4>the data:</h4> {this.state.data} </div>; } }); ReactDOM.render(<DataBlock url={data}/>,document.getElementById('.container'));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。