從零開始搭建vue項目

来源:https://www.cnblogs.com/vikki7/archive/2019/07/26/11250837.html
-Advertisement-
Play Games

一、使用vue-cli搭建項目 註意:在mac執行該命令會報錯 改用管理員許可權執行以下命令即可 $ sudo npm install -g vue-cli$ vue init webpack tcloud$ cd tcloud$ npm run dev 完成了利用腳手架創建並啟動一個vue的項目,可 ...


一、使用vue-cli搭建項目

$ npm install  -g vue-cli

註意:在mac執行該命令會報錯

改用管理員許可權執行以下命令即可

$ sudo npm install -g vue-cli
$ vue init webpack tcloud
$ cd tcloud
$ npm run dev

完成了利用腳手架創建並啟動一個vue的項目,可訪問http://localhost:8080 看到下圖界面說明項目啟動成功。

二、引入vuex並實現數據持久化

1.首先對目錄結構調整後如下:

  • assets            前端靜態資源 包括圖片、樣式、和js插件
  • components    可復用的組件
  • lang               國際化/多語言環境配置文件 cn.js 業務相關文本翻譯-簡體   tw.js 業務相關文本翻譯-繁體
  • pages             業務組件
  • router             路由配置文件
  • vuex               store相關配置
  • App.vue          根組件
  • main.js            入口文件

2.安裝vuex

$ npm install vuex --save

3.創建store文件

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const state = {
  test: 1,
  lang: 'cn'
}
const mutations = {
  add: (state, data) => {
    state.selectGoods.push(data)
    state.test++
  }
}
const actions = {
  addTest: ({ commit }, data) => {
    commit('add', data)
  }
}
export default new Vuex.Store({
  state,
  mutations,
  actions
})

 4.在入口文件main.js中引入store

import store from './store/store'

// 並掛載到根實例中
new Vue({
  el: '#app',
  store,
  router,
  components: { App },
  template: '<App/>'
})

 5.vuex-persistedstate實現數據持久化

vuex可以進行全局的狀態管理,但刷新後刷新後數據會消失

  • 安裝
$ npm install vuex-persistedstate --save
  •  在store.js中引入及配置
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
  // ...
  plugins: [createPersistedState({
      storage: window.sessionStorage, // 不設置預設存儲到localStorage
      reducer(val) {  
          return {
          // 指定需要持久化的state
          lang: val.lang
        }
     }
  })]
  • 生效後在瀏覽器Storage中展示效果

三、實現多語言環境-簡繁體轉換

1.安裝vue-i18n

$ npm install vue-i18n --save

 

2.準備業務相關文本的翻譯文件

3.創建VueI18n 實例

代碼如下

import Vue from 'vue'
import VueI18n from 'vue-i18n'
import cnlocale from './cn'
import twlocale from './tw'
import store from '@/vuex/store'
Vue.use(VueI18n)
const i18n = new VueI18n({
  locale: store.state.lang || 'cn',
  messages: {
    cn: { ...cnlocale },
    tw: { ...twlocale }
  }
})
export default i18n

 

4.在main.js中引入vue-i18n

import i18n from './lang/index'
// 把 i18n 掛載到 vue 根實例上
new Vue({
  el: '#app',
  i18n,
  axios,
  store,
  router,
  components: { App },
  template: '<App/>'
})

5.引用

// 在HTML模板中引用
<van-button @click="logout" type="default">{{$t('log.out')}}</van-button>
// 在 js 模板中使用
this.$t('log.in')

6.解決切換語言後刷新界面時出現一瞬間白屏的問題

利用在app.vue的<router-view></router-view>加上v-if屬性和provide/inject,具體代碼實現如下:

// App.vue文件
<template>
  <div id="app">
    <router-view v-if="isAlive" />
  </div>
</template>

<script>
export default {
  name: 'App',
  provide () {
    return {
      reload: this.reload
    }
  },
  data () {
    return {
      isAlive: true
    }
  },
  methods: {
    reload () {
      this.isAlive = false
      this.$nextTick(function () {
        this.isAlive = true
      })
    }
  }
}
</script>

接下來在需要刷新的組件中註入reload函數 

<template>
    <button @click="refresh"></button>
</template>
<script>
    export default{
        name: 'refresh',
        inject: ['reload'],
        methods: {
              refresh () {
                  this.reload()
              }
        }
    }
</script>

四、實現登錄攔截

1.路由攔截

首先在定義路由的時候就需要多添加一個自定義欄位requireAuth,用於判斷該路由的訪問是否需要登錄。如果用戶已經登錄(token存在),則順利進入路由, 否則就進入登錄頁面。

