广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >vue路由怎么创建
  • 964
分享到

vue路由怎么创建

2024-04-02 19:04:59 964人浏览 薄情痞子
摘要

这篇“Vue路由怎么创建”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue路由怎么创建”

这篇“Vue路由怎么创建”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue路由怎么创建”文章吧。

一、概念

路由用于设定访问路径,并将路径和组件映射起来

一般用Vue做的都是单页应用,只有一个主页面index.html,所以你写的<a></a>标签是不起作用的,要使用vue-router来进行管理。

二、使用步骤

第一步:安装 

npm install vue-router

第二步:在src文件目录下新建一个router文件夹,src/router/index.js,此处就是编写路由组件的地方,这个文件就是路由的核心文件

//该文件专门用于创建整个应用的路由器

import VueRouter from "vue-router"

//引入组件

import About from '../pages/About'

import Home from '../pages/Home'

//创建并暴露一个路由器

const router = new VueRouter({

    routes: [

        {

            path: '/about',

            component:About

        },

        {

            path: '/home',

            component:Home

        }

    ]

})

export default router

第三步:在入口函数里引入相关路由

import Vue from "vue";

import App from './App.vue'

//引入VueRouter

import VueRouter from 'vue-router'

//引入路由器

import router from './router/index'

Vue.config.productionTip = false

//应用插件

Vue.use(VueRouter)

//创建vue

new Vue({

    el: '#app',

    render: h => h(App),

    router:router

})

第四步:新建两个路由组件 ,一般存放在pages文件夹里面

第五部:配置App组件

vue中借助router-link标签实现路由的切换    

<router-link class="list-group-item" active-class="active" to="/about">About</router-link> 

active-class:表示当前活跃的路由高亮显示

<router-view></router-view>:指定组件的内容呈现位置 

<template>

  <div>

    <div class="row"> 

      <div class="col-xs-2 col-xs-offset-2">

        <div class="list-group">

          <!-- 原始html中我们使用a标签实现页面的跳转 -->

          <!-- <a class="list-group-item active" href="./about.html">About</a> -->

          <!-- <a class="list-group-item" href="./home.html">Home</a> -->

          <!-- Vue中借助router-link标签实现路由的切换 -->

          <router-link class="list-group-item" active-class="active" to="/about"

            >About</router-link

          >

          <router-link class="list-group-item" active-class="active" to="/home"

            >Home</router-link

          >

        </div>

      </div>

      <div class="col-xs-6">

        <div class="panel">

          <div class="panel-body">

            <!-- 指定组件的呈现位置 -->

            <router-view></router-view>

          </div>

        </div>

      </div>

    </div>

  </div>

</template>

<script>

export default {

  name: "App",

};

</script>

注意点:

路由组件通常存放在pages文件夹里面 ,一般组件通常存放在components文件夹

通过切换,&lsquo;隐藏了的路由组件&rsquo;,默认是被销毁掉的,需要的时候再去挂载

每个组件都有自己的$route属性,里面存储着自己的路由信息

整个应用只有一个router,可以通过组件的$router属性获取到

三、路由嵌套 

跳转要加上父亲路径 即:/home/news

