一个学习 reactjs 的 demo,基于 CNode 社区提供的 API,以 react 组件化的开发思路,练习了基于 react 技术栈为主的前端单页面开发方式。
- 脚手架工具 官方脚手架工具 create-react-app
- 状态管理 redux,redux莞式教程, react-redux
- 前端路由管理 react-router
- 打包编译 webpack
- ES6 ECMAScript 6 入门
- 首页组件化展示
- 基于文章类型的前端路由添加
- 基于文章详情的前端路由添加
- 文章详情页的展示
- 文章评论的显示
## 本地调试
yarn start
## 打包
yarn run build
## 发布至github repository gh-pages分支,使用该功能需要yarn add gh-pages,
## 并在package.json中配置网站的路径,如该示例中的homepage字段
yarn run deploy
第一次尝试使用 react 进行前端单页面开发,之前曾经用 vue 写过一个 CNode.js 的一个应用 vue-cnode。与 vue 都是 MVVM 框架,但是在react的开发中还是有一些地方存在不同,目前尚未进行深入研究及实践。在这个小项目中感受最深的有以下几点:
- 组件的写法
react 中导出的是一个含有jsx语法的类, vue 的开发中组件一般以vue的单文件组件写法,导出一个对象。
- 关于路由的使用
react 中使用 react-router 进行前端路由的管理,同样含有 HashRouter 以及 BrowserRouter。其中 BrowserRouter 需要托管静态主页的服务器配合进行配置。
- 属性的写法
react 中 jsx 语法中给 html 绑定属性值,部分属性名称发生变化,如 class 需要写成 className, for 需要写成 htmlFor,内联样式 style 属性需要使用驼峰的写法等。
- 组件之间的通信
目前仅仅实践了父子组件的通信,通过 props 传参。至于非父子组件之间的通信如何来实现,尚未涉及,redux 以及 react-redux 在该项目中并未得到体现。
另外该仿 CNode.js 社区的 react 项目,仅仅通过部分API完成了首页以及文章详情页的一些展示,添加了 react 的前端路由,目的在于体会 react 技术栈的开发方式,尚不足以谈最佳实践。
感谢 CNode 社区的提供的 API,一个有温度的社区。