IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue之路由01(数据传递、基本案例) -> 正文阅读

[JavaScript知识库]Vue之路由01(数据传递、基本案例)

什么是路由?

  • 请求分发组件
  • 编程请求定向
  • 请求URL资源Resource映射

先通过一个小案例看看路由到底有什么用?

?

通过上面可以看到路由就像是一个<a>标签链接一样

代码

<div id="app">
        <!-- 使用 router-link 组件来导航. -->
        <!-- router-link 组件是vue的内置组件,使用前需保证导入了vue-router.js包. -->
        <!-- <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script> -->
        <!-- 通过传入 `to` 属性指定链接. -->
        <!-- <router-link> 默认会被渲染成一个 `<a>` 标签,点击后将跳转到指定链接 -->
        <router-link to="/home">主页</router-link>
        <router-link to="/game">游戏</router-link>

        <!-- 路由出口 -->
        <!-- 路由匹配到的组件(也就是跳转的链接)将渲染在这里 -->
        <router-view></router-view>
</div>
<script>
    //第一步:定义路由组件
    const home = {template : `<div><h2>这是主页</h2></div>`}
    const game= {template : `<div><h2>游戏页面</h2></div>`}


    //第二步:创建router实例
    const routers = new VueRouter({
        //路由配置,使用routes属性
        //每个路由映射一个组件
        routes : [
            //path:自命名一个路径   component: 绑定对应的组件
            {path : '/home', component: home},
            {path : '/game', component: game}
        ]
    })

    //第三步:注册vue实例
    new Vue({
        //调用router属性,路由实例传入
        router:routers
    }).$mount('#app')
</script>

传递数据

第一种方式:

第一步: 参数的传递

<!-- 第一种:传递固定参数,直接在链接路径后面加上参数 -->
<router-link to="/game/王者荣耀/英雄联盟">游戏</router-link>

第二步:路由实例的配置

/* 用" /: "加上接收参数的形参名 */
{path : '/game/:name/:name2', component: game}

第三步:调用接收到的数据

/* 使用$route.params.形参名 */
const game= {template : `<div><h2>游戏页面{{$route.params.name+$route.params.name2}}</h2></div>`}

最终结果:?

第二种方式:

第一步: 参数的传递?

<!-- 第二种:传递可变参数 -->
<!-- to前面加上' : ' -->
<!-- 链接路径变成name的值 -->
<!-- params:{ 传递的参数 } -->
<router-link :to="{name:'home',params : {name:userName,Id:id}}">主页</router-link>

?第二步:路由实例的配置

/* 加上name属性 */
/* path:中可加可不加占位形参(/:name/:Id) */
/* 加了的话,在浏览器地址栏会显示传递的数据,否则不会显示 */
{path : '/:name/:Id',name :"home", component: home}

第三步:调用接收到的数据?

/* 没有变化 */
const home = {template : `<div><h2>这是主页{{$route.params.name+$route.params.Id}}</h2></div>`}

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-01 20:30:57  更:2022-02-01 20:32:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 15:19:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码