先看效果图
上代码:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>table</title> </head> <style> #lineTd { background: #fff url() no-repeat 100% center; } table.gridtable { font-family: verdana, arial, sans-serif; font-size: 11px; color: #333333; border-width: 1px; border-color: #666666; border-collapse: collapse; } table.gridtable th { width: 30px; border-width: 1px; padding: 8px; border-style: solid; border-color: #666666; background-color: #dedede; } table.gridtable td { border-width: 1px; padding: 8px; border-style: solid; border-color: #666666; background-color: #ffffff; text-align: center; } ul { width: 20%; } ul li { position: relative; } ul li button { position: absolute; right: 0; } </style> <body> <div id=‘app‘> <div class="hello"> 自定义表格 <ul> 字典一的数据: <br/> <input type="text" v-model=‘value1‘> <button @click=‘addValue1‘> 添加</button> <li v-for="(item,index) in dic1" :key="index"> {{ item }} <button @click=‘deleterow1(item)‘>删除</button> </li> </ul> <ul> 字典二的数据: <br/> <input type="text" v-model=‘value2‘> <button @click=‘addValue2‘> 添加</button> <li v-for="(item,index) in dic2" :key="index"> {{ item }} <button @click=‘deleterow2(item)‘>删除</button> </li> </ul> <table class="gridtable"> <tr> <td id="lineTd"> <span style="float: left; margin-top: 20px">字典2</span> <span style="float: right; margin-top: -10px">字典1</span> </td> <th v-for="(item,index) in dic1" :key="index">{{ item}}</th> </tr> <tr v-for="item in dic2" :key="item"> <td> {{ item }} </td> <td v-for="(y,index) in dic1" :key="index" @click="rowclick(item, y)" :id=`${item+y}`> <!-- <span v-show="isActive === item+y">??</span> --> </td> </tr> </table> <button>确定</button> </div> </div> </body> <script src="./js/vue.js"></script> <script> var vm = new Vue({ el: ‘#app‘, data: { dic1: [1, 2, 3, 4, 5, 6], dic2: ["a", "b", "c", "d"], isActive: "-1", value1: ‘‘, value2: ‘‘ }, methods: { rowclick(x, y) { // this.isActive = x + y; if (document.getElementById(`${x+y}`).innerHTML == ‘??‘) { document.getElementById(`${x+y}`).innerHTML = ‘‘; return } document.getElementById(`${x+y}`).innerHTML = ‘??‘; }, addValue1() { if (!this.value1) { alert(‘数据不可为空‘); return } for (let i in this.dic1) { if (this.dic1[i] == this.value1) { alert(‘不许重复添加数据‘); return } } this.dic1.push(this.value1); }, addValue2() { if (!this.value2) { alert(‘数据不可为空‘); return } for (let i in this.dic2) { if (this.dic2[i] == this.value2) { alert(‘不许重复添加数据‘); return } } this.dic2.push(this.value2); }, deleterow1(id) { for (let i in this.dic1) { if (this.dic1[i] == id) { this.dic1.splice(i, 1) } } }, deleterow2(id) { for (let i in this.dic2) { if (this.dic2[i] == id) { this.dic2.splice(i, 1) } } } }, }) </script> </html>