Vue路由query 和 params 传参的区别

简介: Vue路由query 和 params 传参的区别

通过 url 传递参数控制页面显示数据的两种方式


1. query 传统问号传参

url 格式:xxx.com/product?id=123

模板内获取数据:this.$route.query.id

2. params 动态路由匹配

url 格式:xxx.com/product/123

模板内获取数据:this.$route.params.id

注意这个方式参数字段名 id 要在路由配置中定义 用冒号的形式标记

参数可以继续拼接 /student/:id/:name/:age/:address

他必须严格按照 url 的配置格式访问

3. 如何选择哪一个传参方式

两个并没有高低之分


动态路由, 优点 ,好看整齐 缺点 必须预先定义, 如果参数多起来多起来不好管控

问号的形式 灵活随意想改就改, 想加就加, 缺点就是太丑陋了, 也不直观

params:/router1/:id ,    //router1/123,/router1/789 ,这里的id叫做params
query:/router1?id=123 ,  //router1?id=456 ,这里的id叫做query。

query 传参配置的是path,而params传参配置的是name,在params中配置path无效


query在路由配置不需要设置参数,而params必须设置


query传递的参数会显示在地址栏中


params传参刷新会无效,但是query会保存传递过来的值,刷新不变 ;


接收参数使用this.$router后面就是搭配路由的名称就能获取到参数的值

//query:
  {
  path: '/home',
  name: Home,
  component: Home
  }
 // params:
  {
  path: '/home/:id',
  name: Home,
  component: Home
  }

接口封装

import axios from 'axios'
import qs from 'qs'
import Vue from 'vue'
import store from '@/store'
// 创建一个 axios 实例
const service = axios.create({
  withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000 // request timeout
})
// 请求拦截
service.interceptors.request.use(
  config => {
    // do something before request is sent
    if (config.isLoading) loadingInstance = Vue.prototype.$baseLoading()
    if (process.env.NODE_ENV === 'development') {
      config.headers['debugMode'] = 'true'
    }
    return config
  },
  error => {
    return Promise.reject(error)
  }
)
// 响应拦截
service.interceptors.response.use(
  response => {
    const res = response.data
    if (res.intRes === 1) { // 登录请求退出
      if (store.getters.empId) { // 如果登录过,提示会话失效
        Vue.prototype.$baseConfirm('会话已失效请重新登录', '会话失效', () => {
          window.location.href = process.env.VUE_APP_BASE_SSO_URL + window.location.href
        })
      }
      return res
    }
    if (res.intRes !== 0) {
      const msg = isEmpty(res.objRes) ? res.msgRes : res.objRes
      Vue.prototype.$baseMessage(msg, 'warning')
      return Promise.reject(res)
    } else {
      return res
    }
  },
  error => {
    return Promise.reject(error.response)
  }
)
//  get 和 post 请求封装
export default {
  get(url,params){
     return service.get(url,{params:params})
   },
   postJson(url,data){
     return service.post(url,data,
     {
       headers:{'ContentType':'application/json'}
     })
   },
   postForm(url, data, isLoading = true) {
    return service.post(url, qs.stringify(data), {
      isLoading: isLoading,
      headers: { 'Content-Type': 'application/x-www-form-urlencoded' }
    })
  },
   }

image.png

相关文章
|
4天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
41 1
|
15天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript API 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何劫持响应式对象的
Vue是如何劫持响应式对象的
33 1
|
2月前
|
JavaScript 前端开发 API
介绍一下Vue中的响应式原理
介绍一下Vue中的响应式原理
35 1
|
2月前
|
JavaScript 前端开发 开发者
Vue是如何进行组件化的
Vue是如何进行组件化的
|
2月前
|
存储 JavaScript 前端开发
介绍一下Vue的核心功能
介绍一下Vue的核心功能
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
46 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
32 1
|
2月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
39 1
vue学习第四章

热门文章

最新文章