Vue 學習筆記 vue-router路由和前端狀態(tài)管理

Vue 學習筆記十一、vue-router路由和前端狀態(tài)管理

什么是路由:網(wǎng)址

11.1 vue--router路由基本加載

/Users/mac/Desktop/日記本1. 安裝

npm install --save vue-router
  1. 引用
//main.js
import router from 'vue-router'
Vue.use(router)
  1. 配置路由文件性誉,并在vue實例中注入
var rt = new router({
  routes:[{
    path:'/',//指定要跳轉(zhuǎn)的路徑
    component:HelloWorld//指定要跳轉(zhuǎn)的組件
  }]
})
new Vue({
  el: '#app',
  router:router,
  components: { App },
  template: '<App/>'
})
  1. 確定視圖加載的位置
<router-view></router-view>

11.2 vue--router路由的跳轉(zhuǎn)

使用

<router-link to="/"></router-link>

實現(xiàn)跳轉(zhuǎn)

<template>
  <ul>
    <li>
      <router-link to="/helloworld">HELLO WORLD</router-link>
    </li>
    <li>
      <router-link to="/helloearth">HELLO EARTH</router-link>
    </li>
  </ul>
</template>

11.3 vue--router路由參數(shù)的傳遞

  1. 必須在路由內(nèi)加入路由的name
  2. 必須在path后加/: +傳遞的參數(shù)
  3. 傳遞參數(shù)和接收參數(shù)看下邊代碼
<router-link
  :to="{name: helloearth,params:{msg: 只有一個地球}}">
  HELLO WORLD
</router-link>
讀取參數(shù): $route.params.XXX
方式:/helloworld/你好世界
<router-link
  :to="{path: '/helloearth',query:{msg: 只有一個地球}}">
  HELLO WORLD
</router-link>
方式:/helloworld?name=XX&count=xxx

函數(shù)模式
你可以創(chuàng)建一個函數(shù)返回 props窿吩。這樣你便可以將參數(shù)轉(zhuǎn)換成另一種類型,將靜態(tài)值與基于路由的值結(jié)合等等错览。

const router = new VueRouter({
  routes: [
    { path: '/search', component: SearchUser, props: (route) => ({
      query: route.query.q }) }
  ]
})

11.4.1 Axios之get請求詳解

axios的簡介:

axios 是一個基于Promise 用于瀏覽器和 nodejs 的 HTTP 客戶端纫雁,它本身具有以下特征:

從瀏覽器中創(chuàng)建 XMLHttpRequest
從 node.js 發(fā)出 http 請求
支持 Promise API
攔截請求和響應
轉(zhuǎn)換請求和響應數(shù)據(jù)
取消請求
自動轉(zhuǎn)換JSON數(shù)據(jù)
客戶端支持防止 CSRF/XSRF

安裝

npm install axios

引入加載到helloworld.vue

import axios from 'axios'

將axios全局掛載到VUE原型上

Vue.prototype.$http = axios;

發(fā)出請求 以cnode社區(qū)API為例子

// 為給定 ID 的 user 創(chuàng)建請求
//使用傳統(tǒng)的function
getData(){
  var self = this;
  this.$http.get('https://cnodejs.org/api/v1/topics')
  .then(function (res) {
//此處的this指向的不是當前vue實例
    self.items = res.data.data
    console.log(res.data.data)
  })
  .catch(function (err) {
    console.log(err)
  })
}
//es6
getData(){
  this.$http.get('https://cnodejs.org/api/v1/topics')
  .then(res=>{
    this.items = res.data.data
  })
  .catch(err=>{
    console.log(err)
  })
}

//兩種傳遞參數(shù)的形式

getData(){
  this.$http.get('https://cnodejs.org/api/v1/topics',{
    params:{
      page:1,
      limit:10
      }
    })
  .then(res=>{
    this.items = res.data.data
  })
  .catch(err=>{
    console.log(err)
  })
}
//或者
axios.get('https://cnodejs.org/api/v1/topics?page=1&limit=15')

使用CNODE社區(qū)官方的API為例展開學習
獲取主題列表API:https://cnodejs.org/api/v1/topics

參數(shù):page頁碼
limit 每頁顯示的數(shù)量

11.4.2 Axios之post請求詳解

// 為給定 ID 的 user 創(chuàng)建請求
使用傳統(tǒng)的function
getData(){
  var self = this;
  this.$http.post(url,{
    page:1,
    limit:10
  })
  .then(function (res) {
//此處的this指向的不是當前vue實例
    self.items = res.data.data
    console.log(res.data.data)
  })
  .catch(function (err) {
    console.log(err)
  })
}

POST傳遞數(shù)據(jù)有兩種格式:

form--data ?page=1&limit=48
x--www--form--urlencoded { page: 1,limit: 10 }

