结合 webpack 使用 vue-router:

  1. 首先安装路由包vue-router: cnpm install vue-router
  2. 使用模块化工具导入 vue-router 后,必须手动调用 Vue.use() 明确的安装路由:
  3. 导入 vue 包:import Vue from 'vue';
  4. 导入 vue-router 包:import VueRouter from 'vue-router';
  5. 手动安装 Vue-router :Vue.use(VueRouter);
  6. 导入 Account 组件
  7. 导入 GoodsList 组件
  8. 创建路由对象:var router = new VueRouter({ routes:[ accout, goodslist ] });

入口函数 main.js:

//`1:导入 vue 包
import Vue from 'vue';
//2:导入 vue-router 包
import VueRouter from 'vue-router';
//3:手动安装 VueRouter
Vue.use(VueRouter);
// 4:导入 Account 组件
import account from './main/Account.vue';
// 5:导入 GoodsList 组件
import goodsList from './main/GoodsList.vue'; import app from './App.vue'; //6:创建 VueRouter 路由对象
var router = new VueRouter({
//Account GoodsList
routes:[
{ path: '/account', component: account},
{ path: '/goodsList', component: goodsList},
]
}); var vm = new Vue({
el: "#app",
render: c => c(app), //render 会把 el 指定的容器中所有的内容都清空覆盖,所以不要把路由的 router-view 和 router-link 直接写到 el 所控制的元素中;
router //7:将路由对象挂载到 vm 上
}); //App 这个组件是通过 vm 实例的 render 函数渲染出来的, render 函数如果要渲染组件,渲染出来的组件只能放到 el:'#app' 所有指定的元素中;
//Account 和 GoodsList 组件是通过路由匹配监听到的,所以这两个组件只能展示到属于路由的 <router-view></router-view> 中去;

创建组件 Account.vue:

<template>
<div>
<h1>
这是 Account 组件
</h1>
</div>
</template> <script>
export default {
name: "account"
}
</script> <style scoped> </style>

创建 GoodsList.vue 组件:

<template>
<div>
<h1>
这是 GoodsList 组件
</h1>
</div>
</template> <script>
export default {
name: "GoodsList"
}
</script> <style scoped> </style>

创建 App.vue 组件:

<template>
<div>
<h1>这是 App 组件</h1> <router-link to="/account">Account</router-link>
<router-link to="/goodsList">GoodsList</router-link>
<router-view></router-view>
</div>
</template> <script> </script> <style> </style>

index.html:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!--这时容器-->
<div id="app"> </div>
</body>
</html>

展示效果:

创建子组件:

  1:创建子组件 register.vue:

<template>
<div>
<h3>这是 Account 的注册子组件</h3>
</div>
</template> <script>
export default {
name: "register"
}
</script> <style scoped> </style>

  2:创建子组件 login.vue:

<template>
<div>
<h3>这是 Account 的登录子组件</h3>
</div>
</template> <script>
export default {
name: "login"
}
</script> <style scoped> </style>

  3:在组件 account.vue 中添加子组件链接和显示区域:

<template>
<div>
<h1>
这是 Account 组件
</h1>
<router-link to="/account/login">登录</router-link>
<router-link to="/account/register">注册</router-link>
<router-view></router-view>
</div>
</template> <script>
export default {
name: "account"
}
</script> <style scoped> </style>

  4:入口文件 main.js 修改为:

//`1:导入 vue 包
import Vue from 'vue';
//2:导入 vue-router 包
import VueRouter from 'vue-router';
//3:手动安装 VueRouter
Vue.use(VueRouter);
// 4:导入 Account 组件
import account from './main/Account.vue';
// 5:导入 GoodsList 组件
import goodsList from './main/GoodsList.vue'; import app from './App.vue'; //9:导入 account 中的两个子组件
import login from './subcom/login.vue';
import register from './subcom/register.vue' //6:创建 VueRouter 对象
var router = new VueRouter({
//Account GoodsList
routes:[
{
path: '/account',
component: account,
children: [//8:创建 account 的两个子组件
{ path: 'login', component: login},
{ path: 'register', component: register}
]
},
{ path: '/goodsList', component: goodsList},
]
}); var vm = new Vue({
el: "#app",
render: c => c(app), //render 会把 el 指定的容器中所有的内容都清空覆盖,所以不要把路由的 router-view 和 router-link 直接写到 el 所控制的元素中;
router //7:将路由对象挂载到 vm 上
}); //App 这个组件是通过 vm 实例的 render 函数渲染出来的, render 函数如果要渲染组件,渲染出来的组件只能放到 el:'#app' 所有指定的元素中;
//Account 和 GoodsList 组件是通过路由匹配监听到的,所以这两个组件只能展示到属于路由的 <router-view></router-view> 中去;

  其中添加代码:

添加子组件后的显示效果:

注意:组件的 style 样式表:

  •   普通的 style 标签只支持普通的样式,如果想要启用 scss 或者 less,需要为 style 元素设置 lang 属性 例如:<style lang="scss"></style>
  •   只要 style 标签是在 .vue 组件中定义的,推荐为 style 标签开启 scoped 属性 例如:<style scoped></style>
  • <style lang="scss" scoped></style>

抽离路由模块:

入口文件 main.js:

