VUE基于NUXT的SSR 服务端渲染


Posted in Javascript onNovember 30, 2018

Server Side Rendering(服务端渲染)

SSR 目的是为了解决单页面应用的 SEO 的问题,对于一般网站影响不大,但是对于论坛类,内容类网站来说是致命的,搜索引擎无法抓取页面相关内容,也就是用户搜不到此网站的相关信息。

原理

将 html 在服务端渲染,合成完整的 html 文件再输出到浏览器。

适用场景

  • 客户端的网络比较慢
  • 客户端运行在老的或者直接没有 JavaScript 引擎上

NUXT

作用就是在 node.js 上进一步封装,然后省去我们搭建服务端环境的步骤,只需要遵循这个库的一些规则就能轻松实现 SSR。

可以作为一个 Node.js 应用跑在服务器上,也可以把整站直接编译为静态 HTML。另外这个框架支持自动生成路由,用来写展示型的页面是非常不错的选择。

NUXT 能为我们做什么

  • 无需再为了路由划分而烦恼,你只需要按照对应的文件夹层级创建 .vue 文件就行
  • 无需考虑数据传输问题,nuxt 会在模板输出之前异步请求数据(需要引入 axios 库),而且对 vuex 有进一步的封装
  • 内置了 webpack,省去了配置 webpack 的步骤,nuxt 会根据配置打包对应的文件

安装流程

$ npm install -g vue-cli

$ vue init nuxt/starter <project-name>
$ cd <project-name>
$ npm install

$ npm run dev

Nuxt.js 会监听 pages 目录下的改变,添加新 page 的时候不需要重启服务

Next.js

来自Zeit的团队在React的基础和组件模型上构建了Next.js,同时还提供了一个关键扩展:通过使用名为getInitialProps()的组件生命周期钩子方法,框架能够在服务器上进行初始渲染,如果需要的话,还可以在客户端继续进行渲染。不过这个高级特性是一个很小却功能强大的框架所额外提供的。

Next提供了非常丰富的生态环境,特别是它的example,包含了多种情况下的源码,让学习者很容易搭建起一个多功能的Next框架,客户端有的东西,服务端基本都有。

  • webpack的各项配置,Next集成了webpack的很多配置,热更新是必备品,还支持提供next.config.js的方式导入自己定义的配置。
  • 你可以使用less、scss、style-in-Component、css等各种样式写法。
  • 支持redux、redux-saga、或者不用。
  • 各种图片的支持都包含在webpack中了。
  • 支持自定义的babelrc配置。
  • 对于react的版本的支持也在维护者的维护中不断更新。
  • 支持preact。

简单易用,就跟写 PHP 一样一个文件一个页面了,但缺点也很明显,其实它是通过改变正常 React + webpack 的代码书写习惯来绕过前后端同构的坑,所以也引入了一些新的问题:

  • 图片等静态文件只能放在 static 目录下,不能通过 require 来引入,也就是没办法通过 webpack 来进行模块化管理,如果各个组件有自身依赖的图片,也只能一股脑放 static 里,也很难实现版本管理控制浏览器缓存。
  • 样式同样也没办法通过 webpack 进行模块化管理,只能通过 style 标签嵌入或直接内联。

简单地说,很适合快速搭建简单站点,但自由度不高,且带样式或图片的 React 组件无法直接使用,个人看法是一个用自由度和通用性来换取易用性的框架。

其他方法

Google 可以正常爬取和渲染一个纯 js 动态生成的网站,上传 sitemap 就可以了。

直接生成静态页面由 CDN 分发。有些新技术还可以在 static gen 同时支持 pwa,比如 gatsbyjs。

掘金是未登录用户使用 SSR,不错的思路。

要分清楚什么时候用 mvvm,mvvm 其实就是 modelview 非常方便定义页面的各种逻辑和改变页面数据,如果是传统的网站,前端没啥逻辑,就没有必要上 mvvm

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

