Svelte 实现 keypress 快捷键功能

有些框架中内置了常用的事件修饰符和按键修饰符,例如:Vue 中就提供了按键 .enter.13),修饰键 .ctrl.alt.shift.meta等修饰符,简化了很多快捷键功能的实现。在 Svelte 中也提供了 preventDefaultstopPropagationonce 等事件修饰符,但是没有内置快捷键修饰符。

Svelte Keypress

一、Svelte 事件修饰符

Svelte 中使用 | 字符为 DOM 事件添加修饰符。可以使用的修饰符有:

修饰符作用
preventDefault在程序运行之前调用 event.preventDefault()
stopPropagation调用 event.stopPropagation(), 防止事件到达下一个标签
passive改善了 touch/wheel 事件的滚动表现(Svelte 会在合适的地方自动加上它)
capture表示在 capture 阶段而不是 bubbling 触发其程序
once程序运行一次后删除自身
self仅当 event.target 是其本身时才执行

例:带 once 修饰符的事件处理程序只运用一次。

<script>
  function handleClick() {
    alert('只提示一次')
  }
</script>

<button on:click|once={handleClick}>
  点击
</button>

二、Svelte 实现快捷键

<svelte:window> 标签允许你添加事件监听到 window 对象,从而不用担心移除它时 component 被毁,或者在服务端渲染时检查是否存在于 window。

实现 Esc 关闭弹窗和 Ctrl+S 提交保存的快捷键。

<svelte:window on:keydown={handleKeydown}/>

{#if show }
  <div class="box"></div>
{/if}
  
<script>
  let show = false
  
  function handleKeydown(e) {
    let {
      keyCode,
      ctrlKey,
    } = e
    // Esc 关闭
    if (keyCode===27) show = false
    // Ctrl + S 提交保存
    if (ctrlKey && keyCode === 83) {
      save()
      // 阻止浏览器默认的保存网页功能
      e.preventDefault()
    }
  }
  
  function save() {
    // do something
  }
</script>

欢迎访问:天问博客

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值