const routes = [
    {
        path: '/',
        name: '/',
        component: Index
    },
    {
        path: '/repository',
        name: 'repository',
        meta: {
            requireAuth: true,  // 添加該欄位,表示進入這個路由是需要登錄的
        },
        component: Repository
    },
    {
        path: '/login',
        name: 'login',
        component: Login
    }
];

定義完路由後,我們主要是利用vue-router提供的鉤子函數beforeEach()對路由進行判斷

router.beforeEach((to, from, next) => {
    if (to.meta.requireAuth) {  // 判斷該路由是否需要登錄許可權
        if (store.state.token) {  // 通過vuex state獲取當前的token是否存在
            next();
        }
        else {
            next({
                path: '/login',
                query: {redirect: to.fullPath}  // 將跳轉的路由path作為參數,登錄成功後跳轉到該路由
            })
        }
    }
    else {
        next();
    }
})

每個鉤子方法接收三個參數:

  • to: Route: 即將要進入的目標 路由對象
  • from: Route: 當前導航正要離開的路由
  • next: Function: 一定要調用該方法來 resolve 這個鉤子。執行效果依賴 next 方法的調用參數。
    • next(): 進行管道中的下一個鉤子。如果全部鉤子執行完了,則導航的狀態就是 confirmed (確認的)。
    • next(false): 中斷當前的導航。如果瀏覽器的 URL 改變了(可能是用戶手動或者瀏覽器後退按鈕),那麼 URL 地址會重置到 from 路由對應的地址。
    • next('/') 或者 next({ path: '/' }): 跳轉到一個不同的地址。當前的導航被中斷,然後進行一個新的導航

2.axios攔截器

當前token失效了,但是token依然保存在本地,這時候你去訪問需要登錄許可權的路由時,實際上應該讓用戶重新登錄。 這時候就需要結合 http 攔截器 + 後端介面返回的http 狀態碼來判斷

// http request 攔截器
axios.interceptors.request.use(
    config => {
        if (store.state.token) {  // 判斷是否存在token,如果存在的話,則每個http header都加上token
            config.headers.Authorization = `token ${store.state.token}`;
        }
        return config;
    },
    err => {
        return Promise.reject(err);
    });

// http response 攔截器
axios.interceptors.response.use(
    response => {
        return response;
    },
    error => {
        if (error.response) {
            switch (error.response.status) {
                case 401:
                    // 返回 401 清除token信息並跳轉到登錄頁面
                    store.commit(types.LOGOUT);
              router.currentRoute.name !== 'login' && router.replace({
                        path: 'login',
                        query: {redirect: router.currentRoute.fullPath}
                    })
            }
        }
        return Promise.reject(error.response.data)   // 返回介面返回的錯誤信息
    });

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 問題描述: 使用webpack打包vue項目後,前後端聯調無法找到資源 解決方案: 一、 改為相對路徑,去除axios中地址的第一個“/” onProxyReq: function (proxyReq, req, res) { console.log("原路徑:" + req.originalUrl ...
  • 函數:簡單來說就是將程式中一段代碼封裝,再起一個名字。 步驟: 1.封裝 function 函數名(參數列表){ 函數體; return結果; } 解釋: 參數:接收傳入函數的數據,函數執行是必要的數據。參數其實就是一個普通變數,使用時與變數完全一致。當函數執行時,必需某些數據,那麼就需要定義參數, ...
  • 測試1 測試2 測試3 測試4 ...
  • 最近在開發項目,針對小程式前端,顯示文本需要添加下劃線問題,起初是通過border-bottom:1rpx solid #eee; 進行編寫,但是總是覺得線的高度過於粗,移動端最小單位值是 1 即:1rpx 1px,高度設置0.3是不生效的,後面看到相關博客通過 scale進行劃線,在這記錄下: ...
  • 清空 ...
  • 1 計算得來的屬性 2 3 4 如果需要使用表達式來創建屬性鍵,那麼需要使用方括弧。否則屬性名稱不會進行計算: 5 6 var obj = { 'b'+'ar': 'foo' }; 7 // SyntaxError: missing : after property id 8 9 把計算表達式放置到... ...
  • 一下內容為筆者個人理解,如有出入還請大佬指出不勝感激 頁面有數據未保存,用戶離開頁面分為兩種 1 . 直接關閉瀏覽器標簽 或者點擊瀏覽器後退按鈕 離開當前頁面 2. 在頁面內改變路由,或則刷新頁面(不包含新標簽頁打開頁面‘target=_blank’) 先說第1種情況 通過關閉頁簽和後退按鈕 1 通 ...
  • html: <section> <nav id="nav"> <a class="on">tab1</a> <a>tab2</a> <a>tab3</a> <a>tab4</a> </nav> <div id="contentBox"> <div class="box active">內容一</di ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...