Vue 2.0 服务端渲染入门介绍


Posted in Javascript onMarch 29, 2017

1 什么是服务端渲染 SSR

server side render

就是通过后端吐模板,而不是通过前端ajax获取数据,拼接字符串。

2 为什么需要SSR

需要SEO,因为爬虫不会等待ajax结果。

客户端网络慢,加载速度慢,影响用户体验。

3 另一种解决办法 预渲染

不是一次性下载整个单页应用,预渲染只是在构建时为了特定的路由生成特定的几个静态页面

你用webpack可以很简单地通过prerender-spa-plugin来添加预渲染

 4 NodeJS编写Vue的SSR

首先npm install --save-dev的有 vue express vue-server-renderer

// server.js

'use strict';

var fs = require('fs');
var path = require('path');

global.Vue = require('vue')

var layout = fs.readFileSync('./index.html', 'utf8')

var renderer = require('vue-server-renderer').createRenderer()

var express = require('express')
var server = express()

server.use('/assets',express.static(
  path.resolve(__dirname,'assets')
))


server.get('*',function(req, res){

  // 将Vue实例渲染成HTML
  renderer.renderToString(
    // 创建一个应用实例
    require('./assets/app')(),

    // 处理渲染结果
    function(error, html){
      if(error){
        console.error(error);
        return res
          .status(500)
          .send('Server Error')
      }
      // 发送布局和HTML文件
      res.send(layout.replace('<div id="app"></div>', html))

    }
  )
})


server.listen(5000, function(error){
  if(error) throw errorr;
  console.log('Server is running at localhost:5000')
})
// index.html 

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <script src="" charset="utf-8"></script>
  <script src="/assets/vue.js" charset="utf-8"></script>
</head>
<body>

  <div id="app"></div>
  <script src="/assets/app.js" charset="utf-8"></script>
  <script type="text/javascript">app.$mount('#app')</script>


</body>
</html>
// assets/app.js

(function() {
  'use strict'
  var createApp = function() {
    return new Vue({
      template: '<div id="app">你已经在这花了 {{ counter }} 秒。</div>',
      data: {
        counter: 0
      },
      created: function() {
        var vm = this;
        setInterval(function(){
          vm.counter += 1;
        },1000)
      }
    })
  }

  // 暴露接口
  if(typeof module !== 'undefined' && module.exports) {
    module.exports = createApp
  } else {
    this.app = createApp()
  }

}).call(this)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js调用activeX获取u盘序列号的代码
Nov 21 Javascript
JavaScript设计模式之工厂方法模式介绍
Dec 28 Javascript
Jquery easyui 实现动态树
Nov 17 Javascript
Vue.js组件tabs实现选项卡切换效果
Dec 01 Javascript
有关suggest快速删除后仍然出现下拉列表的bug问题
Dec 02 Javascript
JavaScript 中对象的深拷贝
Dec 04 Javascript
jQuery+pjax简单示例汇总
Apr 21 jQuery
详谈jQuery中使用attr(), prop(), val()获取value的异同
Apr 25 jQuery
Vue2.x中的父子组件相互通信的实现方法
May 02 Javascript
vue项目中添加单元测试的方法
Jul 21 Javascript
Vuejs+vue-router打包+Nginx配置的实例
Sep 20 Javascript
微信小程序之滑动页面隐藏和显示组件功能的实现代码
Jun 19 Javascript
vue2组件实现懒加载浅析
Mar 29 #Javascript
整理关于Bootstrap排版的慕课笔记
Mar 29 #Javascript
如何使用Bootstrap创建表单
Mar 29 #Javascript
Bootstrap 响应式实用工具实例详解
Mar 29 #Javascript
jQuery日程管理控件glDatePicker用法详解
Mar 29 #jQuery
利用js查找数组中指定元素并返回该元素的所有索引示例
Mar 29 #Javascript
jQuery实现简单漂亮的Nav导航菜单效果
Mar 29 #jQuery
You might like
php创建多级目录代码
2008/06/05 PHP
测试php连接mysql是否成功的代码分享
2014/01/24 PHP
php连接mysql数据库
2017/03/21 PHP
基于ThinkPHP删除目录及目录文件函数
2020/10/28 PHP
在javascript将NodeList作为Array数组处理的方法
2010/07/09 Javascript
document.documentElement的一些使用技巧
2013/04/18 Javascript
js动态改变select选择变更option的index值示例
2014/07/10 Javascript
JS+CSS实现Li列表隔行换色效果的方法
2015/02/16 Javascript
js格式化输入框内金额、银行卡号
2016/02/01 Javascript
AngularJS手动表单验证
2016/02/01 Javascript
JavaScript中使用webuploader实现上传视频功能(demo)
2017/04/10 Javascript
webpack4 + react 搭建多页面应用示例
2018/08/03 Javascript
如何让微信小程序页面之间的通信不再变困难
2019/06/03 Javascript
JavaScript cookie原理及使用实例
2020/05/08 Javascript
python字符串中的单双引
2017/02/16 Python
python微信跳一跳游戏辅助代码解析
2018/01/29 Python
Python实现Kmeans聚类算法
2020/06/10 Python
Python简单定义与使用二叉树示例
2018/05/11 Python
python实现上传文件到linux指定目录的方法
2020/01/03 Python
浅谈selenium如何应对网页内容需要鼠标滚动加载的问题
2020/03/14 Python
python实现超级玛丽游戏
2020/03/18 Python
pycharm通过anaconda安装pyqt5的教程
2020/03/24 Python
Python调用OpenCV实现图像平滑代码实例
2020/06/19 Python
Pytorch 卷积中的 Input Shape用法
2020/06/29 Python
Pycharm创建文件时自动生成文件头注释(自定义设置作者日期)
2020/11/24 Python
python中time包实例详解
2021/02/02 Python
Ray-Ban雷朋西班牙官网:全球领先的太阳眼镜品牌
2018/11/28 全球购物
大学生最新职业生涯规划书范文
2014/01/12 职场文书
人事专员职责
2014/02/22 职场文书
中学生操行评语
2014/04/24 职场文书
环卫工作汇报材料
2014/10/28 职场文书
听证通知书
2015/04/24 职场文书
新娘婚礼致辞
2015/07/27 职场文书
导游词之山东孔庙
2019/11/04 职场文书
Java生成读取条形码和二维码的简单示例
2021/07/09 Java/Android
java后台调用接口及处理跨域问题的解决
2022/03/24 Java/Android