路径:children:[

       {    path:'news'   ,component:News

]

注意path后面不要加 &lsquo;/news&rsquo;

比如我们要在上面基础步骤里面的home路由组件里面嵌套两个组件 

index.js文件:

const router = new VueRouter({

    routes: [

        {

            path: '/about',

            component: About

        },

        {

            path: '/home',

            component: Home,

            children: [

                {

                    path: 'news',

                    component:News,

                },

                {

                    path: 'message',

                    component:Message,

                }

            ]

        }

    ]

那么home组件的展示区就是嵌套组件的呈现位置

home.vue

<template>

  <div>

    <h3>Home组件内容</h3>

    <div>

      <ul class="nav nav-tabs">

        <li>

          <router-link class="list-group-item " active-class="active" to="/home/news">News</router-link>

        </li>

        <li>

          <router-link class="list-group-item " active-class="active" to="/home/message">Message</router-link>

        </li>

      </ul>

      <!-- 指定组件的呈现位置 -->

      <router-view></router-view>

    </div>

  </div>

</template>

<script>

export default {

  name: "Home",

};

</script>

四、路由命名

作用:可以简化路由的跳转

如何使用:

首先给路由命名

const router = new VueRouter({

   routes:[

      {

         name:'guanyu',

         path:'/about',

         component:About

      }

]

})

简化跳转

首先看下没加命名的跳转:

<router-link to ='/demo/test/about'> 跳转 </router-link>

简化后的,直接通过名字跳转

<router-link to='{name:about}'> 跳转 </router-link>

简化写法搭配传递参数

<router-link :to'{name:'about',query:{ id:m.id,title:m.title}}'>{{m.title}}</router-link>

五、query参数 和 params参数

5.1、路由的query参数

传递参数的方法:

方法一:跳转路由并携带query参数,to的字符串写法

<router-link :to="&mdash;&mdash;/home/message/detail? id=${m.id}&title=${m.title}&mdash;&mdash;">{{m.title}}</router-link>

方法二:跳转路由并携带query参数,to的对象写法

<router-link 

   :to="{

        path:'/home/message/detail',

        query:{

            id:m.id,

            title:m.title  

   }">

 {{m.title}}

</router-link>

接受参数的方法:

detail.vue

$route.query.xx

<template>

  <div>

    <ul>

      <li>消息编码:{{$route.query.id}}</li>

      <li>消息编码:{{$route.query.title}}</li>

    </ul>

  </div>

</template>

5.2、路由的params参数 

配置路由:

children: [

         {

              name:'xiangqing',

              path: 'detail/:id/:title', //使用占位符声明接受params参数

              component: Detail,

          }

  ]

传递参数的方法:

方法一:跳转路由并携带params参数,to的字符串写法

<router-link :to="&mdash;&mdash;/home/message/detail/${m.id}/${m.title}&mdash;&mdash;">{{m.title}}</router-link>

方法二:跳转路由并携带params参数,to的对象写法

特别注意:路由携带params参数时,若使用to的对象写法,则不能使用path配置项,必须使用name配

 <router-link

          :to="{

            name: 'xiangqing',

            params: {

              id: m.id,

              title: m.title,

            },

          }"

        >

      {{ m.title }}

</router-link>

接受参数的方法:

detail.vue

$route.params.xx 

<template>

  <div>

    <ul>

      <li>消息编码:{{$route.params.id}}</li>

      <li>消息编码:{{$route.params.title}}</li>

    </ul>

  </div>

</template>

六、路由的params配置  

当父组件携带参数给子路由的时候,子路由可以直接使用,通过params配置后更加简单

作用:让路由组件更加方便的收到参数

之前的:<li>消息编码:{undefined{$route.params.id}}</li>

现在的:  <li>消息编码:{undefined{id}}</li>

6.1、方法一

    路由配置props 【使用少】

children: [

            {

               name: 'xiangqing',

               path: 'detail/:id/:title', //使用占位符声明接受params参数

               component: Detail,

               props: { a: '001', b: '你好' }

             }

 ]

值为对象,该对象中的所有key-value都会以props的形式传给Detail组件

   路由接受props

路由;

<template>

  <div>

    <h3>{{a}}</h3>

    <h3>{{b}}</h3>

  </div>

</template>

export default {

  name: "Detail",

  props:['a','b'],

  mounted() {

    console.log(this.$route);

  },

};

 6.2、方法二

   路由配置props

props值为布尔值,为true的时候,就会把该路由组件收到的多有params参数,以props的形式传给detail组件

 path: 'detail/:id/:title' :携带的id和title参数都是跳转路径的时候携带的query参数或params参数

 children: [

            {

             name: 'xiangqing',

             path: 'detail/:id/:title', //使用占位符声明接受params参数

             component: Detail,

             props:true

            }

    ]

   路由接受props

<template>

  <div>

    <ul>

      <li>消息编码:{{id}}</li>

      <li>消息编码:{{title}}</li>

    </ul>

  </div>

</template>

 props:['id','title'],

 6.2、方法三

   路由配置props

children: [

      {

        name: 'xiangqing',

        path: 'detail', //使用占位符声明接受params参数

        component: Detail,

         props($route) {

                 return{

                      id: $route.query.id,

                      title:$route.query.title

                 }

          }

       }

]

   路由接受props

<template>

  <div>

    <ul>

      <li>消息编码:{{id}}</li>

      <li>消息编码:{{title}}</li>

    </ul>

  </div>

</template>

props:['id','title'],

七、两个新的生命周期钩子(路由)

作用:路由组件所独有的两个钩子,用于捕获路由组件的激活状态

具体名字:activated 路由组件被激活时触发、deactivted 路由组件失活时触发

即使将news里面的内容缓存起来,在news路由组件失活的时候,定时器也会被关闭,缓存和失活不会相互影响

export default {

  name: "News",

  data() {

    return {

      opacity: 1,

    };

  },

  activated() {

    this.timter = setInterval(() => {

      this.opacity -= 0.01;

      if (this.opacity <= 0) this.opacity = 1;

    }, 16);

  },

  deactivated() {

    clearInterval(this.timter);

  },

};

以上就是关于“vue路由怎么创建”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网node.js频道。

--结束END--

本文标题: vue路由怎么创建

本文链接: https://www.lsjlt.com/news/92055.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue路由怎么创建
    这篇“vue路由怎么创建”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue路由怎么创建”...
    99+
    2022-10-19
  • vue如何创建路由实例
    在vue中创建路由实例的方法:1.新建项目,引入vue和vue-router;2.使用Vue.use方法注册路由;3.定义路由;4.使用new VueRouter方法创建路由实例;具体步骤如下:首先,在新建一个html项目,并在项目中引入v...
    99+
    2022-10-11
  • vue路由怎么用
    这篇文章给大家分享的是有关vue路由怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。vue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,适合用于构...
    99+
    2022-10-19
  • Vue路由vue-router怎么用
    这篇文章主要为大家展示了“Vue路由vue-router怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue路由vue-router怎么用”这篇文章吧。一、vue-router1、简介(1...
    99+
    2023-06-29
  • Vue路由怎么使用
    这篇文章主要介绍“Vue路由怎么使用”,在日常操作中,相信很多人在Vue路由怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue路由怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!在Vue中...
    99+
    2023-06-04
  • vue如何建立子路由
    在vue中建立子路由的方法:1.新建html项目,引入vue和vue-router;2.使用Vue.use方法注册路由;3.定义路由;4.在children属性中添加子路由;具体步骤如下:首先,在新建一个html项目,并在项目中引入vue和...
    99+
    2022-10-20
  • vue静态路由怎么写
    Vue是一款流行的JavaScript框架,它提供了一个灵活的框架,用于构建交互式、动态和可伸缩的Web应用程序。Vue Router是Vue.js官方路由管理插件,它允许您将组件映射到路由,从而实现单页应用程序 (SPA) 开发。Vue ...
    99+
    2023-05-14
  • vue嵌套路由怎么实现
    本文小编为大家详细介绍“vue嵌套路由怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue嵌套路由怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。用 Vue CLI 进行设置如果尚未安装,请运行以...
    99+
    2023-07-04
  • Vue中路由守卫怎么用
    小编给大家分享一下Vue中路由守卫怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1.全局守卫1.1 全局前置守卫顾名思义,前置守卫主要是在你进行路由跳转之前根据你的状态去 进行一系列操作(全局前置是为在路由初始化以及...
    99+
    2023-06-21
  • Vue嵌套路由怎么使用
    这篇“Vue嵌套路由怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue嵌套路由怎么使用”文章吧。用 Vue CLI...
    99+
    2023-07-04
  • 轻松创建nodejs服务器(4):路由
    服务器需要根据不同的URL或请求来执行不一样的操作,我们可以通过路由来实现这个步骤。 第一步我们需要先解析出请求URL的路径,我们引入url模块。 我们来给onRequest()函数加上一些逻辑,用来找出浏...
    99+
    2022-06-04
    路由 轻松 服务器
  • 如何使用Go语言创建路由
    如何使用Go语言创建路由,需要具体代码示例在Go语言中,路由是Web开发中非常重要的一部分。它用于将HTTP请求映射到具体的处理函数,实现不同请求的处理和路由的管理。本文将介绍如何使用Go语言创建路由,并给出具体的代码示例。首先,我们需要导...
    99+
    2023-12-18
    Go语言 路由 创建
  • vue二级路由报错怎么办
    本教程操作环境:Windows10系统、Vue 3版、Dell G3电脑。vue二级路由报错怎么办?vue中二级路由跳转不成功的一个原因二级路由有具体的路径时前面不加斜杠/vue二级路由不显示页面bug如果父路由path是 / 则redir...
    99+
    2023-05-14
    Vue
  • 怎么用vue实现动态路由
    这篇文章主要介绍了怎么用vue实现动态路由的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用vue实现动态路由文章都会有所收获,下面我们一起来看看吧。1、什么是动态路由?动态路由,动态即不是写死的,是可变的。...
    99+
    2023-07-02
  • vue中怎么设置二级路由
    本篇文章为大家展示了vue中怎么设置二级路由,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。首先把一级路由的结构准备好: <router-link&n...
    99+
    2022-10-19
  • vue中怎么实现路由传参
    本篇文章为大家展示了vue中怎么实现路由传参,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。在vue路由中,支持3中传参方式。场景,点击父组件的li元素跳转到子组件中...
    99+
    2022-10-19
  • vue怎么实现路由懒加载
    这篇文章主要介绍了vue怎么实现路由懒加载,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。路由懒加载写法: // 我所采用...
    99+
    2022-10-19
  • 什么是Vue-Router路由
    这篇文章给大家介绍什么是Vue-Router路由,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Vue Router是Vue.js 官方的路由管理器。它和Vue.js的核心深度集成,可以非常方便的用于SPA应用程序的开发...
    99+
    2023-06-22
  • 实例讲解vue怎么实现父级路由跳转子路由
    在Vue中,我们经常需要进行路由跳转操作。Vue的路由功能非常强大,支持嵌套路由和动态路由等功能。本文将讲述如何父级路由跳转子路由。子路由配置首先,我们需要在父级路由中配置子路由。在Vue中,可以使用Vue Router插件来实现路由管理和...
    99+
    2023-05-14
  • 怎么用Vue-Router实现路由功能
    这篇“怎么用Vue-Router实现路由功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么用Vue-Router实现路由...
    99+
    2023-07-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作