Vue.js实现tab滑块效果

这里写图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <script src="../lib/vue.min.js"></script>
    <style>
        *{margin:0;padding:0;}
		#tabPanel .itemname{height:40px;width:180px;margin-bottom:10px;}
		#tabPanel .itemcontent{height:40px;width:180px;}
		#tabPanel .addbtn{width:100px;height:30px;}
        #tabPanel .active{background:#eee;}
        #tabPanel{height:340px;width:500px;margin:100px auto;}
        #tabPanel .tab{height:40px;background:#ccc;margin-top:10px;}
        #tabPanel .tab ul li{list-style: none;float:left;width:80px;height:40px;text-align:center;line-height:40px;}
		#tabPanel .content{height:300px;width:500px;background:#eee;}
    </style>
    <title>Vue.js编写tab滑块效果</title>
</head>
<body>
    <div id="tabPanel">
		<label>添加滑块名称:<input type="text" v-model="tabItem" class="itemname"></label><br>
		<label>添加滑块内容:<input type="text" v-model="tabContent" class="itemcontent"></label><br>
		<input type="button" value="添加选项" @click="addItem()" class="addbtn">
        <div class="tab">
            <ul>
                <li v-for="(value, index) in tabs" v-bind:class="{active: index == num }" @mouseover="toggle(index)" @dblclick="del(index)">{{value}}</li>
            </ul>
        </div>
        <div class="content">
            <div class="box" v-for="(value, index) in tabContents" v-show="index == num" contenteditable="true" @blur="editContent(index,value)">{{value+index}}</div>
        </div>
    </div>
</body>
<script>
    var v = new Vue ({
        el: "#tabPanel",
        data: {
            tabs: ["第一项","第二项"],
            tabContents: ["第一项内容","第二项内容"],
            num: 0,
            tabItem:"",
			tabContent:""
        },
        methods:{
			//切换滑块
            toggle: function(index){
                this.num = index;
            },
			//添加滑块
			addItem: function(){
				if(this.tabItem == "" || this.tabContent == ""){
					alert("填写完整的名称和内容");
				}else{
					this.tabs.push(this.tabItem);
					this.tabContents.push(this.tabContent);
				}
			},
			//双击删除滑块
			del: function(index){
				this.tabs.splice(index,1);
				this.tabContents.splice(index,1)
			},
			//编辑选项内容
			editContent: function(index,value){
				this.tabContents[index] = value;
				console.log(this.tabContents);
			}
        }
    });
</script>
</html>
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值