时间:2021-05-26
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)以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
首先,这个例子用到了服务端渲染的技术。服务端渲染,说白了就是在服务端使用模板引擎,这里我先简单的介绍一下服务端渲染与客户端渲染之间的区别。服务端渲染与客户端渲染
服务端渲染(SSR)将一个Vue组件在服务端渲染成HTML字符串并发送到浏览器,最后将这些静态标记“激活”为可交互应用程序的过程就叫服务端渲染(SSR)服务器渲
本文主要介绍了Vue2SSR渲染根据不同页面修改meta,分享给大家,具体如下:注意:经过测试,vue-meta会导致内存泄漏,请慎用…以现在vue2的服务端渲
1、前沿1.1、什么是SSRSSR(服务端渲染)顾名思义就是将页面在服务端渲染完成后在客户端直接展示。1.2、客户端渲染与服务端渲染的区别传统的SPA模式即客户
Nuxt.js是一个建立在Vue.js基础上的服务端渲染框架。它非常易于上手并且可以让你在几分钟内构建你的应用。服务端渲染是一个解决所有SPA的SEO问题的伟大