动态创建一个tab,里面放一个table,这样一个后台管理的基本功能(之一)就出来了。
好吧,这里其实只是试试水,感受一下vue的数据驱动可以怎么玩,通过一个个实例学习一下vue的各个知识点。这里要看看方法和css如何设置。
一、目标
1、 可以动态创建tab。
2、 可以切换(废话)、可以关闭tab。
3、 Css的设置。
4、 方法的处理方式。
5、 效果图
二、思路
应该有好多种方式可以实现,这里先试一个,其他的以后再说。
还是数据驱动,那么就建立一个大的数据包,把tab信息和table信息都放进去,然后绑定就好了。似乎不是太难的样子。Emmmmmm大概是吧。
Tab切换,暂时使用css的方式来控制。
关闭tab,就是干掉对应的数据。
三、设计与编码 1. 数据包
var tab = new Vue({ el: '#tab', data: { tabNumber: 1, //标签数量,这个是临时的,便于自动重新绑定 currentTabId: 1, //当前激活的tab的id beforeTabId: 1, //上一个被激活的tab的id tabs: { tab1: { //可以有多个标签,这里先默认一个tab id: "1", //标签识别标示 title: "我的桌面", isShow:true, //是否显示 message: '桌面', orderBy: [], //可以控制字段的先后顺序,想调整列的先后顺序,改这个数组就行,可以做个性化设置 tableTh: {}, //表头的描述信息 dataList: [] //数据包,字段名作为关键字,便于列的调整先后顺序 } } }, methods: { tabClick: function (id) { //切换tab //alert("切换tab" + id); //隐藏当前的tab var oldId = tab.currentTabId; //记录切换前tab的id tab.beforeTabId = oldId; tab.tabs["tab" + oldId].isShow = false; //隐藏切换前的tab tab.currentTabId = id; //记录切换后的id tab.tabs["tab" + id].isShow = true; //显示切换后的tab }, closeTab: function (id) { if (id === "1") { alert("这是桌面,建议不要关闭哦:)"); return; } delete tab.tabs["tab" + id]; //这种方式不会被vue监控到,所以不会触发视图的刷新 tab.tabNumber = tab.tabNumber - 1; //这样子凑合一下。触发视图的刷新 //设置“激活”状态 var oldId = tab.beforeTabId; //上一个激活tab var nowId = tab.currentTabId; //现在激活tab if (nowId === id) { //关掉的是激活tab,需要设置上一个tab为激活状态 tab.currentTabId = oldId; tab.tabs["tab" + oldId].isShow = true; //这么写好像可以触发视图的刷新 tab.beforeTabId = 1; } else if (oldId === id) { //关闭的是上一个激活tab,修改前一个tab的id tab.beforeTabId = 1; }else { //需要强制修改一下,否则不会刷新,emmm,好吧还是没自动刷新 tab.currentTabId = nowId; } } } });
methods 这个也是一个保留字(关键字),就是放方法的。里面可以有多个方法,方法名称和标签里的v-on:XXXX='00000' 对应。
这里写了两个方法,一个是切换tab的,一个是关闭tab的。
切换tab:按照数据驱动视图的思路,在方法里面改变数据的isShow 属性值,然后通过模板的设置来实现切换效果。
关闭tab:干掉对应的数据即可,只是实现的时候遇到点小问题,delele的方式不能被监控,到时视图不能及时更新,所以加了一个tab数量的属性,关掉一个tab,数量-1,这样数据变化就可以被监控到了,然后一起重新绑定。
2. 模板
<div> <!--tab标签--> <ul class="tabs left"> <li v-for="t in tabs" v-bind:class="{'selectTag':t.isShow}"> <a v-on:click="tabClick(t.id)" href="javascript:void(0)" rel="external nofollow" > {{t.title}} <em class="arrup" v-on:click.stop="closeTab(t.id)">x</em> </a> </li> </ul> <div v-for="t in tabs" v-show="t.isShow"> {{ t.message }}{{tabNumber}} <table class="table_default1" v-show="t.message!=='桌面'"> <tr> <th>序号</th> <th v-for="key in t.orderBy"> {{t.tableTh[key].title}} </th> </tr> <tr v-for="(tr,i) in t.dataList"> <td>{{i+1}}</td> <td v-for="index in t.orderBy" v-bind:align="t.tableTh[index].align"> {{tr[index]}} </td> </tr> </table> </div> </div>
切换tab
用v-show的方法来控制div是否显示。
v-show是通过修改style的属性来实现的。
用v-bind:class="{'selectTag':t.isShow}" 的方式来实现tab的激活效果。
v-bind:class 可以绑定css名称。因为css名称总是要被换来换去的,所以vue就很贴心的提供了这种if true 才设置的方式,冒号后面为真,才会设置设个css名称,这样数据驱动的时候就方便多了。
四、运行效果
调试了半天,好吧上年纪了,思维不够敏捷,这么点逻辑问题就卡住了,哎。
不过最后还是调试成功了。
五、总结
这个有一个明显的问题,这个数据包是不是有点大,创建的tab越多,数据包就越大,有没有性能问题?会不会卡?
另外这还只是table,如果增加了按钮、查询条件、分页控件,这个数据包的结构要变成多复杂呀?挖坑也不带这么挖的呀。
那么怎么办呢?下次再说。(好吧,现在还没想好,似乎要写组件,或者要用到插槽)感谢大家对的支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】