Vue 全家桶介紹

Vue有著名的全家桶系列岗钩,包含了vue-router(http://router.vuejs.org)纽窟,vuex(http://vuex.vuejs.org)肖油, vue-resource(https://github.com/pagekit/vue-resource)。再加上構(gòu)建工具vue-cli臂港,sass樣式,就是一個(gè)完整的vue項(xiàng)目的核心構(gòu)成森枪。

概括起來(lái)就是:、1.項(xiàng)目構(gòu)建工具审孽、2.路由县袱、3.狀態(tài)管理、4.http請(qǐng)求工具佑力。

下面單獨(dú)介紹

前言:Vue兩大核心思想:組件化和數(shù)據(jù)驅(qū)動(dòng)式散。組件化:把整體拆分為各個(gè)可以復(fù)用的個(gè)體,數(shù)據(jù)驅(qū)動(dòng):通過(guò)數(shù)據(jù)變化直接影響bom展示打颤,避免dom操作暴拄。

一漓滔、Vue-cli是快速構(gòu)建這個(gè)單頁(yè)應(yīng)用的腳手架,

#?全局安裝?vue-cli

$ npm install --global vue-cli

#?創(chuàng)建一個(gè)基于?webpack?模板的新項(xiàng)目

$ vue init webpack my-project

#?安裝依賴,走你

$?

cd?my-project

$ npm install

$ npm run dev



二乖篷、vue-router

安裝:npm installvue-router

如果在一個(gè)模塊化工程中使用它响驴,必須要通過(guò)?Vue.use()?明確地安裝路由功能:

import Vue from'vue'

import VueRouter from'vue-router'

Vue.use(VueRouter)



另外注意在使用中,可以利用vue的過(guò)渡屬性來(lái)渲染出切換頁(yè)面的效果撕蔼。

三豁鲤、vuex

vuex為專門為vue.js應(yīng)用程序開(kāi)發(fā)的狀態(tài)管理可以理解為全局的數(shù)據(jù)管理。vuex主要由五部分組成:state ?action鲸沮、mutation琳骡、getters、module組成诉探。

使用流程是: 組件中可以直接調(diào)用上面四個(gè)部分除了module日熬,

1、state

類似vue?對(duì)象的data,?用來(lái)存放數(shù)據(jù)以及狀態(tài)肾胯。存放的數(shù)據(jù)為響應(yīng)式竖席,如果數(shù)據(jù)改變,那么依賴數(shù)據(jù)的組件也會(huì)發(fā)生相應(yīng)的改變敬肚。

獲取state的兩種方式例子:

1.store.getters['getRateUserInfo']

2. ...mapGetters({

??????? UserInfo: 'login/UserInfo', // 用戶信息

??????? menuList: 'getMenuList', // approve 運(yùn)價(jià)審批

??????? RateUserInfo: 'getRateUserInfo' // Rate用戶信息

?? })

注意:可以通過(guò)mapState把全局的state和 getters 映射到當(dāng)前組件的 computed計(jì)算屬性中毕荐。


2、actions

Action?通過(guò)?store.dispatch?方法觸發(fā):action支持異步調(diào)用(可以調(diào)用api)艳馒,mutation只支持操作同步憎亚,并且action提交的是?mutation,而不是直接變更狀態(tài)弄慰。

例如:

const store = new Vuex.Store({

? state: {

??? count: 0

? },

? mutations: {

??? increment (state) {

????? state.count++

??? }

? },

? actions: {

??? increment (context) {

????? context.commit('increment')

??? }

? }

})

Action?函數(shù)接受一個(gè)與?store?實(shí)例具有相同方法和屬性的?context?對(duì)象第美,因此你可以調(diào)用?context.commit?提交一個(gè)?mutation,或者通過(guò)?context.state?和?context.getters?來(lái)獲取?state?和?getters陆爽。


實(shí)踐中什往,我們會(huì)經(jīng)常用到?ES2015?的?參數(shù)解構(gòu)?來(lái)簡(jiǎn)化代碼(特別是我們需要調(diào)用?commit?很多次的時(shí)候):

actions:{

? increment ({ commit }){

??? commit('increment')

? }

}

3、mutation

每個(gè)?mutation?都有一個(gè)字符串的事件類型(type)和一個(gè)回調(diào)函數(shù)(handler)慌闭。這個(gè)回調(diào)函數(shù)就是我們實(shí)際進(jìn)行狀態(tài)更改的地方别威,并且它會(huì)接受?state?作為第一個(gè)參數(shù)。

4驴剔、getters

Vuex?允許我們?cè)?store?中定義“getter”(可以認(rèn)為是?store?的計(jì)算屬性)省古。就像計(jì)算屬性一樣,getter?的返回值會(huì)根據(jù)它的依賴被緩存起來(lái)丧失,且只有當(dāng)它的依賴值發(fā)生了改變才會(huì)被重新計(jì)算

