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

vue-router

Vue Router 是 Vue.js 官方的 路由管理器
前端 来控制页面的跳转(但其实是个单页面),根据不同的 url 地址展示不同的内容和页面。

  • 优点:体验好,不需要每次从服务器获取全部,快速展现给用户;
  • 缺点:不利于SEO;使用浏览器的前进,后退键的时候会重新发送请求,没有合理的利用缓存;单页面无法记住之前滚动的位置,无法在前进和后退的时候记住滚动的位置。

路由的基本加载

简单四步走

  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:router,
  components: { App },
  template: '<App/>'
})
  1. 确定视图加载的位置
<router-view></router-view>

路由的跳转

<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>

路由参数的传递

使用 params

···/helloworld/你好世界
路由:

  1. 必须在路由内加入路由的 name
  2. 必须在 path 后加 /: +传递的参数
export default new router({
  routes: [{
    name: 'helloworld',
    path: '/helloworld/:worldmsg', // 指定要跳转的路径
    component: HelloWorld // 指定要跳转的组件
  }, {
    name: 'helloearth',
    path: '/helloearth/:earthmsg',
    component: HelloEarth
  }]
})

传递参数:

<router-link :to="{name: helloearth,params:{msg: 只有一个地球}}">
  HELLO WORLD
</router-link>

接收参数:

$route.params.earthmsg
使用 query

···/helloworld?name=xxx&count=yyy
路由:
你可以创建一个函数返回 props。这样你便可以将参数转换成另一种类型,将静态值与基于路由的值结合等等。

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

传递参数:

<router-link :to="{path: '/helloearth',query:{msg: 只有一个地球}}">
  HELLO WORLD
</router-link>

接收参数:

{{msg}}

Axios

axios的简介

axios 是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端,它本身具有以下特征:

  • 从浏览器中创建 XMLHttpRequest
  • 从 node.js 发出 http 请求
  • 支持 Promise API
  • 拦截请求和响应
  • 转换请求和响应数据
  • 取消请求
  • 自动转换JSON数据
  • 客户端支持防止 CSRF/XSRF
  1. 安装
npm install axios
  1. 引入加载
import axios from 'axios'
  1. 将 axios 全局挂载到 VUE 原型上
Vue.prototype.$http = axios

get 请求

getData(){
  this.$http.get('https://cnodejs.org/api/v1/topics', {
    params: {
      page: 1,
      limit: 10
    }
  })
    .then(response => {
      this.items = response.data.data
    })
    .catch(error => {
      console.log(error)
    })
}

两种传递参数的形式:

axios.get('https://cnodejs.org/api/v1/topics', {
    params: {
      page: 1,
      limit: 10
    }
  })
axios.get('https://cnodejs.org/api/v1/topics?page=1&limit=10')

post 请求

POST 传递数据有两种格式:

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

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

postData(){
  this.$http.post(url, qs.stringify({
    page: 1,
    limit: 10
  }))
    .then(response => {
      this.items = response.data.data
    })
    .catch(error => {
      console.log(error)
    })
}

Vuex

store

用来管理状态,共享数据,在各个组件之间管理外部状态。
如何使用 Vuex 获取状态?
第一步:引入 vuex,并通过 use 方法使用它。

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

第二步:创建状态仓库。

var store = new Vuex.Store({
  state: {
    XXX: xxx
  }
})
new Vue({
  el: '#app',
  router,
  store,
  components: { App },
  template: '<App/>'
})

第三步:通过 this.$store.state.XXX 直接拿到需要的数据(获取状态)。

Vuex 的相关操作

如何改变状态?

mutations

var store = new Vuex.Store({
  state: {
    num: 88
  },
  mutations: {
    // 定义状态改变函数
    increase(state){
      state.num++
    },
    decrease(state){
      state.num--
    }
  }
})

通过 this.$store.commit('increase') 调用状态改变函数。

actions

var store = new Vuex.Store({
  state: {
    num: 88
  },
  mutations: {
    // 定义状态改变函数
    increase(state){
      state.num++
    },
    decrease(state){
      state.num--
    }
  },
  actions: {
    // context 为上下文对象
    increaseAction(context){
      // actions 中只能对 mutation 进行操作,不直接变更状态
      context.commit('increase')
    }
  }
})

通过 this.$store.dispatch('increaseAction') 调用。
actions 可以包含异步操作,但是 mutations 只能包含同步操作。

getters

var store = new Vuex.Store({
  state: {
    num: 88
  },
  ···
  getters: {
    getNum(state){
      return state.num > 0 ? state.num : 0
    }
  }
})

通过 this.$store.getters.getNum 拿到处理后的数据。

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

推荐阅读更多精彩内容