Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andycall/thinkjs-react-server-render-example
基于thinkjs的react后端渲染方案,集成了react-router
https://github.com/andycall/thinkjs-react-server-render-example
Last synced: 23 days ago
JSON representation
基于thinkjs的react后端渲染方案,集成了react-router
- Host: GitHub
- URL: https://github.com/andycall/thinkjs-react-server-render-example
- Owner: andycall
- Created: 2016-04-12T18:38:30.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2016-05-30T13:50:13.000Z (over 8 years ago)
- Last Synced: 2024-10-19T04:30:39.485Z (3 months ago)
- Language: HTML
- Size: 642 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# thinkjs-react-server-render-example
基于thinkjs的react后端渲染方案,采用webpack编译, 同时集成了react-router
## 如何安装
```
npm install
``````
npm start
```## 如何使用
添加一个叫做admin的模块
```
thinkjs module admin
```
再添加一个新的控制器```
thinkjs controller admin/login
```在`www/client` 新建一个`admin`文件夹, 粘贴`www/client/home`文件夹的所有文件
依照示例,将routes里面的路径依照thinkjs的路由解析填写
删除多余的模块和页面.
但是一定要保留client.js和server.js以及root.js在`pages.js`里为`pages`对象添加如下的配置
```
admin: {
client: path.join(__dirname, './www/client/admin/client'),
server: path.join(__dirname, './www/client/admin/server')
}
```
到`src/admin/controller/base.js`文件下, 现在顶部添加代码```
import path from 'path'
import AdminBundle from '../../../share/home.bundle'
```再给当前文件的`init`方法下面添加如下的代码
```
init (http) {
super.init(http);this.templateFile = path.join(__dirname, '../../../view/admin/index_index.html');
this.reactBody = AdminBundle(http);
this.assign('html', this.reactBody);
}
```修改`view/admin/index_index.html` 删除内部所有的css和html标签, 替换成下面的样子
```New ThinkJS Application
<%- html %>```
运行`npm start`
## 细节阐释
#### 目录划分
前端的所有资源依然按照模块进行划分, 根目录是 `www/client` , 目录划分结构和thinkjs划分module一致
如果有一个module为`home`, 那么 `www/client` 目录下就应该 具有 `home` 文件夹.所有的组件和路由建议都放在同一个文件夹下面,
路由模块建议放在`route`文件夹
共享的组件放在`components`文件夹对于每一个分页里的资源都用一个文件夹表示, 例如
+ '/' : 文件夹名是index,
+ '/test': 文件夹名是test每一个页面的文件夹存放改页面的所有资源,包含js,css,image等. 文件夹内的目录划分可以自由发挥
#### 模块的入口
在`www/client`下面的每一个模块文件夹内, 都必须有一个浏览器端和服务区端的入口文件
建议分别命名为 `client.js` 和 `server.js`在根目录的 `pages.js` 里面添加`client.js`和 `server.js`的路径, 这样就可以让webpack对客户端和服务器端分别进行编译
`pages.js` 编辑 `module.exports` 里面暴露的对象, 按照以下的格式进行编辑
```
module.exports = {
模块名: {
client: 'client.js文件的路径',
server: 'server.js文件的路径'
}
}
```#### 编译产出
执行客户端编译的`webpack` 会依照依赖将产出放在`www/static`目录下, 同时所有的css文件会合并成一个整体的css
执行服务端编译的`webpack` 会剔除所有的依赖, 同时兼容node引入的方式, 并过滤掉代码中引入的css样式, 将产出放在`share`文件夹下面执行服务端webpack产出的文件将作为`thinkjs`进行后端渲染的入口
同时react-router也将在thinkjs的路由解析之后运行.#### 路由解析
前端路由需和后端的路由相对应, 才能实现完美切换.一个模块的的所有controller 都必须display同一个视图模板文件.
每个控制器返回视图应该是
```
this.display(this.templateFile);
```templateFile 在每一个module的base.js里定义