Implementation of element input box automatically getting focus

Implementation of element input box automatically getting focus

When making a form in a recent project, I need to automatically scroll to the comment box and make the comment box automatically focused, which requires manually triggering the focus state of the input box.

However, element does not support the autofocus attribute, so you can only get the focus effect through native js effects.

document.getElementById("input").focus();

Or you can use the ref attribute of vue to achieve the focusing effect:

The principle is actually very simple. Element already provides a focus method, but the documentation does not specify how to call it. The following is to add a ref attribute to the el-input tag, and then call the method directly where needed.

<el-input v-model="input" placeholder="Please enter content" ref="input"></el-input>
this.$nextTick(() => {
      this.$refs.input.focus()
    })

Note: A page can only have one focus effect

Last, vue also supports custom instructions

When the page loads, the element will receive focus (note: autofocus does not work on mobile Safari). In fact, as long as you haven't clicked anything since opening the page, the input box should still be in focus. Now let's implement this functionality using instructions:

// Register a global custom directive `v-focus`
Vue.directive('focus', {
  // When the bound element is inserted into the DOM...
  inserted: function (el) {
    // Focus element el.focus()
    //element-ui
    el.children[0].focus()
    // If the element changes, such as show or parent element changes, you can add a delay or judge setTimeout(_ => {
      el.children[0].focus()
    })
  }
})

Reference: vue custom directive https://cn.vuejs.org/v2/guide/custom-directive.html

This is the end of this article about how to automatically get the focus of the element input box. For more information about how to automatically get the focus of the element input box, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Solution for Vue form input box not supporting focus and blur events
  • Vue implements the fuzzy query method of Input input box
  • The input box in Vue does not focus after clicking

<<:  Implementation of nginx virtual host settings based on domain name, port, and different IP

>>:  Summary of HTML knowledge points for the front end (recommended)

Recommend

Introduction to query commands for MySQL stored procedures

As shown below: select name from mysql.proc where...

How to create a basic image of the Python runtime environment using Docker

1. Preparation 1.1 Download the Python installati...

UTF-8 and GB2312 web encoding

Recently, many students have asked me about web p...

JS code to achieve page switching effect

This article example shares the specific code of ...

Pure CSS implementation of radio and checkbox effect example

radio-and-checkbox Pure CSS to achieve radio and ...

Detailed explanation of how Vue components transfer values ​​to each other

Table of contents Overview 1. Parent component pa...

Code for aligning form checkbox and radio text

Alignment issues like type="radio" and t...

Installing Win10 system on VMware workstation 14 pro

This article introduces how to install the system...

Vue implements drag and drop or click to upload pictures

This article shares the specific code of Vue to a...

canvas.toDataURL image/png error handling method recommendation

Problem background: There is a requirement to tak...

Write a React-like framework from scratch

Recently I saw the article Build your own React o...

A brief introduction to VUE uni-app core knowledge

Table of contents specification a. The page file ...

Docker Stack deployment method steps for web cluster

Docker is becoming more and more mature and its f...