mousemove 鼠标移动选中单元格
mousemove 移动选中单元格
-
mousemove 移动选中单元格 click 选中/取消单元格
<template> <div class="table-page"> <div class="table-box"> <table cellpadding="0" cellspacing="0"> <tr> <th>日</th> <th>一</th> <th>二</th> <th>三</th> <th>四</th> <th>五</th> <th>六</th> </tr> <tr v-for="(item,index) in tableList" :key="index"> <td v-for="(tmp,tmpIndex) in item.tdList" :key="tmpIndex" :class="[handleChooseColor(checkList,tmp)]" @click="onTableItem(tmp)" @mousedown="mousedown(tmp, $event)" @mousemove.prevent='mousemove(tmp, $event)' @mouseup='mouseup(tmp, $event)'>{{ tmp.name }}</td> </tr> </table> {{ checkList }} </div> </div> </template> <script lang="ts"> import { Component, Vue } from "vue-property-decorator"; @Component({ name: "TablePage", components: {}, }) export default class extends Vue { tableList = [ { tdList: [ { name: "张三", id: 1, }, { name: "张三1", id: 2, }, { name: "张三2", id: 3, }, { name: "张三3", id: 4, }, { name: "张三4", id: 5, }, { name: "张三5", id: 6, }, { name: "张三6", id: 7, }, ], }, { tdList: [ { name: "李四", id: 8, }, { name: "李四1", id: 9, }, { name: "李四2", id: 10, }, { name: "李四3", id: 11, }, { name: "李四4", id: 12, }, { name: "李四5", id: 13, }, { name: "李四6", id: 14, }, ], }, { tdList: [ { name: "王五", id: 15, }, { name: "王五1", id: 16, }, { name: "王五2", id: 17, }, { name: "王五3", id: 18, }, { name: "王五4", id: 19, }, { name: "王五5", id: 20, }, { name: "王五6", id: 21, }, ], }, { tdList: [ { name: "赵六", id: 28, }, { name: "赵六1", id: 22, }, { id: 23, name: "赵六2", }, { id: 24, name: "赵六3", }, { id: 25, name: "赵六4", }, { id: 26, name: "赵六5", }, { id: 27, name: "赵六6", }, ], }, ]; is_moving = false; checkList = []; mousedown(site, event) { this.is_moving = true; } mousemove(site, event) { const _this = this; if (this.is_moving) { const tmpIndex = this.checkList.findIndex(el => el.id === site.id); // tmpIndex === -1 不存在,否则存在 if (tmpIndex !== -1) { } else { this.checkList.push(site); } } } mouseup(e) { this.is_moving = false; } mounted() {} handleChooseColor(array, item) { if (array.length > 0) { let isColor = ""; for (let i = 0; i < array.length; i++) { if (array[i].id === item.id) { isColor = "table-actived"; } } return isColor; } } onTableItem(item) { const tmpIndex = this.checkList.findIndex(el => el.id === item.id); if (tmpIndex !== -1) { this.checkList.splice(tmpIndex, 1); } else { this.checkList.push(item); } } } </script> <style lang="scss" scoped> .table-page { width: 100%; .table-box { width: 800px; height: 100%; margin: 100px auto; table { border: 1px solid #cdcdcd; border-bottom: none; border-right: none; margin-bottom: 30px; text-align: center; tr { border-collapse: collapse; /*设置单元格的边框合并为1*/ height: 60px; display: table; width: 100%; table-layout: fixed; td { border-bottom: 1px solid #dcdfe6; border-right: 1px solid #dcdfe6; color: #606266; font-size: 12px; user-select: none; cursor: pointer; &.table-actived { background-color: #c1f5d9; border: 1px solid #61d8a3; } } th { font-size: 13px; color: #303133; font-weight: normal; border-right: 1px solid #dcdfe6; border-bottom: 1px solid #dcdfe6; } } } } } </style>