vue-router的使用方法及含参数的配置方法


Posted in Javascript onNovember 13, 2018

html

router-link:跳转链接

参数to:就是跳转到的链接位置

二层链接 eg:

<router-link to="/users/evan">/users/evan</router-link>

需要配置所对应的对应的children

children所对应的参数

path:可分我固定的参数url 和带参数的  区别于 :(冒号)

name:对应的参数的模块名称(动态传参数)

component:可以传多个组件

eg:
{ path: '/',
 // a single route can define multiple named components
 // which will be rendered into <router-view>s with corresponding names.
 components: {
  default: Foo,
  a: Bar,
  b: Baz
 }
},

:to="{ name: 'user', params: { username: 'evan' }, query: { foo: 'bar' }}"

参数说明params 对应的是children的path的值 ,to中的name为vueRouter中的name

当要传多个参数时

{ path: ':username/:aaa', name: 'user', component: User }

也可以利用query传值

query: { foo: 'bar' }
eg: path: ':username'

redirect:链接直接指向指定的方向(重定向)

beforeEnter:
·
{ path: '/dashboard', component: Dashboard, beforeEnter: requireAuth },
function requireAuth (route, redirect, next) {
 if (!auth.loggedIn()) {
 redirect({
  path: '/login',
  query: { redirect: route.fullPath }
 })
 } else {
 next()
 }
}

使用props将组件和路由解耦:

在组件中使用$route会使之与其对应路由形成高度耦合,从而使组件只能在某些特定的url上使用,限制了其灵活性。

对应的参数的值的获取

{{$route.params.username1 }}
 { path: '/users', component: Users,
  children: [
  { path: ':username', name: 'user', component: User }
  ]
 }

eg:

<ul>
  <li><router-link to="/">/</router-link></li>
  <li><router-link to="/" exact>/ (exact match)</router-link></li>

  <li><router-link to="/users">/users</router-link></li>
  <li><router-link to="/users" exact>/users (exact match)</router-link></li>

  <li><router-link to="/users/evan">/users/evan</router-link></li>
  <li><router-link to="/users/evan#foo">/users/evan#foo</router-link></li>
  <li>
   <router-link :to="{ path: '/users/evan', query: { foo: 'bar' }}">
   /users/evan?foo=bar
   </router-link>
  </li>
  <li><!-- #635 -->
   <router-link :to="{ name: 'user', params: { username: 'evan' }, query: { foo: 'bar' }}" exact>
   /users/evan?foo=bar (named view + exact match)
   </router-link>
  </li>
  <li>
   <router-link :to="{ path: '/users/evan', query: { foo: 'bar', baz: 'qux' }}">
   /users/evan?foo=bar&baz=qux
   </router-link>
  </li>

  <li><router-link to="/about">/about</router-link></li>

  <router-link tag="li" to="/about">
   <a>/about (active class on outer element)</a>
  </router-link>
  </ul>
const router = new VueRouter({
 mode: 'history',
 base: __dirname,
 routes: [
 { path: '/', component: Home },
 { path: '/about', component: About },
 { path: '/users', component: Users,
  children: [
  { path: ':username', name: 'user', component: User }
  ]
 }
 ]
})

js:vue-router配置

router-view:组件的放置位置

对应的链接所对应的组件的配置

路由底下的子组件

{ path: '/users', component: Users,
  children: [
  { path: ':username', name: 'user', component: User }
  ]
 }

//组件

Vue.use(VueRouter)

const Home = { template: '<div><h2>Home</h2></div>' }
const About = { template: '<div><h2>About</h2></div>' }

const Users = {
 template: `
 <div>
  <h2>Users</h2>
  <router-view></router-view>
 </div>
 `
}

const User = { template: '<div>{{ $route.params.username }}</div>' }

==================分界线====================

案例:1

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
</head>
<body>
<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
<div id="app">
 <h1>Hello App!</h1>
 <p>
  <!-- 使用 router-link 组件来导航. -->
  <!-- 通过传入 `to` 属性指定链接. -->
  <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
  <router-link to="/foo">Go to Foo</router-link>
  <router-link to="/bar">Go to Bar</router-link>
 </p>
 <!-- 路由出口 -->
 <!-- 路由匹配到的组件将渲染在这里 -->
 <router-view></router-view>
</div>
<script>
 var Foo = { template: '<div>foo</div>' }
 var Home= { template:'<div>Home</div>' }
 var Bar = { template: '<div>bar</div>' }

 // 2. 定义路由
 // 每个路由应该映射一个组件。 其中"component" 可以是
 // 通过 Vue.extend() 创建的组件构造器,
 // 或者,只是一个组件配置对象。
 // 我们晚点再讨论嵌套路由。
 var routes = [
  { path: '/', component: Home},
  { path: '/foo', component: Foo },
  { path: '/bar', component: Bar }
 ]

 // 3. 创建 router 实例,然后传 `routes` 配置
 // 你还可以传别的配置参数, 不过先这么简单着吧。
 var router = new VueRouter({
  routes // (缩写)相当于 routes: routes
 })

 // 4. 创建和挂载根实例。
 // 记得要通过 router 配置参数注入路由,
 // 从而让整个应用都有路由功能
 var app = new Vue({
  router,
  el:'#app'
 })
</script>
</body>
</html>

实现效果

vue-router的使用方法及含参数的配置方法

=====================================

案例:2

path的二级链接固定参数

<div id="app">
 <h1>Data Fetching</h1>
 <ul>
 <li><router-link to="/">/</router-link></li>
 <li><router-link to="/user/even" exact>/users (exact match)</router-link></li>
</ul>
 <router-view class="view"></router-view>
</div>
<script>
 var Users = {
  template: '<div><h2>Users</h2><router-view></router-view> </div>'
 }
 var User = {
  template: '<div>{{$route.params.username1 }}</div>'
 }
 var Home = {
  template: '<div>Home</div>'
 }
 var router = new VueRouter({
  routes: [
   { path: '/', component: Home,},
   // 动态路径参数 以冒号开头
   { path: '/user', component: Users,
    children: [
     { path: ':username1', name: 'bbb', component: User }
    ]}
  ]
 })
 new Vue({
  el:"#app",
  router,
  data:{
   name:111
  }
 })

vue-router的使用方法及含参数的配置方法

二级链接动态参数

<div id="app">
 <h1>Data Fetching</h1>
 <ul>
 <li><router-link to="/">/</router-link></li>
 <li><router-link :to="{ name: 'bbb', params: { username: name}}" exact>/users/evan?foo=bar (named view + exact match)
  </router-link>
 </li>
</ul>
 <router-view class="view"></router-view>
</div>
<script>
 var Users = {
  template: '<div><h2>Users</h2><router-view></router-view> </div>'
 }
 var User = {
  template: '<div>{{$route.params.username }}</div>'
 }
 var Home = {
  template: '<div>Home</div>'
 }
 var router = new VueRouter({
  routes: [
   { path: '/', component: Home,},
   // 动态路径参数 以冒号开头
   { path: '/user', component: Users,
    children: [
     { path: ':username', name: 'bbb', component: User }
    ]}
  ]
 })
 new Vue({
  el:"#app",
  router,
  data:{
   name:111
  }
 })
</script>

实现效果

vue-router的使用方法及含参数的配置方法 

注意与上一个实例进行对比发现链接的地址并没有发生改变,刷新后会返回首页

如何解决这个问题呢

==============案例=======================

<div id="app">
 <h1>Data Fetching</h1>
 <ul>
 <li><router-link to="/">/</router-link></li>
 <li><router-link :to='{name:"user", params:{ id:111 }}'>111</router-link>
 </li>
</ul>
 <router-view class="view"></router-view>
</div>
<script>
 var Users = {
  template: '<div><h2>Users</h2><div>{{$route.params.id}}</div></div>'
 }
 var Home = {
  template: '<div>Home</div>'
 }
 var router = new VueRouter({
  routes: [
   { path: '/', component: Home,},
   // 动态路径参数 以冒号开头
   { path: '/user/:id', name:'user', component: Users}
  ]
 })
 new Vue({
  el:"#app",
  router,
  data:{
   name:111
  }
 })
</script>

vue-router的使用方法及含参数的配置方法

====================案例传多个组件==============================

<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
<div id="app">
 <h1>Named Views</h1>
 <ul>
  <li><router-link to="/">/</router-link></li>
  <li><router-link to="/other">/other</router-link></li>
 </ul>
 <router-view class="view one"></router-view>
 <router-view class="view two" name="a"></router-view>
 <router-view class="view three" name="b"></router-view>
</div>
<script>

 var Foo = { template: '<div>foo</div>' }
 var Bar = { template: '<div>bar</div>' }
 var Baz = { template: '<div>baz</div>' }

 var router = new VueRouter({
  mode: 'history',
  routes: [
   { path: '/',
    // a single route can define multiple named components
    // which will be rendered into <router-view>s with corresponding names.
    components: {
     default: Foo,
     a: Bar,
     b: Baz
    }
   },
   {
    path: '/other',
    components: {
     default: Baz,
     a: Bar,
     b: Foo
    }
   }
  ]
 })
 // 4. 创建和挂载根实例。
 // 记得要通过 router 配置参数注入路由,
 // 从而让整个应用都有路由功能
 var app = new Vue({
  router,
  el:'#app'
 })