在axios中,post請求接收的參數(shù)必須是form-data所以我們必須處理post請求
使用qs插件轉(zhuǎn)換x--www--form--urlencoded 格式成form--data

npm install qs
import qs from 'qs'

qs插件—-qs.stringify

11.5 Vuex之store
用來管理狀態(tài)倾哺,共享數(shù)據(jù)轧邪,在各個組件之間管理外部狀態(tài)如何使用刽脖?

第一步:引入vuex,并通過use方法使用它

import Vuex from './vuex'
Vue.use(Vuex)

第二步: 創(chuàng)建狀態(tài)倉庫
第三步:通過this.$sore.state.XXX直接拿到需要的數(shù)據(jù)

//創(chuàng)建狀態(tài)倉庫忌愚,注意Store,state不能改

var store = new Vuex.Store({
  state:{
    XXX:xxx
  }
})

//直接通過this.$store.state.XXX拿到全局狀態(tài)

11.6 Vuex的相關操作

vuex狀態(tài)管理的流程

view———->actions———–>mutations—–>state————->view
除了能夠獲取狀態(tài)如何改變狀態(tài)呢曲管?

//創(chuàng)建狀態(tài)倉庫,注意Store,state不能改
var store = new Vuex.Store({
  state:{
    XXX:xxx
  },
  mutations:{
  }
})
this.$store.commit(XXX);
// 此處的XXX是你在mucations中定義的方法名
var store = new Vuex.Store({
  state:{
    XXX:xxx
  },
  mucations:{
    a:function(state){
    }
  },
  actions:{
    b:function(context){
      context.commit('a');
    }
  }
})
// 如何調(diào)用
this.$store.dispatch(XXX);
  getters:{
    getNum(state){
      return state.num > 0 ? state.num: 0;
    }
  }
  
this.$store.getters.getCount

注意:actions提交的是mutation,而不是直接變更狀態(tài)
actions可以包含異步操作菜循,但是mutation只能包含同步操作

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末翘地,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子癌幕,更是在濱河造成了極大的恐慌衙耕,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件勺远,死亡現(xiàn)場離奇詭異橙喘,居然都是意外死亡,警方通過查閱死者的電腦和手機胶逢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門厅瞎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人初坠,你說我怎么就攤上這事和簸。” “怎么了碟刺?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵锁保,是天一觀的道長。 經(jīng)常有香客問我半沽,道長爽柒,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任者填,我火速辦了婚禮浩村,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘占哟。我一直安慰自己心墅,他們只是感情好,可當我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布榨乎。 她就那樣靜靜地躺著嗓化,像睡著了一般。 火紅的嫁衣襯著肌膚如雪谬哀。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天严肪,我揣著相機與錄音史煎,去河邊找鬼谦屑。 笑死,一個胖子當著我的面吹牛篇梭,可吹牛的內(nèi)容都是我干的氢橙。 我是一名探鬼主播,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼恬偷,長吁一口氣:“原來是場噩夢啊……” “哼悍手!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起袍患,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤币绩,失蹤者是張志新(化名)和其女友劉穎形帮,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡挟秤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了香罐。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片牛欢。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖惹恃,靈堂內(nèi)的尸體忽然破棺而出夭谤,到底是詐尸還是另有隱情,我是刑警寧澤朗儒,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站曲秉,受9級特大地震影響采蚀,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜榆鼠,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望妆够。 院中可真熱鬧,春花似錦鸵荠、人聲如沸伤极。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽乍楚。三九已至,卻和暖如春届慈,著一層夾襖步出監(jiān)牢的瞬間徒溪,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工金顿, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留臊泌,地道東北人。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓串绩,卻偏偏與公主長得像缺虐,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子礁凡,可洞房花燭夜當晚...
    茶點故事閱讀 42,877評論 2 345

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

  • 11.1 vue-router路由基本加載 簡單四步走 安裝 引用 配置路由文件高氮,并在vue實例中注入 確定視圖加...
    諾CIUM閱讀 475評論 0 7
  • ## 框架和庫的區(qū)別?> 框架(framework):一套完整的軟件設計架構(gòu)和**解決方案**。> > 庫(lib...
    Rui_bdad閱讀 2,890評論 1 4
  • 11.1 vue--router路由基本加載 小案例:在根路徑下只顯示圖片顷牌,在/hello下即顯示圖片又顯示hel...
    sweetBoy_9126閱讀 719評論 0 0
  • 1剪芍、active-class是哪個組件的屬性?嵌套路由怎么定義窟蓝?答:vue-router模塊的router-lin...
    jane819閱讀 1,740評論 0 15
  • vue-cli搭建項目 確保安裝了node與npm 再目標文件夾下打開終端 執(zhí)行cnpm i vue-cli -g...
    Akiko_秋子閱讀 3,214評論 1 22