vue在跳转页面的同时传递参数

本文介绍了一种使用Vue.js框架实现页面间参数传递的方法。通过定义按钮点击事件触发页面跳转,并利用$router.push方法携带参数。接收页面通过this.$route.query获取传递过来的数据。

A页面

<template>
    <button @click="jump">点击跳转</button>
</template>
<script>
    export default {
        data() {
            return {
                parameter:"小狐疑真是个靓仔",//传的参数
            }
        }
        methods: {
        	jump:{
        		this.$router.push({
                  //跳转的路径
                  path: "/helpService/orderPay"//需要传递的参数
                  query: {
                    //取个别名,在跳转到的页面接收 -我觉得最好是和当前页面的变量名一样
                    parameter:JSON.stringify(this.parameter),
                  }
                })
    		}}
        
    }
</script>

B页面接收

<template>
    <!--这里渲染的是:小狐疑真是个靓仔-->
   {{parameter}}
</template>
<script>
     export default {
        data() {
            return {
                parameter:"",//接收参数
            }
        }
		//放在这里面每次页面加载时都会被加载到
       mounted: function() {
           //接收A页面传过来的参数 -this.$route.query.parameter:就是楼上取的别名
           this.parameter = JSON.parse(this.$route.query.parameter);
       }
        
    }
    
</script>
Vue 3中,跳转页面传递query参数可通过Vue Router来实现,以下是具体的实现方法: ### 安装与配置Vue Router 若尚未安装Vue Router,可使用以下命令进行安装: ```bash npm install vue-router@4 ``` 在项目中配置路由,示例代码如下: ```javascript // src/router/index.js import { createRouter, createWebHistory } from 'vue-router' import Home from '../views/Home.vue' import About from '../views/About.vue' const routes = [ { path: '/', name: 'Home', component: Home }, { path: '/about', name: 'About', component: About } ] const router = createRouter({ history: createWebHistory(import.meta.env.BASE_URL), routes }) export default router ``` 在`main.js`中引入并使用路由: ```javascript // src/main.js import { createApp } from 'vue' import App from './App.vue' import router from './router' const app = createApp(App) app.use(router) app.mount('#app') ``` ### 传递query参数的方法 #### 方法一:使用`router.push` 在组件中使用`router.push`方法传递query参数,示例代码如下: ```vue <template> <button @click="goToAbout">Go to About</button> </template> <script setup> import { useRouter } from 'vue-router' const router = useRouter() const goToAbout = () => { router.push({ name: 'About', query: { id: 1, name: 'example' } }) } </script> ``` 上述代码中,通过`router.push`方法,在路由跳转传递了`id`和`name`两个query参数。 #### 方法二:使用`router.replace` `router.replace`方法和`router.push`类似,区别在于`replace`不会向历史记录添加新条目,而是替换当前的历史记录。示例代码如下: ```vue <template> <button @click="replaceToAbout">Replace to About</button> </template> <script setup> import { useRouter } from 'vue-router' const router = useRouter() const replaceToAbout = () => { router.replace({ name: 'About', query: { id: 2, name: 'replace-example' } }) } </script> ``` ### 接收query参数 在目标组件中接收query参数,示例代码如下: ```vue <template> <div> <p>ID: {{ $route.query.id }}</p> <p>Name: {{ $route.query.name }}</p> </div> </template> <script setup> import { useRoute } from 'vue-router' const route = useRoute() </script> ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小狐狸崽子OvO

你的鼓励将是我创造最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值