详解使用Nuxt.js快速搭建服务端渲染(SSR)应用


Posted in Javascript onMarch 13, 2019

安装 nuxt.js

Nuxt.js 官方提功了两种方法来进行项目的初始化,一种是使用Nuxt.js团队的脚手架工具 create-nuxt-app ,一种是根据自己的需求自由配置

使用脚手架适合新手,对 nodejs 后台框架有所了解;按照自己需求自由配置,需要对如何配置 webpack 以及 nodejs 后台框架有所了解。

两种方式比较下就是原生和插件的区别。

使用脚手架安装

需要有 nodejs 或者yarn 环境,推荐使用 vscode 自带的控制台输入命令行命令进行操作

在有了环境之后直接输入以下命令就可以直接创建一个项目(npx 在npm 5.2.0默认安装,使用最新稳定nodejs环境不用考虑有没有)

npx create-nuxt-app <项目名>

#或者用yarn

yarn create nuxt-app <项目名>

之后他会提示你进行一些选择

1.项目名

在这里可以设置项目名,亦可以之后在 package.js 中设置 name 属性,一般是在输入上面命令时的项目名,不需要修改直接回车就好

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

2.项目描述

这里是关于项目的描述,比如是做什么的,也可以之后在 package.js 中设置 description 属性

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

3.选择服务器端框架

看自己习惯使用什么了,一般 Express Koa 居多

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

4.扩展插件

选择 axios EsLint Prettier

  • axios 发送HTTP请求
  • EsLint 在保存时代码规范和错误检查自己的代码。
  • Prettier 在保存时格式化/美化自己的代码。

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

5.选择 UI 框架

UI 框架方便快速开发,提供了很多现成的样式,近几年听到最多的就是 Element UI

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

6.选择测试框架

测试框架是用来检测程序有没有到达预期的目的,有没有出错,这里暂时用不到,所以选择 none 就好

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

7.选择渲染模式

这里分单页应用(spa)以及普遍的方式(Universal),单页应用有很多路由但是页面只有一个,所有能看到的页面都是 js 即时生成的 dom,第二种是在服务器生成 html ,有多少路由就有多少页面。

使用 nuxt 就是为了解决 SEO 的问题,使其实现所有网站路径完全被收录

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

8.作者

这个也可以之后在 package.js 中设置 author 属性

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

9.选择包管理工具

这里选择那个都可以,看自己习惯用哪个

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

10.选择完成开始安装

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

11.安装完成

提示信息

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

项目目录

详解使用Nuxt.js快速搭建服务端渲染(SSR)应用

关于如何根据自己的需求自由配置,这里不讲,有需要自由配置的一般都不是新手了,推荐看看官方文档

添加其他常用功能

除了 nuxt 脚手架自带的,我们还需要其他配置,ES6的编译 ,CSS的预处理,其他的用到了再添加

安装 babel

yarn add babel-cli babel-preset-env

配置文件

.babelrc

{
 "presets": ["env"]
}

安装 scss

yarn add node-sass 
yarn add sass-loader

之后只需要在 vue 文件的 style 标签加一条属性声明下就好

<style lang="sass">
</style>
# or
<style lang="scss">
</style>

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

Javascript 相关文章推荐
写出更好的JavaScript之undefined篇(上)
Nov 22 Javascript
onsubmit阻止form表单提交与onclick的相关操作
Sep 03 Javascript
jquery 按钮状态效果 正常、移上、按下
Aug 12 Javascript
jquery自定义类似$.ajax()的方法实现代码
Aug 13 Javascript
分享Javascript中最常用的55个经典小技巧
Nov 29 Javascript
jquery ajax jsonp跨域调用实例代码
Dec 11 Javascript
php和js对数据库图片进行等比缩放示例
Apr 28 Javascript
JavaScript中使用sencha gridpanel 编辑单元格、改变单元格颜色
Nov 26 Javascript
js和jquery实现监听键盘事件示例代码
Jun 24 Javascript
使用BootStrap实现悬浮窗口的效果
Dec 13 Javascript
基于jquery实现五星好评
Nov 18 jQuery
vue.js实现的经典计算器/科学计算器功能示例
Jul 11 Javascript
react同构实践之实现自己的同构模板
Mar 13 #Javascript
使用Node.js实现一个多人游戏服务器引擎
Mar 13 #Javascript
你可能不知道的CORS跨域资源共享
Mar 13 #Javascript
react项目如何使用iconfont的方法步骤
Mar 13 #Javascript
使用jquery的cookie实现登录页记住用户名和密码的方法
Mar 13 #jQuery
深入Node TCP模块的理解
Mar 13 #Javascript
详解如何使用微信小程序云函数发送短信验证码
Mar 13 #Javascript
You might like
缅甸的咖啡简史
2021/03/04 咖啡文化
php中session退出登陆问题
2014/02/27 PHP
Linux下安装PHP MSSQL扩展教程
2014/10/24 PHP
JavaScript 克隆数组最简单的方法
2009/02/12 Javascript
JavaScript的null和undefined区别示例介绍
2014/09/15 Javascript
javascript设计模式--策略模式之输入验证
2015/11/27 Javascript
基于JS2Image实现圣诞树代码
2015/12/24 Javascript
javaScript语法总结
2016/11/25 Javascript
javaScript生成支持中文带logo的二维码(jquery.qrcode.js)
2017/01/03 Javascript
常用的javascript设计模式
2017/01/11 Javascript
微信小程序中显示html格式内容的方法
2017/04/25 Javascript
web.js.字符串与正则表达式操作
2017/05/13 Javascript
Vue中父子组件通讯之todolist组件功能开发
2018/05/21 Javascript
vue结合element-ui使用示例
2019/01/24 Javascript
jQuery实现当拉动滚动条到底部加载数据的方法分析
2019/01/24 jQuery
JavaScript变量作用域及内存问题实例分析
2019/06/10 Javascript
Vue的data、computed、watch源码浅谈
2020/04/04 Javascript
python冒泡排序算法的实现代码
2013/11/21 Python
Python实现多属性排序的方法
2018/12/05 Python
wxpython绘制音频效果
2019/11/18 Python
python实现逆滤波与维纳滤波示例
2020/02/26 Python
在Mac中配置Python虚拟环境过程解析
2020/06/22 Python
使用Keras训练好的.h5模型来测试一个实例
2020/07/06 Python
用pandas划分数据集实现训练集和测试集
2020/07/20 Python
基于Python爬取京东双十一商品价格曲线
2020/10/23 Python
泰国折扣酒店预订:Hotels2Thailand
2018/03/20 全球购物
MYSQL基础面试题
2012/05/13 面试题
大学竞选班长演讲稿
2014/04/24 职场文书
公司口号大全
2014/06/11 职场文书
奥巴马上海演讲稿
2014/09/10 职场文书
小学感恩节活动策划方案
2014/10/06 职场文书
nginx处理http请求实现过程解析
2021/03/31 Servers
Python Numpy之linspace用法说明
2021/04/17 Python
html5中sharedWorker实现多页面通信的示例代码
2021/05/07 Javascript
MySQL中in和exists区别详解
2021/06/03 MySQL
Python中super().__init__()测试以及理解
2021/12/06 Python