React 全家桶的综合运用.该项目会把日常开发中 遇到的案例抽离成 demo 展现出来,同时会对一些知识点进行实践。
效果展示,项目变大后,gitpage 上访问速度会比较慢(几十秒),建议本地打开
本地运行
yarn install || npm install
yarn start || npm start
打包
yarn build || npm run build
发布
yarn deploy
- 打包构建:Babel Webpack(4.x)
- 热更新
- 包管理:Yarn || Npm
- UI库:React & React-Dom(16.2.0)
- UI组件:Antd(3.x)
- 路由:react-router(4.x)、react-router-redux
- JS:ES6、ES7
- 样式:less
- 状态管理:redux
- Ajax:Fetch
- 跨域: 基于 CORS 实现
- 代码校验: Eslint
- 测试用例:jest
- 网关层:使用 typescript + node.js,可参考 gateway
开发环境中可使用最近开发优化的 webpack 插件 观察各模块的占用情况,从而进一步优化项目。以该项目为例:浏览器中输入 http://localhost:3000/analyze.html
可以看到如下效果:
结合该项目分析过的文章(技术栈以项目中的为准)
- 音乐模块
- 抽离了 Ajax 模块,可完成相应的跨域需求
- redux 流实现数据的获取
- 工具模块
- 实现对工资、房租、身体指数、年龄的智能计算
- 富文本编辑器应用
- 用 redux 实现了待办事项模块
- 画廊模块
- 图片瀑布流(撸了个插件 jswaterfall)
- 搜索模块
- 搜索引擎的实现(集合了百度、360、搜狗搜索)
- 更多模块开发中
- 欢迎 issue || pr
├── build.js 项目打包后的文件
├── config webpack配置文件
│ ├──...
│ ├──webpack.config.dev.js 开发环境配置(启动速度优化)
│ ├──webpack.config.prod.js 生产环境配置(打包体积优化)
├── node_modules node模块目录
├── public
│ └──index.html
├── scripts
│ ├── build.js 打包项目文件
│ ├── start.js 启动项目文件
│ └── test.js 测试项目文件
├── src
│ ├── client
│ │ ├── store redux中的store
│ │ ├── devTools.js 开发者工具
│ ├── common 核心目录
│ │ ├── api 请求api层
│ │ ├── actions redux中的action
│ │ ├── components 通用功能组件
│ │ ├── container 通用样式组件
│ │ ├── images
│ │ ├── pages 页面模块
│ │ ├── reducers redux中的reducer
│ │ ├── utils 工具类
│ │ │ ├── index.js 通用工具
│ │ │ ├── config.js 通用配置
│ │ │ ├── menu.js 菜单配置
│ │ │ └── ajax.js ajax模块
│ │ └── routes.js 前端路由
│ └── server 服务端目录(日后用到)
│ └── controller
├── .gitignore
├── package.json
├── README.md
└── yarn.lock