vue+webpack app项目(2)

作者: Obeing | 来源:发表于2016-09-09 11:09 被阅读1236次

step4 slot的使用


<slot> 就是外部调用时,标签中的内容。如果外部调用时没有提供内容的话,那么它就会使用自己默认提供的内容,非常方便。

-这个字面意思确实难以理解,用代码解释
-首先定义Bar.vue组件替代最外层的nav

Paste_Image.png

-然后在main.vue import 进来引用

-原来的nav标签就会变成这样写

Paste_Image.png

-先看现在的效果

Paste_Image.png

-一切正常,但是如果把Bar.vue中的slot注释,就没有这些导航图标了,所以我可以理解为使用了slot可以把不在Bar.vue的template中的代码引进来,不使用就直接使用Bar.vue的template模板了

Paste_Image.png

--现在可以把里面的item元素也弄成一个BarItem.vue组件
--这里要知道一个新的指令v-link和它的activeClass配合

v-link 是一个用来让用户在 vue-router 应用的不同路径间跳转的指令。http://router.vuejs.org/zh-cn/link.html 详情看这里

= = 先上代码BarItem.vue

Paste_Image.png

-script中的props是在main.vue传进来的参数,v-link中的replcace:true 是用了router.replace()而不是router.go()也就是不能后退(首页标签页切换就不让用户有后退的功能了),activeClass是当路由激活时加上的类

--main.vue现在的代码

Paste_Image.png

--对了,记得把BarItem.vue引进来喔
--现在的效果还是像之前一样,但是已经实现组件化了

step5 菜单栏配置路由

--新建search.vue、message.vue、me.vue、home.vue,然后在router.js中做相应的配置

Paste_Image.png

--这里动态组件载入就是常说的懒加载组件

当你在使用 Webpack 或者 Browserify 时,在基于异步组件编写的 Vue 项目时,也可以较为容易的实现惰性加载组件。不再是之前所述的直接引用一个组件,现在需要像下面这样通过定义一个函数返回一个组件:

--resolve这个参数有点难理解,实际就是用异步加载,用AMD风格的写法是

require(['./MyComponent.vue'], 
     function (MyComponent) { 
    // code here runs after MyComponent.vue is asynchronously loaded
.})

--五个路由都写好就可以随意切换tab了

step6 HomeTab编写

Paste_Image.png

-想要达到这种效果
-homeTab这部分也是可以提取出组件作为各个tab的头部
-赞一下vue的错误提示,一开始死活显示不了,这错误提示还是很明显的


Paste_Image.png

--用组件记得在js components中注册
--还有这个提示,注册了变量没


Paste_Image.png

已更新github代码,不求打赏只求github小星星,跪求
https://github.com/sally2015/vue-project

相关文章

  • Vue项目实例参考

    1. 参考文档 原教程地址 vue+webpack项目实战 vue+webpack app项目(1) https:...

  • vue+webpack app项目(2)

    step4 slot的使用 就是外部调用时,标签中的内容。如果外部调用时没有提供内容的话,那么它就会使用自己默认提...

  • vue-cli搭建项目记录

    创建vue+webpack项目vue init webpack 2.eslint: Newline require...

  • 如何安装vue

    1、vue+webpack安装,生成初始化vue项目vue+webpack安装,生成初始化vue项目_前端劝退师儿...

  • vue+webpack app项目(1)

    概述 项目中会用到的插件 vue-router vue-resource 打包工具 webpack 依赖环境 no...

  • vue+webpack app项目(3)

    step6 HomeTab内容+下拉刷新 --这里的ui用的是sui,包括下拉刷新也是用sui的组件,详情:htt...

  • vue+webpack app项目(4)

    step7解决(3)中刷新在两个tab中都添加元素的问题 (3)中的情况是无论在动态tab下拉刷新还是在前端tab...

  • vue+webpack app项目(5)

    step9 个人中心布局## 前面step1到step8已经将首页和基本菜单栏完成,现在先做个人中心页也就是底部菜...

  • vue+webpack app项目(6)

    step6 利用vue-resource 获取数据 将首页的数据变为动态获取的 首先定义一个json文件,注意格...

  • 用Vue-cli生成vue+webpack的项目模板怎么设置为v

    用Vue-cli生成vue+webpack的项目模板 $npm install -g vue-cli$vue in...

网友评论

本文标题:vue+webpack app项目(2)

本文链接:https://www.haomeiwen.com/subject/evseettx.html