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>
    

posted @ 2022-11-23 16:41  不完美的完美  阅读(232)  评论(0编辑  收藏  举报