vue-router 路由和前端状态管理

一、vue-router 路由基本加载

路由,通俗地来讲就是输入不同的网址,加载不同的组件。

  1. 进入项目目录
cd my-project
  1. 安装
npm install -save vue-router
  1. 在文件中引用
import router from 'vue-router'
Vue.use(router)
  1. 配置路由文件,并在 vue 实例中注入
var rt = new router({
  routes: [{
    path: '/', // 指定要跳转的路径
    component: HelloWorld // 指定要跳转的组件
  }]
})
new Vue({
  el: '#app',
  router: rt,
  components: { App },
  template: '<App/>'
})
  1. 确定视图加载的位置
<router-view></router-view>

二、vue-router 路由的跳转

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

例:

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

三、vue-router 路由参数的传递

  • 必须在路由中加入路由的 name 属性
  • 必须在 path 后加 /: + 传递的参数
  • 传递参数和接收参数见下方代码
1. 配置路由
export default new router({ // 导出路由
    routes: [{
        name: 'helloworld',
        path: '/helloworld/:worldmsg', // 指定要跳转的路径
        component: HelloWorld // 指定要跳转的组件
    }, {
        name: 'helloearth',
        path: '/helloearth/:earthmsg',
        component: HelloEarth
    }]
})
2. 传递和读取参数(两种方法)
  1. 方法一
  • 传递参数:
<router-link :to="{name:'helloworld', params:{worldmsg:'你好世界'}}">
    HELLO WORLD
</router-link>
<router-link :to="{name:'helloearth', params:{earthmsg:'你好地球'}}">
    HELLO EARTH
</router-link>
  • 读取(接收)参数:$route.params.xxx
    要往哪个组件跳转,就由哪个组件来接收。
我是传递过来的参数:<h3>{{$route.params.worldmsg}}</h3> 
  1. 方法二(不常用)
  • 传递参数:
<router-link :to="{path:'/helloearth', query:{worldmsg:'你好世界'}}">
    HELLO WORLD
</router-link>
  • 读取(接收)参数:函数模式
    可以创建一个函数返回 props,这样便可以将参数转换成另一种类型,将静态值与基于路由的值结合等。
const router = new VueRouter({
  routes: [{
    path: '/search',component: SearchUser, props: (route) => ({
        query: route.query.q })
  }]
})
  1. 两种传递方式的区别
  • params 传递方式:http://localhost:8080/helloworld/你好世界
  • query 传递方式:http://localhost:8080/helloworld?name=xx&count=xxx

四、Axios 详解

1. Axios 简介

axios 是一个基于 Promise 用于浏览器和 node.js 的 HTTP 客户端,它的功能与 ajax 相似,其本身具有以下特征:

  • 在浏览器中创建 XMLHttpRequest
  • 从 node.js 发出 http 请求
  • 支持 Promise API
  • 拦截请求和响应
  • 转换请求和响应数据
  • 取消请求
  • 自动转换 JSON 数据
  • 客户端支持防止 CSRF/XSRF

2. Axios 之 get 请求详解

  1. 安装
npm install axios
  1. 在文件中引入加载
import axios from 'axios'
  1. 将 axios 全局挂载到 VUE 原型上
Vue.prototype.$http = axios // $ 后面的内容自定义
  1. 发送请求
  • 以 CNode 社区官方 API 为例:
getData(){
  this.$http.get('https://cnodejs.org/api/v1/topics')
    .then((res) => {
      this.items = res.data.data
      console.log(res)
    })
    .catch(function(err){
      console.log(err)
    })
}
  • GET 请求的两种参数传递形式:
axios.get('https://cnodejs.org/api/v1/topics', {
  params: {      // 只有一个参数时可省略params直接写参数
    page: 1,
    limit: 10
   }
})

axios.get('https://cnodejs.org/api/v1/topics?page=1&limit=15')

3. Axios 之 post 请求详解

POST 请求和 GET 类似,将请求中的 get 替换成 post 即可。

  • POST 请求传递数据的两种格式:
form-data?page=1&limit=48

x-www-form-urlencoded {
  page: 1,
  limit: 10
}

注意:在 axios 中,post 请求接收的参数必须是 form-data 格式
需要使用 qs 插件的 -qs.stringify 方法。

  • 使用步骤:
    安装 qs 插件:npm install qs
    在文件中引入:import qs from 'qs'
    在 post 请求中使用:qs.stringify({ page: 1, limit: 10 })
  • 以 CNode 社区官方 API 为例:
postData(){
  this.$http.get(url, qs.stringify({
      page: 1,
      limit: 10
  })).then((res) => {
      this.items = res.data.data
      console.log(res)
    })
    .catch(function(err){
      console.log(err)
    })
}

五、Vuex 之 store

Vuex 是用来管理状态,共享数据,在各个组件之间管理外部状态的一个插件。例如用户的已登录状态,需要在各个组件之前进行交互。Vuex 首先会创建一个状态仓库,并将所有组件囊括其中,即这个仓库下的所有组件都可以共享仓库里的状态。

  • 使用步骤:
    1. 安装 vuex:npm install vuex
    2. 在 main.js 文件中引入并通过 use 方法使用 vuex:
    import Vuex from 'vuex'Vue.use(Vuex)
    3. 创建状态仓库
    4. 将 store 注入到 Vue 实例
    5. 通过 this.$store.state.xxx 拿到需要的数据
// 创建状态仓库(此处名称store可自定义)
var store = new Vuex.Store({
  state:{
    xxx:yyy
  }
})

六、Vuex 的相关操作

1. 改变状态

除了能够获取状态,那么如何改变状态呢?
我们用 state 存放定义的状态,用 mutations 来改变状态。

  • mutations 用法
// 创建状态仓库
var store = new Vuex.Store({
  state: {
    num: 88
  },
  mutations: {
    // 定义状态改变函数
    zzz: function(state){
      state.num++
    }
  }
})

// 调用方式
this.$store.commit('zzz') // zzz 是在 mucations 中定义的方法名
  • actions 用法:
var store = new Vuex.Store({
  state: {
    num: 88
  },
  mutations: {
    zzz: function(state){
      state.num++
    }
  },
  actions:{
    // actions 中只能对 mutation 进行操作
    ccc: function(context){ // context是上下文对象
      context.commit('zzz')
    }
   }
})

// 调用方式
this.$store.dispatch('ccc')

注意
actions 提交的是 mutation,而不是直接变更状态。
actions 可以包含异步操作,但是 mutation 只能包含同步操作。

  • getters 用法:
var store = new Vuex.Store({
  state: {
    num: 88
  },
  mutations: {
    zzz: function(state){
      state.num++
    }
  },
  getters: {
    getNum: function(state){
      return state.num>0 ? state.num : 0
    }
  }
})

// 调用方式
this.$store.getters.getNum

2. vuex 状态管理流程

vuex 状态管理流程为:

view ——> actions ——> mutations ——> state ——> view

  • 从视图出发,先是 actions,然后是 mutations,然后通过 mutations 来操作 state,最后再回到 view。
  • 直接对状态进行操作的是 mutations,不是 actions。
  • 在这个过程中,actions 不是必须存在的,但如果有异步操作,则必须包含 actions。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,716评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,558评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,431评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,127评论 0 209
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,511评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,692评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,915评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,664评论 0 202
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,412评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,616评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,105评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,424评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,098评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,096评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,869评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,748评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,641评论 2 271

推荐阅读更多精彩内容