一、路由:

1、后端路由:

  对于普通网站,所有的超链接都是URL地址,所有的URL地址都对应服务器上对应的资源;

2、前端路由:

  对于单页面应用程序来说,主要通过URL中的hash(#号)来实现不同页面之间的切换,同时,hash之间有一个特点:HTTP请求中不会包含hash相关的内容;所以,单页面程序中的页面跳转主要用hash实现;

3、在单页面应用程序中,这种通过hash改变来切换页面的方式,称作前端路由!!!

二、安装:

官网:https://router.vuejs.org/zh/installation.html

JS:https://unpkg.com/vue-router/dist/vue-router.js

三、使用:

1、导入及创建对象:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
<title>路由</title>
<script src="./lib/vue.js"></script>
<!-- .安装vue-router路由模块 -->
<script src="./lib/vue-router.js"></script>
<style></style>
</head>
<body>
<div id="app">
<!-- <a href="#/login">登录</a>
<a href="#/register">注册</a> --> <!-- router-link 默认渲染成一个 a 标签 -->
<router-link to="/login" tag="span">登录</router-link>
<router-link to="/register">注册</router-link> <!-- 这是 vue-router 提供的元素,专门用来当做占位符的,将来,
路由规则,匹配到的组件,就会展示到这个 router-view 中去-->
<!-- 我们可以把 router-view 认为是一个占位符 “ 留坑” -->
<router-view></router-view>
</div> <script>
var login = {
template: "<h1>登录组件</h1>"
};
var register = {
template: "<h1>注册组件</h1>"
};
// 2.创建一个路由对象,当导入 vue-router 包之后,在 window 全局对象中,就有了
//一个路由的构造函数,叫做 VueRouter
// 在new 路由对象的时候,可以为 构造函数,传递一个配置对象
var routerObj = new VueRouter({
// route 这个配置对象中的 route 表示【路由匹配规则】的意思
routes: [
//路由匹配规则
// 每个路由规则,都是一个对象,这个规则对象,身上,有两个必须的属性:
// 属性1:path 表示监听哪个路由链接地址
// 属性2: component 表示,如果路由是前面匹配到的 path,则展示 component 属性对应的那个组件
//component 的属性值,必须是一个组件的模板对象,不能是组件的引用名称
{ path: "/login", component: login },
{ path: "/register", component: register }
]
});
var vm = new Vue({
el: "#app",
data: {},
methods: {},
// 将路由规则对象,注册到VM 实例上,用来监听 url地址的变化,然后展示对应的组件
router: routerObj
});
</script>
</body>
</html>

2、重定向(打开时默认导向的位置:可以在地址栏上查看区别)

 { path: "/", redirect: "/login" },

例子中,是默认打开时就导向login页面

3、设置路由高亮的方式(两种:第二种直接样式里定义即可):

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
<title>路由</title>
<script src="./lib/vue.js"></script>
<!-- 1.安装vue-router路由模块 -->
<script src="./lib/vue-router.js"></script>
<style>
/* 2.第二种设置路由高亮的方式---直接设置,不需要再定义 */
.router-link-active {
color: red;
font-weight: 800;
font-style: italic;
font-size: 80px;
text-decoration: underline;
background-color: green;
}
/* 1.1第一种设置路由高亮的方式--需要定义下 */
.myactive {
color: red;
font-weight: 800;
font-style: italic;
font-size: 80px;
text-decoration: underline;
background-color: green;
}
</style>
</head>
<body>
<div id="app">
<!-- <a href="#/login">登录</a>
<a href="#/register">注册</a> --> <!-- router-link 默认渲染成一个 a 标签 -->
<router-link to="/login">登录</router-link>
<router-link to="/register">注册</router-link> <!-- 这是 vue-router 提供的元素,专门用来当做占位符的,将来,
路由规则,匹配到的组件,就会展示到这个 router-view 中去-->
<!-- 我们可以把 router-view 认为是一个占位符 “ 留坑” -->
<router-view></router-view>
</div> <script>
var login = {
template: "<h1>登录组件</h1>"
};
var register = {
template: "<h1>注册组件</h1>"
};
// 2.创建一个路由对象,当导入 vue-router 包之后,在 window 全局对象中,就有了
//一个路由的构造函数,叫做 VueRouter
// 在new 路由对象的时候,可以为 构造函数,传递一个配置对象
var routerObj = new VueRouter({
// route 这个配置对象中的 route 表示【路由匹配规则】的意思
routes: [
//路由匹配规则
// 每个路由规则,都是一个对象,这个规则对象,身上,有两个必须的属性:
// 属性1:path 表示监听哪个路由链接地址
// 属性2: component 表示,如果路由是前面匹配到的 path,则展示 component 属性对应的那个组件
//component 的属性值,必须是一个组件的模板对象,不能是组件的引用名称
// redirect 是重定向,定义打开页面的默认的导向哪个页面,可以在地址栏中具体查看
{ path: "/", redirect: "/login" },
{ path: "/login", component: login },
{ path: "/register", component: register }
]
// 1.2第一种设置路由高亮的方式--需要定义的部分
// linkActiveClass: "myactive"
});
var vm = new Vue({
el: "#app",
data: {},
methods: {},
// 将路由规则对象,注册到VM 实例上,用来监听 url地址的变化,然后展示对应的组件
router: routerObj
});
</script>
</body>
</html>

4、设置路由的动画:

样式内加上:

 .v-enter,
.v-leave-to {
opacity: 0;
transform: translateX(150px);
}
.v-enter-active,
.v-leave-active {
transition: all 0.8s ease;
}

然后:

<transition mode="out-in">
<router-view></router-view>
</transition>

Vue学习之路由vue-router小结(九)的更多相关文章

  1. day 82 Vue学习二之vue结合项目简单使用、this指向问题

    Vue学习二之vue结合项目简单使用.this指向问题   本节目录 一 阶段性项目流程梳理 二 vue切换图片 三 vue中使用ajax 四 vue实现音乐播放器 五 vue的计算属性和监听器 六 ...

  2. day 81 Vue学习一之vue初识

      Vue学习一之vue初识   本节目录 一 Vue初识 二 ES6的基本语法 三 Vue的基本用法 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 vue初识 vue称为渐进式js ...

  3. day 82 Vue学习三之vue组件

      Vue学习三之vue组件   本节目录 一 什么是组件 二 v-model双向数据绑定 三 组件基础 四 父子组件传值 五 平行组件传值 六 xxx 七 xxx 八 xxx 一 什么是组件 首先给 ...

  4. day 81 Vue学习二之vue结合项目简单使用、this指向问题

    Vue学习二之vue结合项目简单使用.this指向问题   本节目录 一 阶段性项目流程梳理 二 vue切换图片 三 vue中使用ajax 四 vue实现音乐播放器 五 vue的计算属性和监听器 六 ...

  5. day 80 Vue学习一之vue初识

    Vue学习一之vue初识   本节目录 一 Vue初识 二 ES6的基本语法 三 Vue的基本用法 四 xxx 五 xxx 六 xxx 七 xxx 八 xxx 一 vue初识 vue称为渐进式js框架 ...

  6. Vue学习之路由vue-router传参及嵌套小结(十)

    一.路由传递参数: 1.使用query传值: <!DOCTYPE html> <html lang="en"> <head> <meta ...

  7. vue学习之用 Vue.js + Vue Router 创建单页应用的几个步骤

    通过vue学习一:新建或打开vue项目,创建好项目后,接下来的操作为: src目录重新规划——>新建几个页面——>配置这几个页面的路由——>给根实例注入路由配置 src目录重整 在项 ...

  8. vue学习之六路由系统

    一.vueRouter实现原理 VueRouter的实现原理是根据监控锚点值的改变,从而不断修改组件内容来实现的,我们来试试不使用VueRouter,自己实现路由控制,如下代码: <!DOCTY ...

  9. vue学习笔记:vue的认识与特点与获取

    Vue了解 Vue:读作 view Vue是一个渐进式框架 与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计. Vue 的核心库只关注视图层,并且非常容易学习,非常容易与其它库或已有项目整 ...

  10. day 83 Vue学习三之vue组件

    本节目录 一 什么是组件 二 v-model双向数据绑定 三 组件基础 四 父子组件传值 五 平行组件传值 六 xxx 七 xxx 八 xxx 一 什么是组件 首先给大家介绍一下组件(componen ...

随机推荐

  1. Vinagre(Gnome Remote Desktop) cannot connect to RDP Server

    In a Sudden , this client cannot be used. Tried to install kdenetwork-krdc , then found there are de ...

  2. MongoDB数据操作练习

    1.创建一年级的3个班,并随机添加 10 名学生: >for(grade_index in (grade = ['grade_1_1', 'grade_1_2', 'grade_1_3'])) ...

  3. js 将图片转换为 base64

    var img = document.getElementById('s_lg_img'); function getBase64Image(img) { var canvas = document. ...

  4. OI蒟蒻收集的各种网址集合(无标记

    本地收藏夹伤不起…… https://zh.wikipedia.org/wiki/Template:%E7%AE%97%E6%B3%95 https://courses.csail.mit.edu/6 ...

  5. 【字符串】【P5830】 【模板】失配树

    [字符串][P5830] [模板]失配树 Description 给定一个长度为 \(n\) 的字符串 \(S\),有 \(m\) 次询问,每次询问给定 \(S\) 的两个前缀,求它们的最长公共 bo ...

  6. ASP.NET 网站迁移 HTTP 错误 500.22 - Internal Server Error 检测到在集成的托管管道模式下不适用

    前提:今天要做网站迁移,把A服务器上的网站迁移到B服务器上,A服务器当时的环境是.NET 4.0 ,而B服务器是.NET2.0,A服务器IIS为6.0,B服务器IIS版本为7.0  第一步,先在B服务 ...

  7. ef core 全局过滤

    有些固定的条件,基本每个查询的时候需要带的条件,我们可以使用全局过滤来帮我们,这样后面的查询就不用每次都带条件了. 微软自带的:https://docs.microsoft.com/zh-cn/ef/ ...

  8. cad.net 在位编辑的原理猜测及找到在位编辑状态的图元

    在位编辑的时候会产生一个名为 0-RefEdit0 的图层,原因不明.... 在位编辑的本质是一个长事务,长事务是使用编辑库的对象替换源对象,相当于剪辑.不理解没关系,请看下面的聊天记录.... [贵 ...

  9. Rancher 构建 CI/CD 自动化流程 - 动态配置 Jenkins-slave(二)

    一.说明 1.1 说明 前面介绍采用 Jenkinsfile + KubernetesPod.yaml 方式进行部署项目(Rancher 构建 CI/CD 自动化流程 - 动态配置 Jenkins-s ...

  10. vs中使用tfs创建项目

    1.打开“Team Explorer”,点击“Home”,选择"Project"->"New Team Project",操作如下图: 2.输入项目名称. ...