• 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>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    二、Svelte 实现快捷键

    标签允许你添加事件监听到 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
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    欢迎访问:天问博客

  • 相关阅读:
    Android垃圾分类助手APP(Java+Android Studio+SQLite)
    Enzo大肠杆菌宿主细胞蛋白ELISA试剂盒——3小时内出结果!
    lua函数定义
    Go复合类型之数组类型
    springboot项目:前后端搭建
    【HMS core】【FAQ】Health Kit、In-App Purchases、Account Kit典型问题合集4
    ubuntu20.04开机运行java的sh脚本
    Java—简单斗地主(集合练习)
    css3中有哪些伪选择器?
    Simulation Studio - TRNSYS
  • 原文地址:https://blog.csdn.net/tiven_/article/details/127907331