题解 | #移动控制#

移动控制

http://www.nowcoder.com/practice/84af7932f53f4bbeaa1fa079a138bb35

function bind() {
    const con = document.getElementById('jsContainer')
    const rows = con.querySelectorAll('tr')
    const cols = rows[0].querySelectorAll('td')
    document.onkeydown = event => {
        if (!event) return;
        var code = event.keyCode || '';
        if (!{'37': 1, '38': 1, '39': 1, '40': 1}[code]) return;
        event.preventDefault && event.preventDefault();
        //TODO: 请实现按键控制
        const cur = con.querySelector('.current')
        let x = 0
        let y = 0
        Array.from(rows).forEach((tr,index) => {
            if(tr.contains(cur)){
                y = index
                Array.from(tr.querySelectorAll('td')).forEach((td,i)=>{
                    if(td === cur){
                        x = i
                    }
                })
            }
        })

        // 上
        if(Number(code) === 38){
            if(y === 0){
                y = rows.length - 1
            } else {
                y--
            }
        }
        // 下
        else if(Number(code) === 40){
            if(y === rows.length - 1){
                y = 0
            } else {
                y ++
            }
        }
        // 左
        else if(Number(code) === 37){
            if(x === 0){
                x = cols.length - 1
            } else {
                x--
            }
        }
        //右
        else if(Number(code) === 39){
            if(x === cols.length - 1){
                x = 0
            } else {
                x ++
            }
        }
        cur.classList.remove('current')
        rows[y].querySelectorAll('td')[x].classList.add('current')
    };
}
bind()
全部评论

相关推荐

11-18 09:44
Java
小白也想要offer:简历别放洋屁,搞不还还放错了,当然你投外企除外,以上纯属个人观点
点赞 评论 收藏
分享
9 收藏 评论
分享
牛客网
牛客企业服务