Vue路由传递参数

Vue路由传递参数

路由界面介绍

​ 这里是页面进行路由的配置,并且这里的名字最好大驼峰的方式进行抒写

php 复制代码
// 调用user方法,将VueRouter作为一个vue组件来使用
Vue.use(VueRouter);

​ 下面的const router 是用来声明不同页面对应的不同的访问的路径

路由的配置

​ 在创建路由的对象中,我们添加路由的模式, 这里我们选择添加hash默认的格式,这样通过npm run serve启动项目的时候,就会自动打开网页了

js 复制代码
const router = new VueRouter({
  routes,
  // 路由的两种模式  history 历史模式
  // hash:哈希模式 路径上带# 默认是此模式
  mode: "hash",
});

路由的两种模式

第一种是声明式路由

​ 它默认会被渲染成一个带有链接的a标签,通过to属性指定链接地址。

  • to:导航路径,要填写的是你在router/index.js文件里配置的path值,如果要导航到默认首页,只需要写成 to="/" ,
  • text :就是我们要显示给用户的导航名称。
ini 复制代码
<router-link to="/">[text]</router-link>
// 例子
<router-link to="/aa">界面内的a界面</router-link>

// router index.js文件
const routes = [
  {
    path: "/aa",
    name: "aa",
    component: AaView,
  },
]

​ 用于渲染界面所用的,例如我们在app的界面中引入的 默认界面,然后我们通过,将当前默认界面放入到router-view里面,就不用重复的去写页面了,这样就比较方便

sql 复制代码
<router-view ></router-view>

第二种是编程式路由

​ 这种就是我们在里面添加一个方法,让这个按钮点击这个方法的时候进行跳转

scss 复制代码
<button @click="go">跳转Aaview界面</button>

// methods

   methods: {
        go() {
            this.$router.push("/aa")
            // 使用replace做页面跳转时,此页面不会加入到历史页面中,因此无法后退
            // this.$router.replace('/aa')
        }
   }

路由传递参数

定义数据

​ 这里面的数据我们就随便定义了,

yaml 复制代码
 data() {
        return {
            users: [
                {
                    id: 1,
                    name: "admin",
                    age: 18
                }, {
                    id: 2,
                    name: 'root',
                    age: 20
                }
            ]
        }
    },

渲染数据

​ 这里渲染数据就用v-for的方式进行渲染,当我们点更新这个按钮的时候跳转这个链接,进行参数的传递,注意第二种传递方式很不常用,因为刷新浏览器后,参数就会丢失,所以说没有什么用

javascript 复制代码
<table>
            <tr v-for="(item, index) in users " :key="index">
                <td>{{ item.name }}</td>
                <td>{{ item.age }}</td>
                <td><button @click="update(item.id)">更新</button></td>
            </tr>
        </table>
        // methods方法中
               update(id) {
            // 跳转页面,将id值传到另外一个页面中 这种方式参数刷新浏览器不会丢失
            this.$router.push({
                //传参方式一: 动态路由传递参数  动态传递参数
                path: `/param/${id}`
                // -------------
                //传参方式二:  通过路由名称跳转界面 刷新参数就丢失 名称传参数
                // 方式二基本不用 ,没有用
                // name: 'param',
                // params: {
                //     id
                // }

                //-----------
                // 传参方式三:路径跳转,query传参
                // path: '/param',
                // query: { id }
            })
        }

​ 这里主要说下第一种与第三种方式,两种方式刷新浏览器都会

第一种方式

​ 根据router定义的路由,然后跳转到param这个界面

​ 注意方式一和方式二的接收参数方式相同,但是方式三接收参数的方式是通过query

bash 复制代码
path: `/param/${id}`

param界面接收传值过来的id

bash 复制代码
  路由参数:{{$route.params.id }}
第三种方式

​ 这里通过query将值到param界面,注意这里是将传递的值写在路径上面的

makefile 复制代码
//传参方式三:路径跳转,query传参
path: '/param',
query: { id }

param界面接收传值过来的id

bash 复制代码
 路由参数:{{$route.query.id }}
相关推荐
木斯佳5 分钟前
前端八股文面经大全:美团前端暑期实习一面(2026-06-08)·面经深度解析
前端
Uso_Magic13 分钟前
VOL_实现APP多文件上传_前端多文件显示!
前端
问心无愧051319 分钟前
ctf sow web入门112
android·前端·笔记
库拉大叔27 分钟前
工具调用效率对比实测:GPT-5.5与Gemini 3.5 Flash性能评估
java·前端·人工智能
艾伦野鸽ggg31 分钟前
CSS容器查询和悬浮间隙问题
前端·css
云水一下1 小时前
Vue.js从零到精通系列(一):初识Vue——背景、环境与第一个应用
前端·javascript·vue.js
云水一下1 小时前
Vue.js从零到精通系列(二):响应式核心——ref、reactive、computed与watch
前端·javascript·vue.js
放下华子我只抽RuiKe51 小时前
FastAPI 全栈后端(二):路由与数据模型
前端·人工智能·react.js·前端框架·html·fastapi
lichenyang4531 小时前
ArkTS 严格类型系统:我答错 2 道题后才真正搞懂的几条规则
前端
小小小小宇1 小时前
定高、不定高、瀑布流虚拟列表
前端