欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Nuxt.js改造已有項目的方法

 更新時間:2018年08月07日 10:57:54   作者:wopelo  
這篇文章主要介紹了使用Nuxt.js改造已有項目的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

如果我們需要對現(xiàn)有的vue項目進行ssr改造,使用nuxt.js是一個不錯的選擇。這里用作例子的“現(xiàn)有項目”是一個“高仿”餓了么外賣APP的spa。不過我沒有把全部功能開發(fā)出來(全部做出來就不得了了),只是做出幾個基本界面意思意思

 

下面就以這個demo為小白鼠進行ssr改造

準備

現(xiàn)有目錄

 

很明顯,這是使用vue-cli搭建的項目

其中prod.server.js是build之后的啟動文件

dataa.json文件是模擬數(shù)據(jù),在build/dev-server.js中會用到它

安裝與配置

安裝nuxt

npm install --save-dev nuxt

新建nuxt文件夾

我們需要在根目錄下建立一個nuxt文件夾,該文件夾的內(nèi)部組織按照nuxt本身的應用目錄架構(gòu)進行組織(參考

 

注意,在static目錄下有一個logo.png,它將作為項目圖標,在nuxt.config.js中這張圖片的地址直接寫成/logo.png。下一節(jié)會對nuxt文件夾的組織進行詳細說明。

新建并設置nuxt.config.js

當然,我們也需要在根目錄下創(chuàng)建nuxt.config.js文件用于組織Nuxt.js 應用的個性化配置,在這個項目中,需要進行設置的點有:

  1. 源碼目錄路徑
  2. head中的meta以及l(fā)ink(主要是圖標)
  3. 全局的css樣式
  4. 項目中需要使用圖片和字體文件,雖然nuxt默認對其進行配置,但我們需要重新定義部分內(nèi)容(項目中是擴大limit)
  5. 項目中使用了sass,需要對其進行配置

所以,nuxt.config.js的代碼如下

module.exports = {
  // 設置nuxt源碼目錄路徑
  srcDir: "nuxt/",
  head: {
    title: "sell-nuxt",
    meta: [
      {
        charset: "utf-8"
      },
      {
        name: "viewport",
        content: "width=device-width, initial-scale=1,user-scalable=no,maximum-scale=1.0,minimum-scale=1.0"
      }
    ],
    link: [
      {
        rel: "shortcut icon",
        type: "image/png",
        // 注意圖片的路徑直接指向static下的logo.png
        href: "/logo.png"
      }
    ]
  },
  css: [
    "~assets/reset.css"
  ],
  build: {
    vendor: ['axios'],
    loaders: [
      {
        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
        loader: 'url-loader',
        options: {
         limit: 10000,
         name: 'img/[name].[hash:7].[ext]'
        }
      },
      {
        test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
        loader: 'url-loader',
        options: {
         limit: 10000,
         name: 'fonts/[name].[hash:7].[ext]'
        }
      },
      {
        test: /\.scss$/,
        loader: "vue-style-loader!css-loader!sass-loader"
      }
    ]
  }
}

配置package.json

package.json是npm的配置文件,現(xiàn)在,我們需要對script選項進行配置

"scripts": {
  "dev": "nuxt",
  "build": "nuxt build",
  "start": "nuxt start",
  "generate": "nuxt generate",
  "lint": "eslint --ext .js,.vue --ignore-path .gitignore .",
  "precommit": "npm run lint"
 }

可以參考nuxt的命令列表

改造后的目錄

 

其中有個nuxt.api.js,這個文件是為完成ssr改造后的項目提供api接口的,使用koa,運行在3001端口

nuxt文件夾組織

因為我們已經(jīng)把項目代碼開發(fā)出來了,所以nuxt文件夾里面的大部分代碼可以直接從已有代碼中拷貝

layouts

布局目錄 layouts 用于組織應用的布局組件,nuxt可通過添加 layouts/default.vue 文件來擴展應用的默認布局,在layouts下新建default.vue

<template>
 <div id="app">
  <v-header v-bind:seller="seller"></v-header>
  <v-tab></v-tab>
  <nuxt/>
 </div>
</template>

<script>
 import axios from 'axios';
 // 引入組件
 import header from "~/components/header/header.vue";
 import tab from "~/components/tab/tab.vue";
 export default {
  data:function(){
   return {
    seller:{}
   }
  },
  created:function(){
   axios.get("http://localhost:3001/seller").then(res=>{
    console.log(res.data);
    this.seller = res.data.data;
   });
  },
  components:{
   "v-header":header,
   "v-tab":tab
  }
 }
</script>

<style lang="scss" rel="text/css">

</style>

<nuxt/> 組件用于顯示頁面的主體內(nèi)容,即“商品”、“評論”、“商家”這幾個部分

pages

nuxt依據(jù) pages 目錄結(jié)構(gòu)自動生成 vue-router 模塊的路由配置,這無疑是非常方便的

 

不難看出goods、patings、seller分別對應“商品”、“評論”、“商家”

這樣子設置,則nuxt自動生成的路由配置如下

router: {
 routes: [
  {
   name: 'index',
   path: '/',
   component: 'pages/index.vue'
  },
  {
   name: 'goods',
   path: '/goods',
   component: 'pages/goods/index.vue'
  },
  {
   name: 'patings',
   path: '/patings',
   component: 'pages/patings/index.vue'
  },
  {
   name: 'seller',
   path: '/seller',
   component: 'pages/seller/index.vue'
  }
 ]
}

但我們希望默認進入goods,nuxt官方文檔并沒有說如何設置默認路徑,這就是為什么要在pages下面創(chuàng)建一個index.vue

<template>

</template>

<script>
 export default {
  created:function(){
   this.$router.push('/goods'); // 頁面加載時跳轉(zhuǎn)
  }
 }
</script>

<style lang="scss" rel="text/css">

</style>

對于那些不需要像在pages下的頁面組件那樣有 asyncData 方法的特性的組件,我們可以將他們放到components目錄下

assets

資源目錄 assets 用于組織未編譯的靜態(tài)資源如 LESS、SASS 或 JavaScript,這個目錄是我感覺在引用路徑時最坑的一個。
在官方文檔中,每個目錄都有別名,這些別名在nuxt.config.js中配置時是有效的,比如之前配置的css選項,但不代表我們在組件中使用這些別名會有效,在組件中我們最好使用相對路徑,比如在components/header/header.vue中就不能直接寫~assets,而得老老實實寫相對路徑

<style lang="scss" rel="text/css" src="../../assets/base.scss"></style>
<style type="text/css" src="../../assets/style.css"></style>
<style lang="scss" rel="text/css">
  @import "../../assets/mixin.scss";
  @import "./header.scss";
</style>

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Vue3之列表動畫和狀態(tài)動畫示例詳解

    Vue3之列表動畫和狀態(tài)動畫示例詳解

    這篇文章主要為大家介紹了Vue3之列表動畫和狀態(tài)動畫示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • ElementPlus表單rules校驗的方法步驟

    ElementPlus表單rules校驗的方法步驟

    相信大家經(jīng)常都會遇到要處理表單驗證的環(huán)節(jié),而我在最近的項目中也遇到需要做表單驗證的業(yè)務,下面這篇文章主要給大家介紹了關于ElementPlus表單rules校驗的方法步驟,需要的朋友可以參考下
    2023-04-04
  • vue實現(xiàn)面包屑的方法

    vue實現(xiàn)面包屑的方法

    這篇文章主要為大家詳細介紹了vue實現(xiàn)面包屑的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vue nextTick的原理解析

    Vue nextTick的原理解析

    這篇文章主要介紹了Vue nextTick的原理解析,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下
    2021-04-04
  • vue如何設置描點跳轉(zhuǎn)到對應頁面

    vue如何設置描點跳轉(zhuǎn)到對應頁面

    這篇文章主要介紹了vue如何設置描點跳轉(zhuǎn)到對應頁面問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Vue3使用el-form嵌套el-table進行單條數(shù)據(jù)的表單校驗功能

    Vue3使用el-form嵌套el-table進行單條數(shù)據(jù)的表單校驗功能

    在實際開發(fā)過程中,我們經(jīng)常需要處理表格中的表單數(shù)據(jù),比如在編輯表格中的某一行數(shù)據(jù)時進行校驗,本文給大家介紹了Vue3使用el-form嵌套el-table進行單條數(shù)據(jù)的表單校驗功能,文中有相關的代碼供大家參考,需要的朋友可以參考下
    2024-08-08
  • 在vue中嵌入外部網(wǎng)站的實現(xiàn)

    在vue中嵌入外部網(wǎng)站的實現(xiàn)

    這篇文章主要介紹了在vue中嵌入外部網(wǎng)站的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue3.x源碼剖析之數(shù)據(jù)響應式的深入講解

    vue3.x源碼剖析之數(shù)據(jù)響應式的深入講解

    這篇文章主要給大家介紹了關于vue3.x源碼剖析之數(shù)據(jù)響應式的相關資料,在講解過程中,我們會對比Vue2.x的API特性,使用有哪些區(qū)別,需要的朋友可以參考下
    2022-01-01
  • 詳解Vue3中對VDOM的改進

    詳解Vue3中對VDOM的改進

    這篇文章主要介紹了詳解Vue3中對VDOM的改進,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • vue 子組件修改data或調(diào)用操作

    vue 子組件修改data或調(diào)用操作

    這篇文章主要介紹了vue 子組件修改data或調(diào)用操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08

最新評論