vue2路由传值-友好url传值

该文详细介绍了如何在Vue项目中使用vue-router进行动态路由配置,包括声明式导航、组件间的通信、动态参数传递以及利用keep-alive和transition实现组件状态保持和过渡动画。
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .router-link-active {
            color: red;
        }

        .v-enter,
        .v-leave-to {
            opacity: 0;
        }

        .v-enter-active,
        .v-leave-active {
            transition: 1s;
        }

        .v-enter-to,
        .v-leave {
            opacity: 1;
        }
    </style>
</head>

<body>
    <script src='https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js'></script>
    <!-- 第一步:在vue之后导入vue-router插件 -->
    <script src="./vue-router.js"></script>

    <div id="myApp">
        <!-- 第二步:在根组件模板中,添加路由跳转标签 -->
        <h1 style="text-align: center;">
            <!-- vue路由封装了组件标签 router-link ,用于替代a标签,属性to设置跳转的路径,不需要加#,渲染的时候会自动补上#-->
            <!-- 1.声明式导航跳转(标签跳转) 在根组件模板中,使用router-link组件标签实现路由跳转-->
            <router-link to="/main">主页</router-link>|
            <router-link to="/login">登录</router-link>|
            <router-link to="/user">个人</router-link>
        </h1>


        <!-- 第六步:在根组件模板合适的位置,添加路由出口(组件渲染的位置) -->


        <!-- 路由在跳转的时候,默认会销毁重建组件,所以组件数据状态会重置,如果不想组件状态重置可以在路由出口添加keep-alive组件 -->
        <!-- 如果路由切换的时候,还需要添加动画效果,再添加一层transition即可 -->
        <transition>
            <keep-alive>
                <router-view></router-view>
            </keep-alive>
        </transition>

    </div>
    <script>

        // 第三步:在全局作用域,创建路由跳转页面对应的组件
        var MainCom = Vue.component("mainCom", {
            template: "<h2>这是主页{{$route.params.name}}</h2>",
            // ------------------------------------------------------------
            // 使用$route.params.name接收
            // -----------------------------------------------------------

            created() {
                console.log("主页创建", this.$route.params.name);
            },
            activated() {
                console.log("主页显示", this.$route.params.name);
            },
        })

        // ------------------------------------------------------------
        // 二.直接打/ 就可以+拼接
        // -----------------------------------------------------------
        var LoginCom = Vue.component("loginCom", {
            template: `<h2>这是登录  <input type="text" v-model="msg">     
                    <router-link :to="'/main/'+msg">主页</router-link>
                </h2>`,
            data() {
                return {
                    msg: ""
                }
            },

        })

        var UserCom = Vue.component("userCom", { template: "<h2>这是个人页</h2>" })

        // 组件在创建之后,返回值是组件的构造函数
        console.log(MainCom);

        // 第四步:创建路由对象,配置路由信息
        const router = new VueRouter({
            // routes数组中配置路由信息对象,一个对象对应一个路由信息
            routes: [
                // path表示路由的地址,省略了#,component表示组件,值是组件的构造函数,而不是组件名


                // ______一.友好url 直接在路由信息拼接对象__________
                { path: "/main/:name", component: MainCom },
                // _____________________________________


                { path: "/login", component: LoginCom },
                { path: "/user", component: UserCom },
                // 默认打开页面,路由默认的路径是/,可以给默认/路径添加配置
                { path: "/", redirect: "/main" }
                // redirect表示路由重定向,当首次打开页面的时候,默认hash路径是/,此时路由重定向,hash路径修改为/main,达到默认访问/main的目的
            ]
        })



        new Vue({
            el: '#myApp',
            // 第五步:把路由信息对象加入vue根组件对象中
            // router:router
            router
        })


            // 总结: 路由传值 - 友好url(动态url)拼接传值
            // 1.在路由配置对象中,添加动态路由配置
            //   { path: "/main/:name", component: MainCom }
            // 2.在路由跳转前的组件内,给路由路径后添加/拼接数据传值
            // < router - link :to = "'/main/'+msg" > 主页</router - link >
            // 3.在路由跳转后的组件内,使用$route对象调用params字段接收数据
            // $route.params.name  this.$route.params.name
    </script>
</body>

</html>

Vue 3 中,路由有以下常见方法及示例: ### 通过 params 接收参数时,可使用 `useRoute` 来获取路由对象,进而取得 `params` 中的参数。示例代码如下: ```vue // 接收参数 import { useRoute } from 'vue-router'; const route = useRoute(); const id = route.params.id; // 123 ``` 在路由配置时需对路径进行定义以支持 `params` ,例如路由配置中路径为 `/detail/:id`,跳转时可这样使用: ```javascript this.$router.push({ name: 'detail', params: { id: 123 } }); ``` ### 通过 query 使用 `path` 匹配路由,通过 `query` 递参数,这种方式下 `query` 递的参数会显示在 URL 后面。示例如下: ```vue // 递参数 methods: { insurance(id) { this.$router.push({ path: '/particulars', query: { id: id } }); } } ``` 接收参数: ```vue import { useRoute } from "vue-router"; import { onMounted } from "vue"; export default { setup() { const $route = useRoute(); onMounted(() => { console.log($route.query); // 打印 query 的参数 }); } }; ``` ### 递复杂对象 当需要递复杂对象时,可先将对象转换为 JSON 字符串并进行编码,接收时再进行解码和解析。示例如下: ```vue // 递页面 <script lang="ts"> import { defineComponent, onMounted, reactive, ref, watch } from 'vue' import { IGetItem, IGetList } from '@/type/types' import { useRouter } from 'vue-router' export default defineComponent({ components: { FormItemView }, setup() { const router = useRouter() const jumpToDetail = (item1: IGetItem) => { router.push({ path: '/formdetail', query: { item: encodeURIComponent(JSON.stringify(item1)) } }) } return { jumpToDetail } } }) </script> ``` 接收时: ```vue import { useRoute } from 'vue-router'; const route = useRoute(); const item = JSON.parse(decodeURIComponent(route.query.item)); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值