Bootstrap

vue表格回车切换到下一个input或select(回车代替tab功能)

简化版,后续有时间在完善,先提供一个思路。

如图
在这里插入图片描述

一、使用回车触发table中每一列input框代码如下

<!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></title>
    <script src="https://cdn.jsdelivr.net/npm/vue@2"></script>
    <!-- 引入样式 -->
    <link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
    <!-- 引入组件库 -->
    <script src="https://unpkg.com/element-ui/lib/index.js"></script>
</head>
<body>
    <div id="app">
        <button id="one" @click="alert('1')">点击事件</button>
       <table>
           <thead>
               <tr>
                   <th>姓名</th>
                   <th>年龄</th>
                   <th>地址</th>
                   <th>电话</th>
               </tr>
           </thead>
           <tbody>
                <tr v-for="(item,index) in tbodyData" :key="index">
                    <th>
                        <input v-model="item.name" class="name" @keyup="handleKeyup($event, index, 'name')"/>
                    </th>
                    <th>
                        <input v-model="item.age" class="age" @keyup="handleKeyup($event, index, 'age')"/>
                    </th>
                    <th>
                        <input v-model="item.address" class="address" @keyup="handleKeyup($event, index, 'address')"/>
                    </th>
                    <th>
                        <input v-model="item.phone" class="phone" @keyup="handleKeyup($event, index, 'phone')"/>
                    </th>
                </tr>
           </tbody>
       </table>
    </div>
    <script>
        var app = new Vue({
            el: '#app',
            data: {
                tbodyData: [
                    {
                        name: '',
                        age: '',
                        address: '',
                        phone: ''
                    },
                    {
                        name: '',
                        age: '',
                        address: '',
                        phone: ''
                    },
                    {
                        name: '',
                        age: '',
                        address: '',
                        phone: ''
                    },
                    {
                        name: '',
                        age: '',
                        address: '',
                        phone: ''
                    }
                ]
            },
            created() {

            },
            methods: {

                handleKeyup (event, index, key) {
                    let keyName = ['name', 'age', 'address', 'phone']
                    //获取页面元素
                    var id = document.getElementById('one');
                    console.log(id, 'id')
                    // *** 注意 *** 鼠标点击事件操作元素
                    // 原生中使用onclick 触发点击事件
                    // id.onclick = function(){
                    //     alert('Hello');
                    // }
                    // vue中使用click 触发点击事件
                    // id.click()
                    console.log(event, index, key, 'event, index, key')
                    // 左键
                    if (event.keyCode === 37) {
                     if (index === 0 && key === 'name') {
                            return
                        }
                        let num = 0
                        if (key === 'name') {
                            index -= 1
                            this.$nextTick(() => {
                                let doms = document.getElementsByClassName('phone')[index]
                                doms.focus()
                                doms.select()
                            })
                            return
                        }
                        keyName.forEach((v, i) => {
                            if (v === key) {
                                num = i - 1
                            }
                        })
                        this.$nextTick(() => {
                            let doms = document.getElementsByClassName(keyName[num])[index]
                            doms.focus()
                            doms.select()
                        })
                        return
                    }
                    // 向上键
                    if (event.keyCode === 38) {
                        // 获取到所有class为[key]的dom列表
                        let doms = document.getElementsByClassName(key)
                        console.log(doms, '向上键')
                        if (!index) {
                            index = this.tbodyData.length
                        }
                        // 选中类表中第index个,向上故而减1,dom里头包含的input,获取焦点以及选中input里的内容
                        let dom = doms[index - 1]
                        dom.focus()
                        dom.select()
                        return
                    }
                    // 向下键
                    if (event.keyCode === 40) {
                        let doms = document.getElementsByClassName(key)
                        console.log(doms, '向下键')
                        if (+index === this.tbodyData.length - 1) {
                            index = -1
                        }
                        let dom = doms[index + 1]
                        dom.focus()
                        dom.select()
                        return
                    }
                    // 小键盘回车键 回车到最后一位鼠标聚焦在第一行第一列
                    // if (event.keyCode === 13) {
                    // // 小键盘回车因为需要根据class判断下一个,故而有input输入框的全部需要在这按顺序声明
                    //     let keyName = ['name', 'age', 'address', 'phone']
                    //     let num = 0
                    //     if (key === keyName[keyName.length - 1]) {
                    //         console.log('this.tbodyData.length', this.tbodyData.length)
                    //         console.log('index', index)
                    //         if (index === this.tbodyData.length - 1) {
                    //             index = 0
                    //         } else {
                    //             ++index
                    //         }
                    //     } else {
                    //         keyName.map((v, i) => {
                    //             if (v === key) {
                    //                 num = i + 1
                    //             }
                    //         })
                    //     }
                    //     let doms = document.getElementsByClassName(keyName[num])[index]
                    //     console.log(doms, '小键盘回车键')
                    //     doms.focus()
                    //     doms.select()
                       
                    // } 
                    // 小键盘回车键 回车到最后一位鼠标聚焦在第一行第一列
                    if (event.keyCode === 13 || event.keyCode === 39) {
                        if (index === this.tbodyData.length - 1 && key === 'phone') {
                            this.tbodyData.push({
                                name: '',
                                age: '',
                                address: '',
                                phone: ''
                            })
                        }
                        let num = 0
                        if (key === keyName[keyName.length - 1]) {
                            if (index === this.tbodyData.length - 1) {
                                index = 0
                            } else {
                                ++index
                            }
                        } else {
                            keyName.map((v, i) => {
                                if (v === key) {
                                    num = i + 1
                                }
                            })
                        }
                        this.$nextTick(() => {
                            let doms = document.getElementsByClassName(keyName[num])[index]
                            console.log(doms, '小键盘回车键')
                            doms.focus()
                            doms.select()
                        })
                       
                    } 
                   
                }
            }
        })
    </script>