//`1:导入 vue 包
import Vue from 'vue';
import app from './App.vue';
//2:导入 vue-router 包
import VueRouter from 'vue-router';
//3:手动安装 VueRouter
Vue.use(VueRouter);
//4:导入被抽离的路由模块
import router from './router.js'; var vm = new Vue({
el: "#app",
render: c => c(app), //render 会把 el 指定的容器中所有的内容都清空覆盖,所以不要把路由的 router-view 和 router-link 直接写到 el 所控制的元素中;
router //7:将路由对象挂载到 vm 上
}); //App 这个组件是通过 vm 实例的 render 函数渲染出来的, render 函数如果要渲染组件,渲染出来的组件只能放到 el:'#app' 所有指定的元素中;
//Account 和 GoodsList 组件是通过路由匹配监听到的,所以这两个组件只能展示到属于路由的 <router-view></router-view> 中去;

被抽离出的路由模块 router.js:

//2:导入 vue-router 包
import VueRouter from 'vue-router'; // 4:导入 Account 组件
import account from './main/Account.vue';
// 5:导入 GoodsList 组件
import goodsList from './main/GoodsList.vue';
//9:导入 account 中的两个子组件
import login from './subcom/login.vue';
import register from './subcom/register.vue' //6:创建 VueRouter 对象
var router = new VueRouter({
//Account GoodsList
routes:[
{
path: '/account',
component: account,
children: [//8:创建 account 的两个子组件
{ path: 'login', component: login},
{ path: 'register', component: register}
]
},
{ path: '/goodsList', component: goodsList},
]
});
//将 router 对象暴露出去
export default router;

结合 webpack 使用 vue-router(七)的更多相关文章

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

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

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

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

  3. 每天记录一点:NetCore获得配置文件 appsettings.json vue-router页面传值及接收值 详解webpack + vue + node 打造单页面(入门篇) 30分钟手把手教你学webpack实战 vue.js+webpack模块管理及组件开发

    每天记录一点:NetCore获得配置文件 appsettings.json   用NetCore做项目如果用EF  ORM在网上有很多的配置连接字符串,读取以及使用方法 由于很多朋友用的其他ORM如S ...

  4. webpack构建vue项目(配置篇)

    最近公司要求用vue重构项目,还涉及到模块化开发,于是乎,我专门花了几天的时间研究了一下webpack这个目前来看比较热门的模块加载兼打包工具,发现上手并不是很容易,现将总结的一些有关配置的心得分享出 ...

  5. Vue 2.0 + Vue Router + Vuex

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

  6. webpack配合vue.js实现完整的单页面demo

    本篇文章主要是我在开发前研究了webpack+vue.js的单页面应用,因为需要用到node的npm,所以确保安装了node,建议官网安装最新的稳定版本.并且在项目中需要加载一些npm包,由于npm的 ...

  7. 使用Webpack加速Vue.js应用的4种方式

    Webpack是开发Vue.js单页应用程序的重要工具. 通过管理复杂的构建步骤,你可以更轻松地开发工作流程,并优化应用程序的大小和性能. 其中介绍下面四种方式: 单个文件组件 优化Vue构建 浏览器 ...

  8. 一个基于ES6+webpack的vue小demo

    上一篇文章<一个基于ES5的vue小demo>我们讲了如何用ES5,vue-router做一个小demo,接下来我们来把它变成基于ES6+webpack的demo. 一.环境搭建及代码转换 ...

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

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

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

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

随机推荐

  1. 阿里妈妈-RAP项目的实践(2)

    接口详情 (id: 32872) Mock数据 接口名称 datalist1 请求类型 get 请求Url /datas/list1 接口描述 数据列表 请求参数列表 变量名 含义 类型 备注 响应参 ...

  2. Machine Learning in Action(2) 决策树算法

    决策树也是有监督机器学习方法. 电影<无耻混蛋>里有一幕游戏,在德军小酒馆里有几个人在玩20问题游戏,游戏规则是一个设迷者在纸牌中抽出一个目标(可以是人,也可以是物),而猜谜者可以提问题, ...

  3. Linux系统上安装字体

    最近项目中需要控制字体类型,然后就上网查了一下在linux系统上安装字体,在window上和linux上,字体要求一样,都是ttf格式,下面这是window上的字体截图 在linux系统中的/usr/ ...

  4. jquery特效(7)—弹出遮罩层且内容居中

    上周写了几个小特效,其中有个点击按钮弹出遮罩层的特效,下面来看最终实现的效果: 由于是测试的程序,所以我未加关闭的按钮. 一.主体程序 <!DOCTYPE html> <html&g ...

  5. ffmpeg 编码h264 profile如何设置为baseline的问题

    http://blog.csdn.net/kisaa133/article/details/7792008 使用最新版ffmpeg-0.11 libx264-125,使用默认编码时,用Eyecard发 ...

  6. 用margin还是用padding?(3)—— 负margin实战

    看过一篇文章是关于我知道你不知道的负Margin,里面对margin做了总结: 当margin四个值都为正数值的话,那么margin按照正常逻辑同周围元素产生边距.当元素margin的top和left ...

  7. IOS微信禁用分享跳转页面返回BUG修复

    fresh(); function fresh() { let isPageHide = false; window.addEventListener('pageshow', function () ...

  8. HDU3666 THE MATRIX PROBLEM (差分约束+取对数去系数)(对退出情况存疑)

    You have been given a matrix C N*M, each element E of C N*M is positive and no more than 1000, The p ...

  9. HTTP Status 500 - Write operations are not allowed in read-only mode (FlushMode.MANUAL): Turn your Session into FlushMode.COMMIT/AUTO or remove 'readOnly' marker from transaction definition.

    如果在service类上面没有添加注解,出现异常 @Transactional

  10. vue 路由跳转到外部链接

    尝试了几次发现,不论怎么写外部链接,最后跳转的路径都会加上localhost:3030; 这个应该是和vue的路由有关系,最后解决方法, window.location = 'http://www.b ...