vue学习十三(VueRouter起步、动态路由参数匹配、获取、监测变化(测试无效))

本文主要是介绍vue学习十三(VueRouter起步、动态路由参数匹配、获取、监测变化(测试无效)),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

      • 起步
      • 动态路由参数匹配
      • 动态路由参数获取
      • 响应路由参数的变化(测试失败)

起步

路由,其实就是指向的意思,当我点击页面上的home按钮时,页面中就要显示home的内容,如果点击页面上的about 按钮,页面中就要显示about 的内容。Home按钮 => home 内容, about按钮 => about 内容,也可以说是一种映射. 所以在页面上有两个部分,一个是点击部分,一个是点击之后,显示内容的部分。

路由中有三个基本的概念 route, routes, router。

1, route,它是一条路由,由这个英文单词也可以看出来,它是单数, Home按钮 => home内容, 这是一条route, about按钮 => about 内容, 这是另一条路由。

2, routes 是一组路由,把上面的每一条路由组合起来,形成一个数组。[{home 按钮 =>home内容 }, { about按钮 => about 内容}]

3, router 是一个机制,相当于一个管理者,它来管理路由。因为routes 只是定义了一组路由,它放在哪里是静止的,当真正来了请求,怎么办? 就是当用户点击home 按钮的时候,怎么办?这时router 就起作用了,它到routes 中去查找,去找到对应的 home 内容,所以页面中就显示了 home 内容。

路由的步骤:

  1. 定义 (路由) 组件。
  2. 定义路由
  3. 创建 router 实例,然后传 routes 配置
  4. 创建和挂载根实例。
<body><div id="box"><router-link to="/one">One</router-link><router-link to="/two">Two</router-link><router-view></router-view></div><script>//1、定义 (路由) 模版组件const Foo = { template: '<div>第一个router</div>' }const Bar = { template: '<div>第二个router</div>' }//2、定义路由var routes = [{path: "/one",component: Foo},{path: "/two",component: Bar},];// 3、创建 router 实例var router = new VueRouter({routes});// 4、创建和挂载根实例const app = new Vue({router}).$mount('#box')</script>

效果如下:
在这里插入图片描述

当然我们也可以将路由模板,放在html块,如下

<body><div id="box"><router-link to="/one">One</router-link><router-link to="/two">Two</router-link><router-view></router-view></div><!--定义模版--><template id="Foo"><div>第一个router</div></template><template id="Bar"><div>第二个router</div></template><script>//1、定义 (路由) 模版组件//2、定义路由var routes = [{path: "/one",component: { template: "#Foo" }},{path: "/two",component: { template: "#Bar" }},];// 3、创建 router 实例var router = new VueRouter({routes});// 4、创建和挂载根实例const app = new Vue({router}).$mount('#box')</script>
</body>

动态路由参数匹配

我们经常需要把某种模式匹配到的所有路由,全都映射到同个组件。例如,我们有一个 User 组件,对于所有 ID 各不相同的用户,都要使用这个组件来渲染。那么,我们可以在 vue-router 的路由路径中使用“动态路径参数”(dynamic segment) 来达到这个效果
上面的例子我们,可以修改如下地方代码,其他的无需修改:

 <div id="box"><router-link to="/one/1">One</router-link><router-link to="/two/2">Two</router-link><router-view></router-view></div>
 var routes = [{path: "/one/:id",component: { template: "#Foo" }},{path: "/two/:id",component: { template: "#Bar" }},];

测试效果如下:
file:///Users/zhiliao/zhiliao/vue/index_test.html#/one/1

One Two
第一个router

file:///Users/zhiliao/zhiliao/vue/index_test.html#/two/2

One Two
第二个router

动态路由参数获取

一个“路径参数”使用冒号 : 标记。当匹配到一个路由时,参数值会被设置到 this.$route.params,可以在每个组件内使用。于是,我们可以更新 User 的模板,输出当前用户的 ID

我们在原来的例子基础上修改如下部分,其他的无需变动

<template id="Foo"><div>第一个router{{$route.params.id}}</div></template><template id="Bar"><div>第二个router{{$route.params.id}}</div></template>

测试效果如下:
file:///Users/zhiliao/zhiliao/vue/index_test.html#/two/2

One Two
第二个router 2

file:///Users/zhiliao/zhiliao/vue/index_test.html#/one/1

One Two
第一个router 1

响应路由参数的变化(测试失败)

提醒一下,当使用路由参数时,例如从 /user/foo 导航到 /user/bar,原来的组件实例会被复用。因为两个路由都渲染同个组件,比起销毁再创建,复用则显得更加高效。不过,这也意味着组件的生命周期钩子不会再被调用。

复用组件时,想对路由参数的变化作出响应的话,你可以简单地 watch (监测变化) $route 对象:

const User = {template: '...',watch: {'$route' (to, from) {// 对路由变化作出响应...}}
}

或者

const User = {template: '...',beforeRouteUpdate (to, from, next) {// react to route changes...// don't forget to call next()}
}

不过我测试是失败的,没有得到响应,以下是我的代码:

<body><div id="box"><router-link to="/one">One</router-link><router-link to="/two">Two</router-link><router-view></router-view></div><script>//1、定义 (路由) 模版组件const Foo = {template: '<div>第一个router</div>',watch: {$route (to, from) {// 对路由变化作出响应...console.info("sfsfs")}}}const Bar = {template: '<div>第二个router</div>',watch: {$route (to, from) {// 对路由变化作出响应...console.info("werwer")}}}//2、定义路由var routes = [{path: "/one",component: Foo},{path: "/two",component: Bar},];// 3、创建 router 实例var router = new VueRouter({routes});// 4、创建和挂载根实例const app = new Vue({router}).$mount('#box')</script></body>

这篇关于vue学习十三(VueRouter起步、动态路由参数匹配、获取、监测变化(测试无效))的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125125

相关文章

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

使用Python实现获取网页指定内容

《使用Python实现获取网页指定内容》在当今互联网时代,网页数据抓取是一项非常重要的技能,本文将带你从零开始学习如何使用Python获取网页中的指定内容,希望对大家有所帮助... 目录引言1. 网页抓取的基本概念2. python中的网页抓取库3. 安装必要的库4. 发送HTTP请求并获取网页内容5. 解

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

一文带你了解SpringBoot中启动参数的各种用法

《一文带你了解SpringBoot中启动参数的各种用法》在使用SpringBoot开发应用时,我们通常需要根据不同的环境或特定需求调整启动参数,那么,SpringBoot提供了哪些方式来配置这些启动参... 目录一、启动参数的常见传递方式二、通过命令行参数传递启动参数三、使用 application.pro

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

基于@RequestParam注解之Spring MVC参数绑定的利器

《基于@RequestParam注解之SpringMVC参数绑定的利器》:本文主要介绍基于@RequestParam注解之SpringMVC参数绑定的利器,具有很好的参考价值,希望对大家有所帮助... 目录@RequestParam注解:Spring MVC参数绑定的利器什么是@RequestParam?@

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处

Python实现html转png的完美方案介绍

《Python实现html转png的完美方案介绍》这篇文章主要为大家详细介绍了如何使用Python实现html转png功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 1.增强稳定性与错误处理建议使用三层异常捕获结构:try: with sync_playwright(