An article teaches you how to implement VUE multiple DIVs and button binding enter events

An article teaches you how to implement VUE multiple DIVs and button binding enter events

There is currently a requirement that an operation is performed when the OK button is clicked or the keyboard enter is pressed, which is needed in many places.

I tried several methods but none of them worked.

First, I bound the @keyup.enter method to the div (button as well), but it had no effect at all. Then I followed the method on the Internet and wrote it like this:

<div class="btn submit" @keyup.enter="submit" @click="submit">Confirm (Ent)</div>
created(){
   document.onkeydown = function(e) {
     if(e.keyCode == 13){
       console.log("Call the method that needs to be executed"); 
     }
   }
 },

This can indeed implement the carriage return event, but it is global, that is, when you press the enter key in other components, the carriage return event here will also be called. This method does not work.

Then I did this:

1. Add an <input> tag between the OK button and the Cancel button (placing it in the middle can serve as a spacer between the buttons, so there is no need to write margin-left), and then add the @keyup.enter event to this input tag;

<template slot="footer">
        <div class="dialog-footer dis-flex">
          <div class="btn cancel" @click="showDialog = false">Cancel (Esc)</div>
          <input
            type="text"
            ref="inputdata"
            class="hiddenIpt"
            @keyup.enter="submit"
          />
          <div class="btn submit" @click="submit">
            Confirm (Ent)
          </div>
        </div>
</template>

2. Write a listener to automatically focus the input box when the pop-up window is opened (inputdata is bound to the input with ref).

watch:
    showDialog() {
      if (this.showDialog) {
        //this.$refs.inputdata.focus(); Wrong way to write this.$nextTick(() => {//Correct way to write this.$refs.inputdata.focus();
        });
      }
    },
  },

3. Hide the input box (set the width to be used as the interval between the OK button and the Cancel button.)

.hiddenIpt {
    width: 2rem;
    opacity: 0;
  }

This is the perfect solution. If you have a better solution, welcome to communicate with us.

Summarize

This article ends here. I hope it can be helpful to you. I also hope that you can pay more attention to more content on 123WORDPRESS.COM!

You may also be interested in:
  • Vue2.x obtains data from QQ music API through the backend interface proxy
  • Detailed explanation of proxy access to data in Vue source code
  • VUE Getting Started Learning Event Handling
  • Vue3 Vue Event Handling Guide
  • Detailed explanation of VUE's data proxy and events

<<:  dl, dt, dd list label examples

>>:  How to create your own Docker image and upload it to Dockerhub

Recommend

How to write a Node.JS version of a game

Table of contents Overview Build Process Related ...

Vue uses monaco to achieve code highlighting

Using the Vue language and element components, we...

Detailed explanation of how to configure openGauss database in docker

For Windows User Using openGauss in Docker Pull t...

Binary Type Operations in MySQL

This article mainly introduces the binary type op...

Understanding render in Vue scaffolding

In the vue scaffolding, we can see that in the ne...

How to block and prohibit web crawlers in Nginx server

Every website usually encounters many non-search ...

JavaScript+html to implement front-end page sliding verification (2)

This article example shares the specific code of ...

5 Reasons Why Responsive Web Design Isn’t Worth It

This article is from Tom Ewer's Managewp blog,...

Solution to Nginx session loss problem

In the path of using nginx as a reverse proxy tom...

Database SQL statement optimization

Why optimize: With the launch of the actual proje...

Linux kernel device driver system call notes

/**************************** * System call******...

How to solve the problem that MySQL cannot start because it cannot create PID

Problem Description The MySQL startup error messa...

Docker batch start and close all containers

In Docker Start all container commands docker sta...

The reason why MySQL uses B+ tree as its underlying data structure

We all know that the underlying data structure of...