Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/leaves4j/vue-easy-renderer
Vue.js server-side renderer for *.vue file with Node.js.
https://github.com/leaves4j/vue-easy-renderer
vue vue-renderer vue-server-renderer
Last synced: 2 months ago
JSON representation
Vue.js server-side renderer for *.vue file with Node.js.
- Host: GitHub
- URL: https://github.com/leaves4j/vue-easy-renderer
- Owner: leaves4j
- Created: 2017-01-24T14:02:32.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2017-11-08T01:41:36.000Z (about 7 years ago)
- Last Synced: 2024-11-03T01:32:55.100Z (2 months ago)
- Topics: vue, vue-renderer, vue-server-renderer
- Language: JavaScript
- Homepage:
- Size: 293 KB
- Stars: 80
- Watchers: 3
- Forks: 12
- Open Issues: 1
-
Metadata Files:
- Readme: README-zh.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-vue - vue-easy-renderer - easy-renderer?style=social) - Nodejs服务端渲染 (服务端)
- awesome-github-vue - vue-easy-renderer - Nodejs服务端渲染 (服务端)
- awesome - vue-easy-renderer - Nodejs服务端渲染 (服务端)
- awesome-github-vue - vue-easy-renderer - Nodejs服务端渲染 (服务端)
README
vue-easy-renderer
---
`vue-easy-renderer` 是一个基于 `vue-server-renderer` 的服务端渲染工具, 他提供了更简单的方式来实现vue的服务端渲染, 包括 `Koa.js` 和 `Express.js` 的插件.- [Installation](#installation)
- [Example](#example)
- [API](#api)
- [Renderer 选项](#renderer-选项)
- [Vue Client Plugin](#vue-client-plugin)
- [Component Head](#component-head)
- [vuex or vue-router](#vuex-or-vue-router)
- [ChangeLog](#changelog)
- [License](#license)## Installation
```bash
npm install vue-easy-renderer -S
```Peer Dependency
```bash
npm i vue vuex vue-router vue-loader vue-server-renderer -S
```## Example
**Vue File**
创建一个文件 `component/hello_word/hello_word.vue`
```html
hello {{world}}export default {
name: 'HelloWorld',
data() {
return {
world: ''
};
}
}```
**Koa.js 2**
```js
'use strict';const path = require('path');
const Koa = require('koa');
const serve = require('koa-static');
const vueEasyRenderer = require('vue-easy-renderer').koaRenderer;const renderer = vueEasyRenderer(path.resolve(__dirname, './component'));
const app = new Koa();app.use(serve('./dist'));
app.use(renderer);// with ES7 async/await
// app.use(async ctx => {
// await ctx.vueRender('simple.vue', {hello: 'world!'});
// });app.use(ctx => ctx.vueRender('hello_world/hello_world.vue', {world: 'world!'}));
app.listen(8080);
console.log('vue-easy-renderer koa example start in 127.0.0.1:8080');
module.exports = app;```
**Express.js**
```js
'use strict';const path = require('path');
const express = require('express');
const vueEasyRenderer = require('vue-easy-renderer').connectRenderer;const renderer = vueEasyRenderer(path.resolve(__dirname, './component'));
const app = express();app.use(express.static('./dist'));
app.use(renderer);app.get('/', (req, res) => res.vueRender('hello_world/hello_world.vue', {world: 'world!'}));
app.listen(8081);
console.log('vue-easy-renderer express example start in 127.0.0.1:8081');
module.exports = app;```
**Result**
最后浏览器获取到的html
```html
window.__VUE_INITIAL_STATE__ = {"world":"world!"};
hello world!```
Detail in [Full example](https://github.com/leaves4j/vue-easy-renderer/tree/master/example)## API
**vueRender(path,data,config)**
在 `koa.js` 中 `vueRender`挂载在`ctx`上,即 `ctx.vueRender()`,在`express.js`中挂载在`res`上,即 `res.vueRender()`
| 参数 | 类型 | 描述 |
| ------------- | ----------------------------------------------------------------------------------- | ------------------------------------------------------ |
| path | `String` | `*.vue` 基于 [`Options.basePath`](#renderer-options) 的路径 |
| data | `Object` | 渲染数据,将会被合并到vue实例的data中或者vuex的state中 |
| [config] | `Object` | 渲染选项 |
| [config.pure] | `Boolean` | 默认 `false`, 当设置为`pure:true`时,将会只渲染vue文件的html,不包含头尾 |
## Renderer 选项**vueEasyRenderer(basePath,options)**
获取 vueEasyRenderer
With `Koa.js 2`
```js
const vueEasyRenderer = require('vue-easy-renderer').koaRenderer;
const renderer = vueEasyRenderer(basePath, options);
```With `Express.js`
```js
const vueEasyRenderer = require('vue-easy-renderer').connectRenderer;
const renderer = vueEasyRenderer(basePath, options);
```**参数**
| 参数 | 类型 | 描述 |
| ------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------- |
| basePath | `string` | `*.vue` 文件路径 |
| [options] | `Object` | renderer 的 options |
| [options.plugins] | `Array` | vue插件, 如 `[vueRouter]`, 同时也支持字符串,如: `[path.resolve('../app/resource.js')]` |
| [options.preCompile] | `Array` | 需要预编译的 `*.vue` 文件路径列表,如:`['test.vue']` |
| [options.head] | `Object` | 通用的html头部设置, 详情见 [Component Head](#component-head) |
| [options.compilerConfig] | `Object` | 服务端vue文件的编译器配置,为webpack配置文件,默认配置使用 `vue-loader`、 `babel-loader` |
| [options.onError] | `Function` | 异常处理方法 |
| [options.onReady] | `Function` | ready 时间处理方法, renderer 将会在完成初始化工作之后emit一个ready事件 |
| [options.global] | `Object` | 全局变量, 这些全局变量将会被注入的vue服务端渲染时的sandbox的作用域,相当于node中的global.xx,浏览器中的window.xx |## Vue Client Plugin
服务端渲染完成后,我们需要把数据注入到浏览器中vue/vuex实例中,需要借助于客户端的插件
Base usage
```js
import Vue from 'vue';
import vueEasyRenderer from 'vue-easy-renderer/lib/plugins/client';
import App from './app.vue';Vue.use(vueEasyRenderer);
const app = new Vue(App);
app.$mount('#app');
```## Component Head
我们可以在组件中设置html的头部
```html
hello {{world}}export default {
name: 'HelloWorld',
data() {
return {
world: ''
};
},
head: {
title: 'hello',
script: [
{src: "/hello_world.js", async: 'async'}
],
link: [
{ rel: 'stylesheet', href: '/style/hello_world.css' },
]
},
}```
Then the result
```html
hello
window.__VUE_INITIAL_STATE__ = {"world":"world!"};
hello world!```
## vuex or vue-router
在服务端渲染中使用vuex或者vue-router时,我们需要为每个请求创建一个vuex或者vue-router实例,因此在跟组件注入vuex或者vue-router实例时,需要在实例上添加一个工厂方法,该方法调用时返回一个实例,默认方法名为`$ssrInstance`,如:
**vuex**
```js
const options = {
state: {
hello: 'world!'
}
};const store = new Vuex(options);
store.$ssrInstance = () => new Vuex(options);
export default store;
```**vue-router**
```js
const options = {
mode: 'history',
routes: [
{ path: '/user/:id', component: User }
]
})const router = new VueRouter(options)
router.$ssrInstance = () => new Vuex(options);
export default router;
```
如果在服务端渲染中使用`vue-router`,需要设置`mode`为`history`## ChangeLog
[ChangeLog](https://github.com/leaves4j/vue-easy-renderer/blob/master/CHANGELOG.md)
## License
MIT