UI框架用的
ant design
npm i antd -S
全部引入文件很大,建议按需引入
1. antd
的样式文件引入失效
webpack.config.js
中针对antd
重新配置样式文件。
// 针对antd样式专用配置文件
{ test: /\.css$/, use: ['style-loader', 'css-loader'], exclude: /src/ },
上面针对src
中的文件配置样式模块化,下面针对antd
重新配置样式文件。
2.按需加载
使用[babel-plugin-import]
3. fetch
fetch的MDN
get请求
fetch('http://example.com/movies.json')
.then(res => {
return res.json()
}
)
.then(data => {
console.log(data)
})
post请求
sendMsg() {
var sendData = new URLSearchParams()
sendData.append('name', 'zs')
fetch('http://39.106.32.91:3000/api/post',{
method: 'POST',
body: sendData
})
.then(res => res.json())
.then(data => console.log(data))
}
fetch jsonp解决跨域问题,适用于服务端没有cors的情况
npm i fetch-jsonp -S
直接使用
import fetchJSONP from 'fetch-jsonp'
sendMsg() {
fetchJSONP('https://api.apiopen.top/getSongPoetry?page=1&count=20')
.then(res => {
return res.json()
}
)
.then(data => {
console.log(data)
})
}
结合
async
和await
一起使用
index.js
import fetchJSONP from 'fetch-jsonp'
React.Component.prototype.$http = fetchJSONP
App.jsx
sendMsg = async () => {
const res = await this.$http('https://api.apiopen.top/getSongPoetry?page=1&count=20')
const data = await res.json()
console.log(data)
}
同上报错,待解决
4.快速搭建项目
create-react-app
其他配置,如按需加载等,参考这里