首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何处理Vue3中的“Vue3”事件?

如何处理Vue3中的“Vue3”事件?
EN

Stack Overflow用户
提问于 2021-03-23 18:28:17
回答 1查看 4.9K关注 0票数 2

我有一个<Parent>组件,如果变量showModal为真,则呈现showModal组件。

变量showModal是在<Parent>组件的setup(){}函数中定义的。

当用户:

  1. 单击关闭按钮
  2. 当他们按下ESC按钮时

父组件

代码语言:javascript
复制
<template>
  <Modal v-if="isShownModal" @clickedModalClose="isShownModal=false" @keydown.esc="isShownModal=false">
  //removed some code for clarity purposes
</template>

<script>
export default {
  components: {Modal},
  setup(){

    const isShownModal = ref(false)
    ...

注意@clickedModalClose="isShownModal=false"@keydown.esc="isShownModal=false"

模态元件

代码语言:javascript
复制
<template>

  <div class="modal is-active">
    <div class="modal-background"></div>  
    
    <div class="modal-content box">
      <slot name="header"></slot>
      <slot name="body"></slot>  
    </div>
  
    <!-- Listen to a custom event @clicked-modal-close (v-on) --> 
    <button @click="$emit('clickedModalClose')" class="modal-close is-large" aria-label="close"></button>
  </div>
  
</template>

要关闭该模式,我将在子组件中单击“关闭”按钮并侦听该事件@clickedModalClose,并按预期正确关闭该模式时发出一个事件。

尽管如此,当我按下ESC按钮时,即使我在Modal组件上声明了事件处理程序:<Modal v-if="isShownModal" @clickedModalClose="isShownModal=false" @keydown.esc="isShownModal=false">,也不会发生任何事情。

我还尝试将@keydown.esc="closeTheModal()"附加到<Modal>中的DIV和template标记,然后在closeTheModal()函数中以编程方式发出clickedModalClose事件,但没有成功。

请找个人来解释一下这个问题好吗?

更新

正确的答案由@blackgreen给出。

在呈现组件之后,为了处理ESC事件,必须将该事件附加到组件中的DOM元素。

我所做的就是简单地使用Modal关闭按钮上的模板引用,使其在onMounted(){}钩子中可用,并在其上调用focus()方法。

父组件

代码语言:javascript
复制
<Modal @keydown.esc="isShownModal=false">

子组件

代码语言:javascript
复制
<template>
<button ref="closingButton" class="modal-close is-large" aria-label="close"></button>
</template>

在JS部分:

代码语言:javascript
复制
<script>
import {ref, onMounted} from 'vue';
export default {
  setup(props, context){
    
    const closingButton = ref(null)
    onMounted(()=>{
      closingButton.value.focus()
    })

    return {closingButton}

  }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-03-23 20:04:11

绑定@keydown.esc是正确的(示范性小提琴)。

但是,如果要实际触发事件,则声明侦听器的元素必须处于焦点位置。

这把小提琴示例中,mounted钩子使用tabindex=0设置<div>元素的焦点(使其具有焦点)。如果在该div聚焦时按Esc,您将看到计数器也在递增。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66769162

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档