Vue-路由配置和使用步骤整理
介绍
路由:控制组件之间的跳转,不会实现请求、不用页面刷新,直接跳转-切换组件》》》
安装
本地环境安装路由插件vue-router: cnpm install vue-router --save-dev
*没有安装淘宝镜像的可以将 cnpm 替换成 npm
想要安装的可以看这篇文章http://www.cnblogs.com/padding1015/p/7162024.html,(打开搜索 镜像 即可跳转到对应位置)
配置
两种配置方法:在main.js中 || 在src/router文件夹下的index.js中
这里只说在src/router/index.js中的
- 引入:
import Vue from 'vue' import Router from 'vue-router'
注意这个Router是自定义的名字,这里叫这个名字后,下边都要用到的
2. 使用/注册:
Vue.use(Router)
3. 配置
配置路由:
export default new Router({
routes: [
{
path : ‘/’, //到时候地址栏会显示的路径
name : ‘Home’,
component : Home // Home是组件的名字,这个路由对应跳转到的组件。。注意component没有加“s”.
},
{
path : ‘/content’,
name : ‘Content’,
component : Content
}
],
mode: "history"
})
4. 引入路由对应的组件地址:
import Home from '@/components/Home' import Home from '@/components/Content’
5. 在main.js中调用index.js的配置:
import router from './router'
6. App.vue页面使用(展示)路由:<!-- 展示router -->
把这个标签放到对应位置:
<router-view></router-view>
7. 路由切换(原来的<a href=”XXX.html”>等地方):把切换标签和链接改成:
<router-link to="/">切换到Home组件</router-link> <router-link to="/content">切换到Content组件</router-link>
//这里,to里边的参数和配置时,path的路径一样即可
贴一个源码:
main.js
// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'
import VueResource from 'vue-resource'//从node_modules里边把vue-resource引入进来,同引入vue文件和引入vue-router一个道理 Vue.config.productionTip = false;
Vue.use(VueResource) //这样以后,就可以在任何组件页面中使用http了
/* eslint-disable no-new */
new Vue({
el: '#app',
router,//引用router
template: '<App/>',
components: { App }
})
main.js
src/router/index.js
import Vue from 'vue'
import Router from 'vue-router'
import Home from '@/components/Home'
import Content from '@/components/Content'
import About from '@/components/About'
import Submit from '@/components/Submit' Vue.use(Router) export default new Router({
routes: [
{
path: '/',
name: 'Home',
component: Home
},
{
path: '/content',
name: 'Content',
component: Content
},
{
path: '/about',
name: 'About',
component: About
},
{
path: '/submit',
name: 'Submit',
component: Submit
}
],
mode: "history"//干掉地址栏里边的#号键
})
src/router/index.js(router的主要配置文件)
App.vue 展示Vue
<template>
<div id="app">
<app-header></app-header>
<app-nav></app-nav>
<!-- 展示router -->
<router-view></router-view>
<app-footer></app-footer>
</div>
</template> <script>
import Header from './components/Header'
import Footer from './components/Footer'
import Navbar from './components/Navbar'
export default {
name: 'app',
data () {
return { }
},
components: {//局部注册组件这里,可能会定义多个组件,所以component这个单词加上“s”
"app-header": Header,
"app-footer": Footer,
'app-nav': Navbar
}
}
</script> <style> </style>
App.vue 的router-view 标签
导航页面的路由链接设置,用于切换组件
<template>
<nav class="app-nav">
<ul class="ul-father">
<li class="li-father" v-for="item in arr" v-on:mouseover="item.show = ! item.show" v-on:mouseout="item.show = ! item.show" v-bind:class="{bgchange: item.show}">
<!-- 路由切换组件 -->
<router-link v-bind:to="item.url">
{{ item.title }}
</router-link>
<template v-if="item.value">
<ul class="ul-child" v-show="item.show">
<li class="li-child" v-for="x in item.value">
<a href="javascript:;">
{{ x }}
</a>
</li>
</ul>
</template>
</li>
</ul>
</nav>
</template>
<script>
export default {
name: "app-nav",
data (){
return {
arr: [
{
title: "首页",
value: ["一","二","三","四"],
url: "/",
show: false
},
{
title: "新闻" ,
value: ["二","二","三","四"],
url: "/content",
show: false
},
{
title: "关于",
url: "/about"
},
{
title: "投稿",
url: "/submit"
}
]
}
}
}
</script>
<style scoped>
.app-nav{
margin-bottom: 20px;
}
ul.ul-father {
background: Lightgreen;
margin: 0;
}
.li-father {
position: relative;
display: inline-block;
width: 20%;
margin: 0;
}
li a {
display: block;
padding: 15px 0;
color: #333;
text-decoration: none;
}
li a:hover,.bgchange>a{
color: #fff;
background: #222;
}
.ul-child{
position: absolute;
top: 51px;
left: 0;
width: 100%;
background: Lightgreen;
}
</style>
NavBar.Vue页面,主要用于页面切换的导航组件
声明:
请尊重博客园原创精神,转载或使用图片请注明:
博主:xing.org1^
出处:http://www.cnblogs.com/padding1015/
Vue-路由配置和使用步骤整理的更多相关文章
- vue路由配置,vue子路由配置
上一篇关于vue环境配置已经写好了!按照操作就行了! 现在一个项目已经部署完成,接下来我们从路由开始! 还记得在初始化项目的时候,有提示是否需要安装vue-router,对没错,vue中路由全靠它! ...
- npm vue路由配置
npm vue路由 复习:1.README.md文件:保存如何使用的命令 (1) npm install:拷项目时可以不拷node_modules文件,运行该命令时,会自动下载node_mod ...
- vue 路由配置
1.不带参数的路由配置 及 跳转 //路由配置: { name: "a", path: "/a", component: a } 页面跳转: this.$r ...
- 【原创】一篇学会vue路由配置 、 动态路由 、多层路由(实例)
先来看看效果图: 为了方便讲解,我没有使用vue脚手架,如果需要的,可以留言跟我要.不多说开工: 首先,html先组上 <div id="app"> <div&g ...
- Vue 路由配置、动态路由
1.安装 npm install vue-router --save / cnpm install vue-router --save 2.引入并 Vue.use(VueRouter) (main.j ...
- vue路由配置
1.安装 npm install vue-router --save / cnpm install vue-router --save 2.引入并 Vue.use(VueRouter) (main.j ...
- Vue路由配置history模式
我的博客: https://github.com/Daotin/fe-notes/issues vue需要node.js吗? 你可以用 script 标签的形式引入vue.min.js 这样的,不需要 ...
- Vue 路由模块化配置
博客地址:https://ainyi.com/77 企业运营后台页面很多,路由如若不区分模块化配置,所有路由挤在同一个文件将不好维护,所以路由的配置也要模块化 分享两个解决方案 -- Vue 路由配置 ...
- vue 路由 以及默认路由跳转
https://router.vuejs.org/ vue路由配置: 1.安装 npm install vue-router --save / cnpm install vue-router --sa ...
随机推荐
- Golang学习 - strconv 包--数据类型转换
// 将布尔值转换为字符串 true 或 false func FormatBool(b bool) string // 将字符串转换为布尔值 // 它接受真值:1, t, T, TRUE, true ...
- Asp.net中Request.Url的各个属性对应的意义介绍
Asp.net中Request.Url的各个属性对应的意义介绍 本文转载自 http://www.jb51.net/article/30254.htm 网络上关于Request.Url的说明已经很多也 ...
- 五分钟了解Hash算法
Hash算法详解 想象一下如果高级语言(Java,C++ ,C#)中如果没有实现类似List.Map等数据结构,企业级应用开发将是多么痛苦的事吧? Key-Value这种数据结构对于数据处理非常方便. ...
- Java经典编程题50道之十
一球从100米高度自由落下,每次落地后反跳回原高度的一半:再落下……求它在第10次落地时,共经过多少米?第10次反弹多高? public class Example10 { public sta ...
- nyoj137 取石子(三) 楼教主男人八题之一
思路:一堆时,N态.两堆时,当两堆数量相同,P态,不同为N态.三堆时,先手可以变成两堆一样的,必胜N态. 此时可以总结规律:堆数为偶数可能且石子数都是两两相同的,为P态.分析四堆时,当四堆中两两数量一 ...
- 天气类API调用的代码示例合集:全国天气预报、实时空气质量数据查询、PM2.5空气质量指数等
以下示例代码适用于 www.apishop.net 网站下的API,使用本文提及的接口调用代码示例前,您需要先申请相应的API服务. 全国天气预报:数据来自国家气象局,可根据地名.经纬度GPS.IP查 ...
- Kaggle新手入门之路
学完了Coursera上Andrew Ng的Machine Learning后,迫不及待地想去参加一场Kaggle的比赛,却发现从理论到实践的转变实在是太困难了,在此记录学习过程. 一:安装Anaco ...
- 【Elasticsearch全文搜索引擎实战】之集群搭建及配置
文中Elasticsearch版本为6.0.1 1. 环境配置 把环境配置放在第一节来讲,是因为很多人按官网的Getting Started安装运行会有各种错误.其实都是因为一些配置不正确引起的. 首 ...
- kibana常用聚合查询DSL语句记录
-------- GET winlogbeat-2017.11.*/_search { "query": { "bool": { "must" ...
- ActiveMq笔记2-消息持久化
为了避免意外宕机以后丢失信息,需要做到重启后可以恢复消息队列,消息系统一般都会采用持久化机制. ActiveMQ的消息持久化机制有JDBC,AMQ,KahaDB和LevelDB, 无论使用哪种持久化方 ...