《vue.js实战》练习---标签页组件
html:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <link rel="stylesheet" href="style.css">
- <title>Title</title>
- </head>
- <body>
- <div id="app">
- <tabs v-model="activeKey">
- <pane label="图片">
- 我是图片内容...
- </pane>
- <pane label="视频">
- 我是视频内容...
- </pane>
- <pane label="音乐">
- 我是音乐内容...
- </pane>
- <pane label="文章">
- 我是文章内容...
- </pane>
- </tabs>
- </div>
- <script src="https://unpkg.com/vue/dist/vue.min.js"></script>
- <script src="pane.js"></script>
- <script src="tabs.js"></script>
- <script>
- var app = new Vue({
- el: '#app',
- data: {
- activeKey: '0'
- }
- })
- </script>
- </body>
- </html>
css:
- [v-cloak] {
- display: none;
- }
- .tabs {
- font-size: 14px;
- color:#657180;
- }
- .tabs-bar:after{
- content:'';
- display: block;
- width: 100%;
- height: 1px;
- background: #d7dde4;
- margin-top:-1px;
- }
- .tabs-tab {
- display: inline-block;
- padding: 4px 16px;
- margin-right: 6px;
- background: #ffffff;
- border: 1px solid #d7dde4;
- cursor: pointer;
- position: relative;
- }
- .tabs-tab-active {
- color: #3399ff;
- border-top: 1px solid #3399ff;
- border-bottom: 1px solid #ffffff;
- }
- .tabs-tab-active:before {
- content: '';
- display: block;
- height: 1px;
- background: #3399ff;
- position: absolute;
- top:;
- left:;
- right:;
- }
- .tabs-content {
- padding: 8px 0;
- }
pane.js:
- Vue.component('pane',{
- name: 'pane',
- template: '<div class="pane" v-show="show">\
- <slot></slot>\
- </div>',
- props: {
- label: {
- type: String,
- default: ''
- }
- },
- data: function () {
- return {
- show: true
- }
- },
- methods: {
- updateNav: function () {
- this.$parent.updateNav();
- }
- },
- watch: {
- label: function () {
- this.updateNav();
- }
- },
- mounted: function () {
- this.updateNav();
- }
- })
tabs.js:
- Vue.component('tabs',{
- template: '<div class="tabs">\
- <div class="tabs-bar">\
- <div \
- v-for="(label,index) in navList"\
- :class="tabCls(index)"\
- @click="handleChange(index)">\
- {{label}}\
- </div>\
- </div>\
- <div class="tabs-content">\
- <slot></slot>\
- </div>\
- </div>',
- props: {
- value: {
- type: String
- }
- },
- data: function () {
- return {
- navList: [],
- currentValue: this.value
- }
- },
- methods: {
- tabCls: function (index) {
- return [
- 'tabs-tab',
- {
- 'tabs-tab-active':index == this.currentValue
- }
- ]
- },
- getTabs: function () {
- return this.$children.filter(function (t) {
- return t.$options.name === 'pane';
- });
- },
- updateNav: function () {
- this.navList = [];
- var _this = this;
- this.getTabs().forEach(function (t) {
- _this.navList.push(t.label);
- })
- this.updateStatus();
- },
- updateStatus: function () {
- var _this = this;
- this.getTabs().forEach(function (t,i) {
- t.show = i == _this.currentValue;
- })
- },
- handleChange: function (index) {
- this.currentValue = index;
- this.$emit('input',index);
- }
- },
- watch: {
- currentValue: function () {
- this.updateStatus();
- },
- value: function (val) {
- this.currentValue = val;
- }
- }
- })
效果图:
《vue.js实战》练习---标签页组件的更多相关文章
- 每天记录一点:NetCore获得配置文件 appsettings.json vue-router页面传值及接收值 详解webpack + vue + node 打造单页面(入门篇) 30分钟手把手教你学webpack实战 vue.js+webpack模块管理及组件开发
每天记录一点:NetCore获得配置文件 appsettings.json 用NetCore做项目如果用EF ORM在网上有很多的配置连接字符串,读取以及使用方法 由于很多朋友用的其他ORM如S ...
- 【Vue.js实战案例】- Vue.js递归组件实现组织架构树和选人功能
大家好!先上图看看本次案例的整体效果. 浪奔,浪流,万里涛涛江水永不休.如果在jq时代来实这个功能简直有些噩梦了,但是自从前端思想发展到现在的以MVVM为主流的大背景下,来实现一个这样繁杂的功能简直不 ...
- Vue.js 实战总结
最近在某个项目中用到了Vue.js,从上手做开发到项目发布,一步步踩了不少坑.本文试图总结过去一个多月使用Vue.js中的一些经验,也算是一点心得体会吧,拿出来与大家分享,欢迎多多交流. Vue.js ...
- vue.js实战——购物车练习(包含全选功能)
vue.js实战第5章 54页的练习1 直接放代码好了,全选的部分搞了好久,代码好像有点啰嗦,好在实现功能了(*^▽^*) HTML: <!DOCTYPE html> <html l ...
- vue.js 实战 todo list
vue.js 起源 vue.js 的作者是尤雨溪,是一名中国人,之前在谷歌工作,现在在全职维护 vue 项目. vue.js 是 2014 年推出来的.现在已经更新到 2.x 版本,3.0 版本会在 ...
- vue.js入门(3)——组件通信
5.2 组件通信 尽管子组件可以用this.$parent访问它的父组件及其父链上任意的实例,不过子组件应当避免直接依赖父组件的数据,尽量显式地使用 props 传递数据.另外,在子组件中修改父组件的 ...
- js基础--浏览器标签页隐藏或显示状态 visibility详解
欢迎访问我的个人博客:http://www.xiaolongwu.cn 前言 在工作中我们可能会遇到这样的需求,当浏览器切换到别的标签页或着最小化时,我们需要暂停页面上正在播放的视频或者音乐,这个需求 ...
- 分享Node.js + Koa2 + MySQL + Vue.js 实战开发一套完整个人博客项目网站
这是个什么的项目? 使用 Node.js + Koa2 + MySQL + Vue.js 实战开发一套完整个人博客项目网站. 博客线上地址:www.boblog.com Github地址:https: ...
- Vue.js 3.x 中跨层级组件如何传递数据?
provide/inject 基本用法 在 Vue.js 中,跨层级组件如果想要传递数据,我们可以直接使用 props 来将祖先组件的数据传递给子孙组件: 注:上图来自 Vue.js 官网:Prop ...
- Vue.js 系列教程 2:组件,Props,Slots
原文:intro-to-vue-2-components-props-slots 译者:nzbin 这是关于 JavaScript 框架 Vue.js 五个教程的第二部分.在这一部分,我们将学习组件, ...
随机推荐
- 20145202马超 2016-2017-2 《Java程序设计》第四周学习总结
20145202马超 2016-2017-2 <Java程序设计>第四周学习总结 教材学习内容总结 继承:打破了封装性 extends 1.提高了代码的复用性. 2.让类与类之间产生了关系 ...
- gp的纯属意外的意外
一不小心,把方法都传过去了,一脸蒙蔽说的就是我,啊哈哈哈啊哈
- fsync体会
看这个链接:http://www.postgresql.org/docs/9.1/static/runtime-config-wal.html 是这样说的: fsync (boolean) If th ...
- Excel拼接字符串
有时候,需要把一些Excel表格中的内容进行拼接,比如A4行的值是前面三行值的加起来.在Excel中可以使用&来进行这种操作.如果数据非常多,就可以使用这个来进行批量操作.
- VectorDrawable在Android中的配置
一.让Android支持VectorDrawable apply plugin: 'com.android.application' android { defaultConfig { vectorD ...
- OpenCV入门:(三:图片Mask operations)
Mask operations 翻译为中文应该是掩模操作,具体操作步骤就是根据一个操作矩阵(又名kernel)处理图片中的每一个像素点,操作矩阵会根据当前像素点的周围像素来调整当前像素值. 1.示例 ...
- 从webview中加载assets中的html文件
private void readHtmlFormAssets(){ WebSettings webSettings = tipsWebView.getSettings(); webSettings. ...
- Vue学习(二):class与style绑定
<!DOCTYPE html> <html lang="en" xmlns:v-bind="http://www.w3.org/1999/xhtml&q ...
- LR创建数据源读取excel
1 在window上创建数据源 2 创建对应的数据文件 excel 注:注意格式和底部的表单名称 3 Vegen中创建参数 注意:机器数据源选择windows的ODBC数据源 SQL查的是(she ...
- Sql面试题之三(难度:简单| 含答案)
Sql面试题之三(难度:简单| 含答案) 答案: .SELECT B.name, B.Depart T.Content FROM B, T WHERE ( T.Content = '税法培训' and ...