前端js实现上下移动

<i
   class="el-icon-top"
   @click="changeIndex(-1,index)"
 />
  <i
   class="el-icon-bottom"
   @click="changeIndex(1,index)"
 />
 // 上移下移
    changeIndex (type, index) {
      console.log(type, index)
      let oldItem = {}
      let newItem = {}
      oldItem = this.dataList[index]
      newItem = this.dataList[index + type]
      if (index == 0 && type == -1) { // 第一位上移到最后一位
        newItem = this.dataList[this.dataList.length - 1]
        this.dataList[this.dataList.length - 1] = oldItem
      } else if ((index == this.dataList.length - 1) && type == 1) { // 最后一位到第一位
        newItem = this.dataList[0]
        this.dataList[0] = oldItem
      } else { 
        this.dataList[index + type] = oldItem
      }
      this.dataList[index] = newItem
      this.$forceUpdate()
    }
  }

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
前端实现上下左右方向键控制,可以通过监听`keydown`事件来实现。具体步骤如下: 1. 给需要控制的元素添加`tabindex`属性,让其可以获取焦点。 2. 给该元素绑定`keydown`事件,监听方向键的按下。 3. 在`keydown`事件处理函数中,根据按下的方向键修改元素的位置或状态。 4. 需要注意的是,在处理方向键时,要阻止浏览器默认的滚动行为。 以下是一个简单的示例代码,实现了通过方向键控制一个小方块的上下左右移动: ```html <div id="box" tabindex="0"></div> ``` ```css #box { width: 50px; height: 50px; background-color: red; position: absolute; top: 0; left: 0; } ``` ```javascript const box = document.getElementById('box'); const step = 10; box.addEventListener('keydown', e => { switch (e.keyCode) { case 37: // 左箭头 e.preventDefault(); // 阻止默认行为 box.style.left = `${parseInt(box.style.left) - step}px`; // 修改位置 break; case 38: // 上箭头 e.preventDefault(); box.style.top = `${parseInt(box.style.top) - step}px`; break; case 39: // 右箭头 e.preventDefault(); box.style.left = `${parseInt(box.style.left) + step}px`; break; case 40: // 下箭头 e.preventDefault(); box.style.top = `${parseInt(box.style.top) + step}px`; break; } }); ``` 在这个示例中,我们首先给小方块添加了`tabindex`属性,让其可以获取焦点。然后,在`keydown`事件处理函数中,我们根据按下的方向键修改小方块的位置,同时阻止了浏览器的默认滚动行为。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值