vue 最佳實踐

前言


前端技術(shù)近幾年發(fā)展十分迅速泉蝌,經(jīng)歷了jQuery嗅虏,angularjs,發(fā)展到現(xiàn)在的Angular蒜鸡,Vue和React三大前端框架。因Vue相比其他框架更容易上手(無需了解jsx牢裳、ts)逢防,且性能優(yōu)異,因而受到廣大開發(fā)者的青睞蒲讯。以下詳細介紹Vue框架忘朝。

vue 全家桶


  • vue-cli 自動化構(gòu)建工具
  • vue-router 路由控制
  • vuex 狀態(tài)管理
  • vue-Devtool 調(diào)試工具
  • UI組件庫 (elementUI,vant)
  • axios http請求

vue-cli 自動化構(gòu)建工具

搭建交互式的項目腳手架判帮,集成了前端生態(tài)中最好的工具

交互式的項目腳手架

基礎(chǔ)配置

module.exports = {
  // 項目部署的基礎(chǔ)路徑
  publicPath: process.env.PUBLIC_PATH,
  // 將構(gòu)建好的文件輸出到哪里
  outputDir: process.env.PUBLIC_PATH,
  // 該對象將會被 webpack-merge 合并入最終的 webpack 配置局嘁。
  configureWebpack: config => {
    if (process.env.NODE_ENV === 'production') {
      // 為生產(chǎn)環(huán)境修改配置...
    } else {
      // 為開發(fā)環(huán)境修改配置...
      config.devtool = 'source-map'
    }
  },
  // 向 CSS 相關(guān)的 loader 傳遞選項
  css: {
    loaderOptions: {
      scss: {
        // 全局引入index.scss
        prependData: `@import "~@/assets/styles/index.scss";`
      }
    }
  },
  // 鏈式操作,允許對內(nèi)部的 webpack 配置進行更細粒度的修改晦墙。
  chainWebpack: config => {
    const svgRule = config.module.rule('svg')

    // 清除已有的所有 loader悦昵。
    // 如果你不這樣做,接下來的 loader 會附加在該規(guī)則現(xiàn)有的 loader 之后晌畅。
    svgRule.uses.clear()

    // 添加要替換的 loader
    svgRule
      .use('vue-svg-loader')
        .loader('vue-svg-loader')
  },
  // 前后的分離時但指,配置代理服務器
  devServer: {
    proxy: {
      '/': {
        target: process.env.PROXY_TARGET,
        pathRewrite: {
          '/test': ''
        }
      }
    }
  }
}

環(huán)境變量管理

通過cross-env來管理不同環(huán)境的變量

.env                # loaded in all cases
.env.local          # loaded in all cases, ignored by git
.env.[mode]         # only loaded in specified mode
.env.[mode].local   # only loaded in specified mode, ignored by git

優(yōu)先級:.local > .[mode] > .env

.env文件可以簡單的以key=value的方式定義變量:

NODE_ENV=production
VUE_APP_TITLE=My App (staging)

注意:變量必須以VUE_APP_*命名才可以在程序中使用。(NODE_ENVBASE_URL除外)

執(zhí)行命令:

vue-cli-service build --mode development // 會讀取.env .env.development .env.development.local

獲取參數(shù):

process.env.NODE_ENV

vue-router 路由控制

路由的基本配置

import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from '../views/Home.vue'

Vue.use(VueRouter)

const routes = [
  {
    path: '/',
    name: 'home',
    component: Home  // 會打包進app.js
  },
  {
    path: '/about',
    name: 'about',
    // 會打包到about.js棋凳,在訪問路由about時拦坠,才加載about.js
    component: () => import(/* webpackChunkName: "about" */ '../views/About.vue') 
  }
]

const router = new VueRouter({
  mode: 'hash',
  base: process.env.BASE_URL,
  routes
})

export default router

運行npm run build打包

code splitting

路由的兩種模式:

  • hash
  • history

hash模式不需要后端配置,可直接使用剩岳。缺點是無法使用錨點功能贪婉。
history模式需要后端配置,url不會出現(xiàn)#卢肃,美觀疲迂。

vuex 狀態(tài)管理

  1. 為什么要使用vuex?

以下場景:

  • 從根組件向子組件傳值莫湘,我們一般使用props尤蒿,倘若有多層嵌套時,得一級一級向下傳遞幅垮,比較繁瑣腰池,并 且中間層級可能并不需要該值。
  • 兄弟組件需要使用同一狀態(tài)時忙芒,得通過父組件才能通信示弓。
  • 來自不同視圖的行為需要變更同一狀態(tài)。
  1. 單向數(shù)據(jù)流
    用 Vuex 的思維去實現(xiàn)v-model的雙向綁定效果:給 <input> 中綁定 value呵萨,然后偵聽 input 或者 change 事件奏属,在事件回調(diào)中調(diào)用 action,通過action改變state潮峦,從而再更新視圖:
<input :value="message" @input="updateMessage">
// ...
computed: {
  ...mapState({
    message: state => state.obj.message
  })
},
methods: {
  updateMessage (e) {
    this.$store.commit('updateMessage', e.target.value)
  }
}
// ...
mutations: {
  updateMessage (state, message) {
    state.obj.message = message
  }
}

雙向綁定的計算屬性

<input v-model="message">
// ...
computed: {
  message: {
    get () {
      return this.$store.state.obj.message
    },
    set (value) {
      this.$store.commit('updateMessage', value)
    }
  }
}
  1. 父子組件通過props傳遞數(shù)據(jù)
    子組件數(shù)據(jù)源通過父組件傳遞囱皿,雖然增加了耦合,但組件之間的層級關(guān)系更明顯忱嘹,代碼邏輯也更清晰明了嘱腥。

  2. Vue官網(wǎng)對Vuex的解釋:

  • Vuex 的狀態(tài)存儲是響應式的。當 Vue 組件從 store 中讀取狀態(tài)的時候拘悦,若 store 中的狀態(tài)發(fā)生變化齿兔,那么相應的組件也會相應地得到高效更新。

  • 你不能直接改變 store 中的狀態(tài)础米。改變 store 中的狀態(tài)的唯一途徑就是顯式地提交 (commit) mutation分苇。這樣使得我們可以方便地跟蹤每一個狀態(tài)的變化,從而讓我們能夠?qū)崿F(xiàn)一些工具幫助我們更好地了解我們的應用椭盏。

vue-Devtool 調(diào)試工具

image.png

UI組件庫 (elementUI组砚,vant)

axios http請求

相關(guān)配置

import Axios from 'axios'
import store from '@/store'

const instance = Axios.create({
  baseURL: '',
  timeout: 60000
})

instance.interceptors.request.use(
  config => {
    const csrf = store.getters.csrf
    config.headers = {
      csrf,
      'Content-Type': 'application/json'
    }
    return config
  },
  error => {
    return Promise.reject(error)
  }
)

instance.interceptors.response.use(
  response => {
    const res = response.data
    // code here

    return res
  },
  error => {
    return Promise.reject(error)
  }
)

export default instance

使用方法

import request from '@/utils/request'

export const getArticles = () => {
  return request({
    methods: 'get',
    url: '',
    params: {}
  })
}

export const saveArticles = () => {
  return request({
    methods: 'post',
    url: '',
    data: {}
  })
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吻商,一起剝皮案震驚了整個濱河市掏颊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖乌叶,帶你破解...
    沈念sama閱讀 212,454評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件盆偿,死亡現(xiàn)場離奇詭異,居然都是意外死亡准浴,警方通過查閱死者的電腦和手機事扭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來乐横,“玉大人求橄,你說我怎么就攤上這事∑瞎” “怎么了罐农?”我有些...
    開封第一講書人閱讀 157,921評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長催什。 經(jīng)常有香客問我涵亏,道長,這世上最難降的妖魔是什么蒲凶? 我笑而不...
    開封第一講書人閱讀 56,648評論 1 284
  • 正文 為了忘掉前任气筋,我火速辦了婚禮,結(jié)果婚禮上旋圆,老公的妹妹穿的比我還像新娘宠默。我一直安慰自己,他們只是感情好灵巧,可當我...
    茶點故事閱讀 65,770評論 6 386
  • 文/花漫 我一把揭開白布光稼。 她就那樣靜靜地躺著,像睡著了一般孩等。 火紅的嫁衣襯著肌膚如雪艾君。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,950評論 1 291
  • 那天肄方,我揣著相機與錄音冰垄,去河邊找鬼。 笑死权她,一個胖子當著我的面吹牛虹茶,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播隅要,決...
    沈念sama閱讀 39,090評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼蝴罪,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了步清?” 一聲冷哼從身側(cè)響起要门,我...
    開封第一講書人閱讀 37,817評論 0 268
  • 序言:老撾萬榮一對情侶失蹤虏肾,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后欢搜,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體封豪,經(jīng)...
    沈念sama閱讀 44,275評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,592評論 2 327
  • 正文 我和宋清朗相戀三年炒瘟,在試婚紗的時候發(fā)現(xiàn)自己被綠了吹埠。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,724評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡疮装,死狀恐怖缘琅,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情廓推,我是刑警寧澤胯杭,帶...
    沈念sama閱讀 34,409評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站受啥,受9級特大地震影響做个,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜滚局,卻給世界環(huán)境...
    茶點故事閱讀 40,052評論 3 316
  • 文/蒙蒙 一居暖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧藤肢,春花似錦太闺、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至最住,卻和暖如春钞澳,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背涨缚。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評論 1 266
  • 我被黑心中介騙來泰國打工轧粟, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人脓魏。 一個月前我還...
    沈念sama閱讀 46,503評論 2 361
  • 正文 我出身青樓兰吟,卻偏偏與公主長得像,于是被迫代替她去往敵國和親茂翔。 傳聞我的和親對象是個殘疾皇子混蔼,可洞房花燭夜當晚...
    茶點故事閱讀 43,627評論 2 350