Javascript 相关文章推荐
JQuery slideshow的一个小问题(如何发现及解决过程)
Feb 06 Javascript
JS控件ASP.NET的treeview控件全选或者取消(示例代码)
Dec 16 Javascript
jquery选择器之层级过滤选择器详解
Jan 27 Javascript
jquery缓动swing liner控制动画过程不同时刻的速度
May 29 Javascript
原生js结合html5制作小飞龙的简易跳球
Mar 30 Javascript
js中substring和substr两者区别和使用方法
Nov 09 Javascript
Vue原理剖析 实现双向绑定MVVM
May 03 Javascript
JScript实现地址选择功能
Aug 15 Javascript
详解.vue文件中监听input输入事件(oninput)
Sep 19 Javascript
Angular 4根据组件名称动态创建出组件的方法教程
Nov 01 Javascript
微信小程序实现消息框弹出动画
Apr 18 Javascript
vue实现行列转换的一种方法
Aug 06 Javascript
Nuxt.js开启SSR渲染的教程详解
Nov 30 #Javascript
基于JavaScript实现每日签到打卡轨迹功能
Nov 29 #Javascript
Next.js项目实战踩坑指南(笔记)
Nov 29 #Javascript
js canvas实现二维码和图片合成的海报
Nov 19 #Javascript
详解@angular/cli 改变默认启动端口两种方式
Nov 29 #Javascript
js实现每日签到功能
Nov 29 #Javascript
Vue.js的复用组件开发流程完整记录
Nov 29 #Javascript
You might like
构建简单的Webmail系统
2006/10/09 PHP
xajax写的留言本
2006/11/25 PHP
PHP和Mysqlweb应用开发核心技术-第1部分 Php基础-2 php语言介绍
2011/07/03 PHP
PHP获取http请求的头信息实现步骤
2012/12/16 PHP
PHP怎么实现网站保存快捷方式方便用户随时浏览
2013/08/15 PHP
php中字符串和正则表达式详解
2014/10/23 PHP
用 Composer构建自己的 PHP 框架之设计 MVC
2014/10/30 PHP
TNC vs BOOM BO3 第二场2.13
2021/03/10 DOTA
Javascript对象中关于setTimeout和setInterval的this介绍
2012/07/21 Javascript
jQuery语法高亮插件支持各种程序源代码语法着色加亮
2013/04/27 Javascript
使用Node.js为其他程序编写扩展的基本方法
2015/06/23 Javascript
JavaScript操作HTML元素和样式的方法详解
2015/10/21 Javascript
AngularJS ngModel实现指令与输入直接的数据通信
2016/09/21 Javascript
Angularjs的Controller间通信机制实例分析
2016/11/07 Javascript
AngularJS+Bootstrap实现多文件上传与管理
2016/11/08 Javascript
理解AngularJs篇:30分钟快速掌握AngularJs
2016/12/23 Javascript
微信小程序 跳转传参数与传对象详解及实例代码
2017/03/14 Javascript
利用vue开发一个所谓的数独方法实例
2017/12/21 Javascript
layer.open关闭父窗口 以及调用父页面的方法
2018/08/17 Javascript
如何利用node转发请求详解
2020/09/17 Javascript
javascript实现左右缓动动画函数
2020/11/25 Javascript
python字典排序实例详解
2015/05/20 Python
浅谈python新式类和旧式类区别
2019/04/26 Python
Python实现京东秒杀功能代码
2019/05/16 Python
python随机生成库faker库api实例详解
2019/11/28 Python
美国在线宠物用品商店:Entirely Pets
2017/01/01 全球购物
缓解脚、腿和背部疼痛:Z-CoiL鞋
2019/03/12 全球购物
Notino瑞典:购买香水和美容产品
2019/07/26 全球购物
科级干部群众路线教育实践活动对照检查材料思想汇报
2014/09/20 职场文书
毕业纪念册寄语大全
2015/02/26 职场文书
2015年学校总务工作总结
2015/07/20 职场文书
婚礼父母致辞
2015/07/28 职场文书
OpenCV-Python实现轮廓的特征值
2021/06/09 Python
Python中使用Opencv开发停车位计数器功能
2022/04/04 Python
vue route新窗口跳转页面并且携带与接收参数
2022/04/10 Vue.js
Mysql查询时间区间日期列表,不会由于数据表数据影响
2022/04/19 MySQL