本人工作栈为dva+antd,使用阿里开源出来的组件有一段时间之后,决定不依赖阿里的框架自己打个环境写一些组件出来,一来为了熟悉工作流程,二来也是为了更好的理解原理,从而更好的满足工作中的需求
源码地址:
预览地址: (目前只兼容chrome和IEedge)
1. 技术点 react + webpack + antd
2. 学习流程
- 首先电脑上要有nodejs环境,本文并不涉及nodejs,主要是用nodejs环境中的npm安装需要的依赖包(nodejs安装即可,npm如果在下载包的时候很慢,可以将镜像换成淘宝的镜像)
- npm i create-react-app -g 全局安装create-react-app脚手架
- create-react-app创建自己的工程文件
- 写自己的webpack配置文件
- 跨域请求时,在webpack中配置代理,在服务器上采用nginx代理转发
- 打包
- 部署到服务器中
3. 详解
安装nodejs环境和用create-react-app创建react脚手架过程省略,因为比较简单,安装都比较方便,不会出什么问题
-
webpack配置文件
- 对webpack简单的理解可以参考博文:;
- 在本程序中的一个难点在于既想要引入antd的样式文件,又想要使用css modules,本程序中的解决方案就是针对不同目录中的css文件分别进行匹配,antd组件中的样式文件一定都在node_modules文件夹中,而本地自己写的文件一定都在src文件夹中,具体解决方案详见;
- 在文件配置中遇到的坑详见 ;
- 遇到跨域问题在本地的解决方案为在本地配置代理:
devServer: {contentBase: './public',publicPath: '/',historyApiFallback: true,inline: true,proxy: { '/search/*': { target: 'https://image.baidu.com', changeOrigin: true }}}, 复制代码
-
部署服务器
服务器申请的为centos阿里云服务器,将打包好的静态文件部署在nginx中,nginx服务器默认监听80端口,启动nginx时可能访问不到,这时需要在“安全组规则”中添加一条规则: