使用了vue-cli 生成了一套webpack的模版。

之后在其中练习 vue-router。

以下是一些记录。

1.动态路由的配置

import Vue from 'vue'
import Router from 'vue-router'
// import HelloWorld from '@/components/HelloWorld'
// import Hello from '@/components/hello'
import Goodslist from '@/views/Goodslist' Vue.use(Router) export default new Router({
// 路由模式 history,hash
mode:'history'
routes: [
{
path: '/goods/:goodsId/user/:name',
name: 'Goodslist',
component: Goodslist
}
]
})
<!-- vue -->
<!-- vue-router其实是对history的封装 -->
<template>
<div>
<span>这是商品列表</span>
<!-- 获取参数 -->
<p>{{$route.params.goodsId}}</p>
<p>{{$route.params.name}}</p>
</div>
</template> <script type="ecmascript-6"> </script> <style rel="stylesheet"> </style>

访问方式:history是带着地址访问,hash则是用#来访问

2.嵌套路由

  使用场景,菜单。

<!-- Goodslist.vue -->
<!-- vue-router其实是对history的封装 -->
<template>
<div>
<span>这是商品列表</span> <br>
<!-- router-link 和 router-view 分别是两个封装好了的标签
在使用嵌套路由的时候,我们需要在goods路由下 来设置 router-view来承载余下的两个页面
router-link 是 对a标签的封装 作用就是跳转
-->
<router-link to="/goods/title">进入标题</router-link>
<router-link to="/goods/img">进入图片</router-link> <div>
<router-view></router-view>
</div>
</div> </template> <script type="ecmascript-6"> </script> <style rel="stylesheet"> </style>
<!-- Title.vue -->
<template>
<span>这是商品标题</span>
</template> <script type="ecmascript-6"> </script> <style rel="stylesheet"> </style>
<!-- Image.vue -->
<template>
<div>this is goods image</div>
</template> <script type="ecmascript-6"> </script> <style rel="stylesheet"> </style>
import Vue from 'vue'
import Router from 'vue-router'
// import HelloWorld from '@/components/HelloWorld'
// import Hello from '@/components/hello'
import Goodslist from '@/views/Goodslist'
import Title from '@/views/Title'
import Img from '@/views/Image' Vue.use(Router) export default new Router({
// 路由模式 history,hash
mode:'hash',
routes: [
{
path: '/goods',
name: 'Goodslist',
component: Goodslist,
// 使用嵌套路由
// 一个数组,里面存的是对象,每个对象为一个组件
children:[
{
path:'title',
name:'title',
component: Title
},
{
path:'img',
name:'img',
component:Img
}
]
}
]
})

3.编程式路由

  顾名思义,就是通过写js代码来实现路由啦。

  使用的函数: $router.push("name") 或 $router.push({ path :"name "})

  在跳转的时候还可以加入传递的参数。

  $router.push({ path:"name?b=222"}) 或 $router.push({path:'name' ,query:{a:111}})

  还可以使用

  $router.go(1) //类似于 history()

  

  

<!-- vue -->
<!-- vue-router其实是对history的封装 -->
<template>
<div>
<span>这是商品列表</span> <br>
<!-- router-link 和 router-view 分别是两个封装好了的标签
在使用嵌套路由的时候,我们需要在goods路由下 来设置 router-view来承载余下的两个页面
router-link 是 对a标签的封装 作用就是跳转
-->
<router-link to="/goods/title">进入标题</router-link>
<router-link to="/goods/img">进入图片</router-link> <div>
<router-view></router-view>
</div>
<router-link to="/cart">前往购物车</router-link>
<button @click='jump'>btn跳转</button>
</div> </template> <script type="ecmascript-6">
export default{
methods:{
jump(){
this.$router.push({path:'/cart?goodsId=333'})
}
}
}
</script> <style rel="stylesheet"> </style>
<!-- vue -->
<template>
<div>
this is cart page
<p>
<span>{{$route.query.goodsId}}</span>
</p>
</div>
</template> <script type="ecmascript-6"> </script> <style rel="stylesheet"> </style>

这次在cart页面接受参数使用的是query 而不是之前动态路由的 params那是因为

query是页面之间传递参数时候用的 而 params是组件之间传递参数用的。

Vue-router 的练习的更多相关文章

  1. Vue 2.0 + Vue Router + Vuex

    用 Vue.js 2.x 与相配套的 Vue Router.Vuex 搭建了一个最基本的后台管理系统的骨架. 当然先要安装 node.js(包括了 npm).vue-cli 项目结构如图所示: ass ...

  2. vue router 只需要这么几步

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  3. Vue.js 2.x笔记:路由Vue Router(6)

    1. Vue Router简介与安装 1.1 Vue Router简介 Vue Router 是 Vue.js 官方的路由管理器.它和 Vue.js 的核心深度集成,构建单页面应用. Vue Rout ...

  4. Vue Router学习笔记

    前端的路由:一个地址对应一个组件 Vue Router中文文档 一.路由基本使用 第1步:导入Vue Router: <script src="https://unpkg.com/vu ...

  5. vue router.push(),router.replace(),router.go()和router.replace后需要返回两次的问题

    转载:https://www.cnblogs.com/lwwen/p/7245083.html https://blog.csdn.net/qq_15385627/article/details/83 ...

  6. 前端MVC Vue2学习总结(八)——Vue Router路由、Vuex状态管理、Element-UI

    一.Vue Router路由 二.Vuex状态管理 三.Element-UI Element-UI是饿了么前端团队推出的一款基于Vue.js 2.0 的桌面端UI框架,手机端有对应框架是 Mint U ...

  7. 深入浅出的webpack4构建工具---webpack+vue+router 按需加载页面(十五)

    1. 为什么需要按需加载? 对于vue单页应用来讲,我们常见的做法把页面上所有的代码都打包到一个bundle.js文件内,但是随着项目越来越大,文件越来越多的情况下,那么bundle.js文件也会越来 ...

  8. 深入浅出的webpack构建工具--webpack4+vue+router项目架构(十四)

    阅读目录 一:vue-router是什么? 二:vue-router的实现原理 三:vue-router使用及代码配置 四:理解vue设置路由导航的两种方法. 五:理解动态路由和命名视图 六:理解嵌套 ...

  9. python 全栈开发,Day91(Vue实例的生命周期,组件间通信之中央事件总线bus,Vue Router,vue-cli 工具)

    昨日内容回顾 0. 组件注意事项!!! data属性必须是一个函数! 1. 注册全局组件 Vue.component('组件名',{ template: `` }) var app = new Vue ...

  10. vue router 跳转到新的窗口方法

    在CreateSendView2.vue 组件中的方法定义点击事件,vue router 跳转新的窗口通过采用如下的方法可以实现传递参数跳转相应的页面goEditor: function (index ...

随机推荐

  1. kitti数据集标定文件解析

    1.kitti数据采集平台 KITTI数据集的数据采集平台装配有2个灰度摄像机,2个彩色摄像机,一个Velodyne64线3D激光雷达,4个光学镜头,以及1个GPS导航系统.图示为传感器的配置平面图, ...

  2. C++之PIMPL模式

    1 PIMPL解释 PIMPL(Private Implementation 或 Pointer to Implementation)是通过一个私有的成员指针,将指针所指向的类的内部实现数据进行隐藏. ...

  3. QQ登陆功能的实现2

    QQ登陆功能的实现2 由于看到园子里有朋友说需要讲解和剖析实现的步骤,前面的QQ登陆实现只有代码,所以这篇补上 1.  分析 1). 当运行QQ.exe后会出现qq登陆界面的窗体 2). 我们用spy ...

  4. 苹果app(iOS app)的URL schemes

    最近折腾iOS快捷启动应用或应用内的某个动作的神器launch center pro (LCP),发现很多国产app并没有被LCP官方收录,所以不得不想办法找到app的url schemes. 下面是 ...

  5. nohup 命令 print 不能实时输出至 nohup.out

    1. 原因 Python 的输出存在缓冲机制,因此不能实时输出结果至 nohup.out 2. 解决方案 用下面的命令即可解决: nohup python -u FileName > nohup ...

  6. ubuntu下安装显卡驱动

    前言           以下内容是个人学习之后的感悟,转载请注明出处~ 作者的显卡是GT 730,现以NVIDIA-Linux-x86-384.69为例. 1.打开终端,先删除旧的驱动: sudo ...

  7. 同步数据库bat脚本

    在开发中, 如果需要将测试数据库同步到本地进行本地的测试, 可以执行一下脚本进行同步 @ECHO off TITLE databaseBackup REM : 该脚本会将 191 的 database ...

  8. 【Linux学习】Linux文件系统4—Linux文件硬链接与软连接

    Linux文件系统4-Linux文件硬链接与软连接 inode:索引节点 (连接文件)link 一.文件硬链接 1.Linux文件系统中,inode只相同的文件是硬链接文件 2.不同文件名,inode ...

  9. 解读大内老A的《.NET Core框架本质》

    老A说的一句话让我很受启发,想要深入了解框架,你要把精力聚焦在架构设计的层面来思考问题.而透彻了解底层原理,最好的笨办法就是根据原理对框架核心进行重建或者说再造.看起来没有捷径,也是最快的捷径. 题外 ...

  10. MFC CMap整理

    映射表类(CMap)是MFC集合类中的一个模板类,也称作为“字典”.CMap是把唯一关键码映射到值的字典收集类,使用CMap可以构造一个关键字和元素值映射的集合类.一旦在映射中插入了一个关键码值对(元 ...