</body>
</html>

二、使用tab切换需要给每一列添加

<td tabindex="0" @focus="handleSubjectClick(item, index)"></td>
需要触发的div也添加 tabindex=“0”
<div v-if="!showDebit" tabindex="1"></div>
<input v-else v-model="name"/>
<script>
	function handleSubjectClick(){
		this.showDebit = true
	}
</script>									

本人观点:添加类名有一点繁琐,可以根据参考链接(2)中的第二种方法进行优化

1、如果列过多添加类名有点不实用
2、如果每列不固定展示,此时keyName就需要使用computed计算
举例:比如点击第二列,需要填写用户名,此时动态新增2列,需要填写邮箱,身份Id,那么此时就需要监听计算出所需要的列

需要考虑到的问题

1、会用到键盘对应的编码,
参考链接:https://www.cambiaresearch.com/articles/15/javascript-char-codes-key-codes.
2、在项目中会遇到 keyup.enter 和 blur 事件冲突的问题,
参考链接:https://blog.csdn.net/userkang/article/details/82755889.
keyup.enter 跟 blur 自己处理各自的事件,比如enter执行完只需要跳转到下一个表格,而blur只需要给金额添加小数点
3、使用@keyup事件,如果enter中有操作,那么用户输入内容一直会触发 keyup 事件,所以需要给keyup添加指定的键
例如:
(1)全部的键盘别名:
.enter
.tab
.delete (捕获 “删除” 和 “退格” 键)
.esc
.space
.up
.down
.left
.right
(2)还有一些组合按键:
.ctrl
.alt
.shift
(3).meta(window系统下是window键,mac下是command键)
Alt + C :
<input @keyup.alt.67=“doSth”>
Ctrl + Click :
( <div @click.ctrl=“doSth”>点我 )
原文链接:https://blog.csdn.net/fifteen718/article/details/80359844.

demo参考链接

1、参考链接:https://blog.csdn.net/qq_28353055/article/details/88573762.
2、参考链接:https://blog.csdn.net/weixin_43932097/article/details/112555955.

小伙伴们如果有好的建议,也请跟我留言。谢谢大家的关注

;