test.json和comment.js位于同一目录下
/comment.js/
//import React, {Component} from 'react';
import React, { Component, PropTypes } from 'react';
import $ from 'jquery';
import jQuery from 'jquery';
//import CommentList from './commentList';
var url='test.json'
class Common extends Component {
constructor(props){
super(props)
this.state={
comments: [
{
author:'lm',
message:'hi,SS'
},
{
author:'lmqq',
message:'hi,SS222'
}
]
}
}
//not a function 排查this
loadData(){
//$("#test").html("1233");
console.log(url);
$.ajax({
url:url,
dataType:"json",
success:function(comments){
console.log(111);
},
error: function(data) {
alert('error');
}
})
}
componentDidMount(){
console.log('render');
this.loadData();
}
render() {
return (
common
);
}
}
class CommentList extends Component {
render() {
var commentsNode=this.props.comments;
var messageList=commentsNode.map(function(item,index){
return(
{item.author}:{item.message}
)
})
return (
{messageList}
);
}
}
export default Common;
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
这个路径要相对生成的html(或者引用生成的js的html)才行, 相对打包前的js文件有啥用, 打包后, 压根就没这个文件
把json文件放到项目根目录, 然后用/xxx.json这样的绝对路径
有可能是服务器不支持 JSON 这种 MIME,在服务器配置里加上相关的配置试试
跟你的 js 在同一目录下无关,要在 webpack 配置文件里面写 loader 才行。
这个 test.json 是返回值吧,建议还是找一个 mock library 用上吧。
使用的 jQuery? 可以试试 jquery-mockjax。
但是,你都上 React 了,为毛不试试 fetch 呢?