/cnode-react-app

基于react的仿cnode社区项目

Primary LanguageJavaScript

cnode-react-app

一个学习 reactjs 的 demo,基于 CNode 社区提供的 API,以 react 组件化的开发思路,练习了基于 react 技术栈为主的前端单页面开发方式。

项目预览

Demo

在线预览,戳我

技术栈

TODOLIST

  • 首页组件化展示
  • 基于文章类型的前端路由添加
  • 基于文章详情的前端路由添加
  • 文章详情页的展示
  • 文章评论的显示

npm scripts

## 本地调试
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,一个有温度的社区。