</script>

vue-router的使用方法及含参数的配置方法

总结

以上所述是小编给大家介绍的vue-router的使用方法及含参数的配置方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jQuery 树形结构的选择器
Feb 15 Javascript
JavaScript移除数组内重复元素的方法
Mar 18 Javascript
JS扩展方法实例分析
Apr 15 Javascript
jquery实现的Accordion折叠面板效果代码
Sep 02 Javascript
javascript的几种继承方法介绍
Mar 22 Javascript
js轮盘抽奖实例分析
Apr 17 Javascript
JavaScript数组去重的6个方法
Jan 21 Javascript
Node.js中流(stream)的使用方法示例
Jul 16 Javascript
jQuery实现可兼容IE6的滚动监听功能
Sep 20 jQuery
基于jquery.page.js实现分页效果
Jan 01 jQuery
在vue中使用防抖和节流,防止重复点击或重复上拉加载实例
Nov 13 Javascript
Vue基于iview table展示图片实现点击放大
Aug 05 Javascript
webpack 从指定入口文件中提取公共文件的方法
Nov 13 #Javascript
详解Vue实战指南之依赖注入(provide/inject)
Nov 13 #Javascript
node.js爬取中关村的在线电瓶车信息
Nov 13 #Javascript
详解Vue SSR( Vue2 + Koa2 + Webpack4)配置指南
Nov 13 #Javascript
详解Vue组件插槽的使用以及调用组件内的方法
Nov 13 #Javascript
Vue实现一个无限加载列表功能
Nov 13 #Javascript
Vue实现移动端页面切换效果【推荐】
Nov 13 #Javascript
You might like
用IE远程创建Mysql数据库的简易程序
2006/10/09 PHP
使用GD库生成带阴影文字的图片
2015/03/27 PHP
一个多次搜索+多次传值的解决方案
2007/01/20 Javascript
表单填写时用回车代替TAB的实现方法
2007/10/09 Javascript
jquery $.ajax入门应用一
2008/11/19 Javascript
jquery json 实例代码
2010/12/02 Javascript
wap浏览自动跳转到wap页面的js代码
2014/05/17 Javascript
iframe调用父页面函数示例详解
2014/07/17 Javascript
jQuery组件easyui基本布局实现代码
2016/08/25 Javascript
利用策略模式与装饰模式扩展JavaScript表单验证功能
2017/02/14 Javascript
jQuery validata插件实现方法
2017/06/25 jQuery
使用JS判断移动端手机横竖屏状态
2018/07/30 Javascript
JS判断用户用的哪个浏览器实例详解
2018/10/09 Javascript
js数组相减简单示例【删除a数组所有与b数组相同元素】
2020/03/04 Javascript
JS实现碰撞检测效果
2020/03/12 Javascript
如何在JS文件中获取Vue组件
2020/09/16 Javascript
[01:05:00]2018国际邀请赛 表演赛 Pain vs OpenAI
2018/08/24 DOTA
Python实现设置windows桌面壁纸代码分享
2015/03/28 Python
Python 的描述符 descriptor详解
2016/02/27 Python
Python实现的圆形绘制(画圆)示例
2018/01/31 Python
keras在构建LSTM模型时对变长序列的处理操作
2020/06/29 Python
CSS书写规范、顺序和命名规则
2014/03/06 HTML / CSS
详解Sticky Footer 绝对底部的两种套路
2017/11/03 HTML / CSS
英国精品买手店:Browns Fashion
2016/09/29 全球购物
AVI-8手表美国官方商店:AVI-8 USA
2019/04/10 全球购物
山海经纬软件测试笔试题和面试题
2013/04/02 面试题
大学生预备党员自我评价分享
2013/11/16 职场文书
食品安全检查制度
2014/02/03 职场文书
优秀大学生求职自荐信范文
2014/04/19 职场文书
房地产公司见习自我鉴定
2014/04/28 职场文书
八项规定个人对照检查材料思想汇报
2014/09/25 职场文书
2014年老干部工作总结
2014/11/21 职场文书
学术会议邀请函
2015/01/30 职场文书
工程资料员岗位职责
2015/04/13 职场文书
酒店宣传语大全
2015/07/13 职场文书
MySQL 数据库 增删查改、克隆、外键 等操作
2022/05/11 MySQL