iview的表格行内编辑,input和select组件使用方向键切换输入

如果表格中的输入框和下拉框需要实现方向键切换选择,效果如图:
请添加图片描述
使用的是IView的UI框架和Vue2,核心是在输入框和下拉框上添加按键监听事件,监听按键对应方向应该要完成的操作,比如当前在Name列的第一行,按【向左键】的话,需要鼠标光标在第一行的Addressfocus()

核心代码讲解

keyup按下键盘执行的方法

handleKeyDown(event, row, key, name) {
  // ↑
  if (event.keyCode === 38) {
    // 按向上键需要执行的操作
  }
  // ↓
  if (event.keyCode === 40) {
    // 按向下键需要执行的操作
  }
  // ->
  if (event.keyCode === 39) {
    // 按向右键需要执行的操作
  }
  // <-
  if (event.keyCode === 37) {
    // 按向左键需要执行的操作
  }
},

针对上下方向键,其实就是更改数组的索引值

changeCurrentRow(row, key, type, name) {
  let curIndex = row._index;
  if (type === "+") {
    curIndex = row._index + 1;
  } else {
    curIndex = row._index - 1;
  }
  let changeRow = this.data[curIndex];
  this.$nextTick(() => {
    let e = document.querySelectorAll(`.${key}`)[curIndex];
    e.querySelector(name).focus();
  });
},

完整代码

template模板部分

<template>
  <Table :columns="columns" :data="data">
    <template #input="{ row, column }">
      <div
        :class="column.key"
      >
        <Input
          v-model="row[column.key]"
          @on-keyup="handleKeyDown($event, row, column.key, 'input')"
          @on-blur="changeValue(column, row[column.key], row._index)"
        />
      </div>
    </template>
    <template #select="{ row, column }">
      <Select
        :class="column.key"
        filterable
        @keyup="handleKeyDown($event, row, column.key, '.ivu-select-input')"
        @on-change="changeSelect(column, row[column.key], row._index, row)"
        clearable
        v-model="row[column.key]"
        :placeholder="`请选择${column.title}`"
      >
        <Option
          v-for="item in selectOption"
          :key="item.value"
          :value="item.value"
          :label="item.label"
        />
      </Select>
    </template>
  </Table>
</template>

javascript部分

<script>
export default {
  data() {
    return {
      selectOption: [
        {
          value: "1",
          label: "四川省",
        },
        {
          value: "2",
          label: "广东省",
        },
      ],
      columns: [
        {
          title: "Name",
          key: "name",
          slot: "input",
        },
        {
          title: "Age",
          key: "age",
        },
        {
          title: "Address",
          key: "address",
          slot: "select",
        },
        {
          title: "Remark",
          key: "remark",
          slot: "input",
        },
      ],
      data: [
        {
          name: "John Brown",
          age: 18,
          address: "1",
          remark: "",
        },
        {
          name: "Jim Green",
          age: 24,
          address: "2",
          remark: "",
        },
        {
          name: "Joe Black",
          age: 30,
          address: "1",
          remark: "",
        },
        {
          name: "Jon Snow",
          age: 26,
          address: "1",
          remark: "1",
        },
      ],
    };
  },
  methods: {
    changeValue(column, val, index) {
      this.data[index][column.key] = val;
    },
    changeSelect(column, val, index) {
      this.data[index][column.key] = val;
    },
    handleKeyDown(event, row, key, name) {
      // ↑
      if (event.keyCode === 38) {
        if (row._index > 0) {
          this.changeCurrentRow(row, key, "-", name);
        }
      }
      // ↓
      if (event.keyCode === 40) {
        if (row._index + 2 <= this.data?.length) {
          this.changeCurrentRow(row, key, "+", name);
        }
      }
      // ->
      if (event.keyCode === 39) {
        if (key === "name") {
          this.$nextTick(() => {
            let e = document.querySelectorAll(".address")[row._index];
            e.querySelector(".ivu-select-input").focus();
          });
        } else if (key === "address") {
          this.$nextTick(() => {
            let e = document.querySelectorAll(".remark")[row._index];
            e.querySelector("input").focus();
          });
        }
      }
      // <-
      if (event.keyCode === 37) {
        if (key === "remark") {
          this.$nextTick(() => {
            let e = document.querySelectorAll(".address")[row._index];
            e.querySelector(".ivu-select-input").focus();
          });
        } else if (key === "address") {
          this.$nextTick(() => {
            let e = document.querySelectorAll(".name")[row._index];
            e.querySelector("input").focus();
          });
        }
      }
    },
    changeCurrentRow(row, key, type, name) {
      let curIndex = row._index;
      if (type === "+") {
        curIndex = row._index + 1;
      } else {
        curIndex = row._index - 1;
      }
      let changeRow = this.data[curIndex];
      this.$nextTick(() => {
        let e = document.querySelectorAll(`.${key}`)[curIndex];
        e.querySelector(name).focus();
      });
    },
  },
};
</script>
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于iview组件Input限制只能输入数字的问题,可以使用正则表达式来限制输入。根据引用\[2\]中的代码示例,可以在onKeydown方法中添加正则表达式的判断,只允许输入数字字符。代码示例如下: ```javascript export default { data() { return { input: '' } }, methods: { onKeydown(e) { let key = e.key if (key == 'e' || key == 'E' || key == '+' || key == '-') { e.returnValue = false } else if (!/^\d$/.test(key)) { e.returnValue = false } else { e.returnValue = true } } } } ``` 在这个示例中,使用正则表达式`/^\d$/`来判断输入的字符是否为数字。如果不是数字字符,则阻止输入。这样就可以限制iview组件Input只能输入数字了。 #### 引用[.reference_title] - *1* *3* [Element-ui input 输入框限制只能输入数字的问题](https://blog.csdn.net/qq_35430000/article/details/124818957)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [iview input限制只能输入数字,不能输入‘+‘/‘-‘/‘e‘/‘E‘](https://blog.csdn.net/weixin_47239395/article/details/131210495)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值