• zxb的博客
    • 运维
      • 🧊即插即更:移动硬盘与 U 盘的自动同步方案
      • ⛳FRP穿透个人博客——SSL安全篇
      • 📄Github Action自动化部署Vue3项目
      • 🎲Docker Desktop 代理配置:让镜像拉取更稳更快
      • 🤓FRP穿透搭建个人博客(白嫖SSL版)
      • 🪁FRP穿透搭建个人博客
      • 📄Kubeeasy安装K8s集群(附独家报错解决)
    • 技术体验
      • 🛡️别再找插件了,美团出品的Tabbit才是真正的AI浏览器
      • 💧GitHub 霸榜!Tabbit平替:给浏览器装上“最强大脑”,这才是真·AI 浏览器插件
    • 自制软件插件
      • 🧋🧧 仪式感拉满!这款开源“年味”小游戏,带你瞬间找回童年快乐!
      • 🕸️摸鱼神器——摸了吗
      • 🔍🚀 思源笔记 S3 插件 v1.0.2 更新:手把手教你配置 PicList 导出
      • 🌊🚀 思源笔记 S3 插件 v1.0.3 更新:一键解锁 BM.md 精美排版!
      • 🥔AE机器人大模型案例
      • Claude Code 终于会"叫"了 —— 一个 10MB 小工具,让 AI 跑完任务发个声
    • 开发小技巧
      • 🪴【保姆级】NAS 骚操作:白嫖百 T 网盘做图床!阿里云/百度秒变“私有云相册”,快到飞起!
    • 后端技术
      • 🚁解决 Spring Session 分布式部署难题:Redis 集成指南
      • 📄使用ThreadLocal实现用户身份认证
      • SpringAI
        • 别再手写 HTTP 客户端调 AI 了!Spring AI 官方出手,一行代码搞定多模型切换
      • 📄使用注解+反射实现自动填充
      • Spring
        • 🔁循环依赖:一个Spring经典坑
        • Spring如何解决依赖循环
        • 🫛什么是Spring Bean
      • Java基础
        • 什么是序列化和反序列化?
        • 📄Java中HashMap的原理
      • 报错解决
        • 🕙SpringWeb报错——CORS问题解决
        • 📄一行 JVM 参数解决 HttpClient 卡死:强制 Java 禁用 IPv6
    • 📑前端技术
      • 🫚axios工具类
      • 🍛Vite项目屏幕适配的两种方案,超详细
      • 📕vue-router小技巧:通过route传参动态设置页面
zxb的博客前端技术

vue-router小技巧:通过route传参动态设置页面

访问次数 1217 次创建时间 2026-03-27 11:08

image

vue-router小技巧:通过route传参动态设置页面

场景介绍

问:当需要对多个不同值进行修改时,使用的是同一个或几乎相同的编辑页面时,如何节省开发时间? 答:使用 route 获取动态参数,并对页面进行设置。

部分代码展示


传参方:

<van-cell :value="user.gender" arrow-direction="down" is-link title="性别" to="/user/edit"  
          @click="edit('gender', '性别', user.gender)"/>

接收方:

<script setup>
import {ref} from 'vue'  
import { useRoute } from 'vue-router'  

// 获取路由参数  
const route = useRoute()  
const editUser = ref({  
  editKey: route.query.editKey,  
  editName: route.query.editName,  
  currentValue: route.query.currentValue  
})  
</script>

...
<van-field  
    v-model="editUser.currentValue"  
    :rules="[{ required: true, message: `请填写${editUser.editName}` }]"  
    :label="editUser.editName"  
    :name="editUser.editKey"  
    :placeholder="editUser.editName"  
/>

完整代码展示


传参:

<script lang="ts" setup>  
import {UserType} from "@/model/user";  
import router from "@/router";  

const user: UserType = {  
  id: 1,  
  username: 'zxb',  
  userAccount: 'zxb',  
  avatarUrl: 'https://picgo.cn-sy1.rains3.com/2025/03/c10098fa9fb610377f7fb02e2815ea58.png',  
  gender: 1,  
  phone: '12345678901',  
  email: '12345678901@qq.com',  
  status: 1,  
  createTime: new Date(),  
  updateTime: new Date(),  
  userRole: 0,  
  planetCode: '2021090101010101'  
};  

// 编辑  
const edit = (editKey: string, editName: string, currentValue: string) => {  
  router.push({  
    path: '/user/edit',  
    query: {  
      editKey,  
      editName,  
      currentValue  
    }  
  })  
}  
</script>  

<template>  
  <van-cell is-link title="用户名" to="/user/edit"/>  
  <van-cell :value="user.userAccount" is-link title="账号" to="/user/edit"/>  
  <van-cell arrow-direction="down" is-link title="头像" to="/user/edit">  
    <van-image :src="user.avatarUrl" alt=""/>  
  </van-cell>  
  <van-cell :value="user.gender" arrow-direction="down" is-link title="性别" to="/user/edit"  
            @click="edit('gender', '性别', user.gender)"/>  
  <van-cell :value="user.phone" arrow-direction="down" is-link title="手机号" to="/user/edit"  
            @click="edit('phone', '手机号', user.phone)"/>  
  <van-cell :value="user.email" arrow-direction="down" is-link title="邮箱" to="/user/edit"/>  
  <van-cell :value="user.planetCode" arrow-direction="down" is-link title="星球编号" to="/user/edit"/>  
  <van-cell :value="user.createTime.toISOString()" arrow-direction="down" is-link title="注册时间" to="/user/edit"/>  
</template>  

<style scoped>  

</style>

接收:

<script lang="ts" setup>  
import {ref} from 'vue'  
import { useRoute } from 'vue-router'  

// 获取路由参数  
const route = useRoute()  
const editUser = ref({  
  editKey: route.query.editKey,  
  editName: route.query.editName,  
  currentValue: route.query.currentValue  
})  

const onSubmit = (values) => {  
  console.log('submit', values);  
};  
</script>  

<template>  
  <van-form @submit="onSubmit">  
    <van-cell-group inset>  
      <van-field  
          v-model="editUser.currentValue"  
          :rules="[{ required: true, message: `请填写${editUser.editName}` }]"  
          :label="editUser.editName"  
          :name="editUser.editKey"  
          :placeholder="editUser.editName"  
      />  
    </van-cell-group>  
    <div style="margin: 16px;">  
      <van-button block native-type="submit" round type="primary">  
        确认修改  
      </van-button>  
    </div>  
  </van-form>  
</template>  

<style scoped>  

</style>

评论

0 条评论

暂无评论,欢迎第一个留言。

验证码
回复评论
验证码
举报内容
验证码
由 b8l8u8e8 提供支持