1.需求说明
因为前后端分离开发项目,就会存在前端静态页面写好了,后端数据接口还没写好;这时候前端就需要自己定义数据来使用。
定义数据有三种方式:直接写死数据、使用mock软件、json-server工具
这里讲解通过json-server工具来获取数据
2.安装插件
npm i -D json-server
3.新建数据文件
在根目录下新建server文件,该文件夹下新建data.json文件用于存储数据
4.更改项目配置文件
package.json
更改前
"scripts": {"start": "react-scripts start","build": "react-scripts build","test": "react-scripts test","eject": "react-scripts eject"},
更改后
"scripts": {"start": "react-scripts start & npm run server","build": "react-scripts build","test": "react-scripts test","eject": "react-scripts eject","server": "json-server ./server/data.json --port 8888"},
说明:
1.需要同时启动项目和工具,工具启动命令是npm run server,项目启动命令是npm run start
2."server": "json-server ./server/data.json --port 8888"代码意思是,server是启动命令、json-server是工具、./server/data.json是数据源位置、--port 8888是设置端口号
3."start": "react-scripts start & npm run server"的意思是,start是启动命令、react-scripts start不知道是什么、& npm run server是代表同时启动server工具;整行代码就是通过npm run start就同时启动项目和启动server工具
4.启动项目和工具可以分开在两个终端控制台启动,分别在两个终端控制台输入各自的命令就行了;也可以在一个控制终端上通过npm run start,前提是有写"react-scripts start & npm run server"
5.测试
import axios from "axios"
function Home() {async function shower() {// await axios.get('http://localhost:8888/kanno').then(res=>{// console.log('res:', res.data);// }) // 通过axios来请求数据const response = await fetch('http://localhost:8888/kanno'); // 通过fetch来请求数据const data = await response.json();console.log('Data:', data);}return (<div><div>我是home</div><button onClick={shower}>点击请求数据</button></div>)
}export default Home
说明:接口地址来源于使用npm run server启动server工具时