const getters = {

? getRateInitData: state => state.rateInitData,

? getchooseRateObj: state => state.chooseRateObj,

? getSearchRateParams: state => state.searchRateParams,

? getSearchRateResult: state => state.searchRateResult,

? getRateUserInfo: state => state.RateUserInfo,

? getMenuList: state => state.menuList,

? getRateQueryParams: state => state.rateQueryParams,

? getRateQueryResult: state => state.rateQueryResult,

? getCheckRateDetailParams: state => state.checkRateDetailParams,

? getReferenceCondition: state => state.referenceCondition,

? getWaitApprovalParams: state => state.waitApprovalParams

}

mapGetters?輔助函數(shù)

mapGetters?輔助函數(shù)僅僅是將?store?中的?getter?映射到局部計(jì)算屬性:



四豺妓、axios

axios是一個(gè)http請(qǐng)求包,vue官網(wǎng)推薦使用axios進(jìn)行http調(diào)用。

安裝:

npm install axios --save

例子:

1.發(fā)送一個(gè)GET請(qǐng)求

//通過(guò)給定的ID來(lái)發(fā)送請(qǐng)求

axios.get('/user?ID=12345')

? .then(function(response){

??? console.log(response);

? })

? .catch(function(err){

??? console.log(err);

? });

//以上請(qǐng)求也可以通過(guò)這種方式來(lái)發(fā)送

axios.get('/user',{

? params:{

??? ID:12345

? }

})

.then(function(response){

? console.log(response);

})

.catch(function(err){

? console.log(err);

});

2琳拭、發(fā)送一個(gè)POST請(qǐng)求

axios.post('/user',{

? firstName:'Fred',

? lastName:'Flintstone'

})

.then(function(res){

? console.log(res);

})

.catch(function(err){

? console.log(err);

});


具體參考:http://www.reibang.com/p/df464b26ae58

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末载佳,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子臀栈,更是在濱河造成了極大的恐慌蔫慧,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件权薯,死亡現(xiàn)場(chǎng)離奇詭異姑躲,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)盟蚣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門黍析,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人屎开,你說(shuō)我怎么就攤上這事阐枣。” “怎么了奄抽?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵蔼两,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我逞度,道長(zhǎng)额划,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任档泽,我火速辦了婚禮俊戳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘馆匿。我一直安慰自己抑胎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布渐北。 她就那樣靜靜地躺著阿逃,像睡著了一般。 火紅的嫁衣襯著肌膚如雪腔稀。 梳的紋絲不亂的頭發(fā)上盆昙,一...
    開(kāi)封第一講書(shū)人閱讀 49,031評(píng)論 1 285
  • 那天羽历,我揣著相機(jī)與錄音焊虏,去河邊找鬼。 笑死秕磷,一個(gè)胖子當(dāng)著我的面吹牛诵闭,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼疏尿,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼瘟芝!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起褥琐,我...
    開(kāi)封第一講書(shū)人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤锌俱,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后敌呈,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體贸宏,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年磕洪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了吭练。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡析显,死狀恐怖鲫咽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情谷异,我是刑警寧澤分尸,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站歹嘹,受9級(jí)特大地震影響寓落,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜荞下,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一伶选、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧尖昏,春花似錦仰税、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至迹淌,卻和暖如春河绽,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背唉窃。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工耙饰, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人纹份。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓苟跪,卻偏偏與公主長(zhǎng)得像廷痘,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容