欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

基于Vue.js实现tab滑块效果

程序员文章站 2022-11-20 09:34:48
本文实例为大家分享了vue.js实现tab滑块效果的具体代码,供大家参考,具体内容如下

本文实例为大家分享了vue.js实现tab滑块效果的具体代码,供大家参考,具体内容如下

基于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>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。