搭建Nuxt项目(搭配Element UI、axios)

使用Nuxt

Nuxt.js文档:https://zh.nuxtjs.org/guide/

开始

初始化Nuxt项目

npx create-nuxt-app <项目名>

// or

yarn create nuxt-app <项目名>

运行

npm run dev

路由

基础路由

Nuxt.js依据 pages 目录结构自动生成 vue-router 模块的路由配置。

举例, pages 如下:

pages/
--| user/
-----| index.vue
-----| one.vue
--| index.vue

那么,Nuxt.js 自动生成的路由配置如下:

router: {
  routes: [
    {
      name: 'index',
      path: '/',
      component: 'pages/index.vue'
    },
    {
      name: 'user',
      path: '/user',
      component: 'pages/user/index.vue'
    },
    {
      name: 'user-one',
      path: '/user/one',
      component: 'pages/user/one.vue'
    }
  ]
}

路由传参

由于在Nuxt.js中,不需要配置 vue-router ,路由配置完全依赖 pages 目录的结构。所以传参时也不例外。

vue-router 中,通过 path: '/route/:param' 定义参数,而在Nuxt.js中,通过 _ 为前缀命名的Vue文件或目录。

通过 $route.params.参数名 取到参数值。

layout

在项目中,通常有一些组件,可以被多个页面复用,如 header、footer、nav 等,这些组件可以共同组成一个布局。

在Nuxt项目结构中,有 /layouts 文件夹,在这个文件夹中写布局文件。通常是引入 /components 里的组件,再加上 <nuxt />

举例:

<template>
  <div class="mLayout">
    <m-header />
    <!-- 这个是“坑”,使用了这个布局文件的页面生成的内容,将出现在下面的这个“坑”里面 -->
    <nuxt />
  </div>
</template>

<script>
// 需要注意的一个小细节 在Nuxt项目中 ~ 代表根目录
import mHeader from '~/components/mHeader.vue'

export default {
  components: {
    'm-header': mHeader
  }
}
</script>

在项目中使用Element-UI

安装element-ui

npm i element-ui -S

创建ElementUI.js

/plugins 文件夹下面,创建 ElementUI.js 文件。

import Vue from 'vue'
import ElementUI from 'element-ui'
Vue.use(ElementUI)

在nuxt.config.js中添加配置

css: [
  'element-ui/lib/theme-chalk/index.css'
],
plugins: [
  // ssr: true表示这个插件只在服务端起作用
  {src: '~/plugins/ElementUI', ssr: true }
],
build: {
  // 防止element-ui被多次打包
  vendor: ['element-ui']
}

在项目中使用axios

安装axios

npm i axios -S

创建axios.js

/plugins 文件夹下面,创建 axios.js 文件。

import axios from 'axios'

// 设置baseURL
axios.defaults.baseURL = 'http://localhost:3301'

// 创建axios对象,暴露
export default axios.create()

在nuxt.config.js中添加配置

防止重复打包

build: {
  vendor: ['axios']
}

使用

在项目的任意一个Vue文件中,引入生成了的axios对象:

import axios from '~/plugins/axios'

如果没有事先创建axios.js,也可以直接引入axios模块来使用:

import axios from 'axios'

先创建axios.js,生成axios对象的好处是,可以做一些配置,如baseURL等。

SEO优化

全局

修改 nuxt.config.js 配置文件,项目生成的每一个 html 文件的 <head> 中都会加入此配置。

  head: {
    // title: pkg.name,
    title: '想被百度垂青的标题',
    meta: [
      { charset: 'utf-8' },
      { name: 'viewport', content: 'width=device-width, initial-scale=1' },
      { hid: 'description', name: 'description', content: pkg.description },
      // 其它那些是本来就有的,加上的内容在这里
      {
        name: 'keywords',
        content:
          '很多个很多个关键词很多个很多个关键词很多个很多个关键词'
      }
    ],
    link: [{ rel: 'icon', type: 'image/x-icon', href: '/favicon.ico' }]
  },

局部

某个 Vue 文件中:

<script>
export default {
  layout: 'mLayout',
  // SEO优化
  head () {
    return {
      title: '标题',
      meta: [
        {
          name: 'keywords',
          content: '很多个很多个关键词很多个很多个关键词很多个很多个关键词'
        }
      ]
    }
  }
}
</script>

马克Eslint的一个小坑

在Nuxt项目中,个人出现了Eslint抽风的情况,报了诸如 Attribute "for" should be on a new line vue/max-attributes-per-line 的error,并且eslint不能正确地格式化代码。

解决

修改 .eslintrc.js 文件的配置,在 rules 中加上以下配置,就不会报错了。

'vue/max-attributes-per-line': [
  2,
  {
    singleline: 1,
    multiline: {
      max: 1,
      allowFirstLine: true
    }
  }
]
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 222,000评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,745评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 168,561评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,782评论 1 298
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,798评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,394评论 1 310
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,952评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,852评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,409评论 1 318
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,483评论 3 341
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,615评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,303评论 5 350
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,979评论 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,470评论 0 24
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,571评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 49,041评论 3 377
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,630评论 2 359

推荐阅读更多精彩内容