vue-focus

A reusable focus directive for reusable Vue.js components

  • Owner: simplesmiler/vue-focus
  • Platform:
  • License:: MIT License
  • Category::
  • Topic:
    vue
  • Like:
    0
      Compare:

Github stars Tracking Chart

vue-focus

A reusable focus directive for reusable Vue.js components

npm version

Overview

It can be tricky to manage input focus. You always have to fall back to accessing DOM elements and calling .focus or .blur on them.

Well not anymore. vue-focus lets you manage focus from the safety of your view model.

Check out the examples, read the docs or file an issue.

Use cases

  • Focus the field when the modal windows appears
  • Track the focus to show a hint for the focused field
  • Move between fields with cursor keys
  • Implement custom focus-related controls (e.g labels)

Requirements

  • vue: ^2.0.0

If you need a version for Vue 1, try vue-focus@1.0.

Install

From npm:

$ npm install vue-focus --save

From CDN:

<script src="https://cdnjs.cloudflare.com/ajax/libs/vue-focus/2.1.0/vue-focus.js"></script>
<!-- OR -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue-focus/2.1.0/vue-focus.min.js"></script>

API

focus

A directive that binds focus to the expression in a one-way manner, so that the element receives focus when the expression is truthy and loses focus when the expression is falsy.

import { focus } from 'vue-focus';

export default {
  directives: { focus: focus },
  template: '<input type="text" v-focus="focused" @focus="focused = true" @blur="focused = false">',
  data: function() {
    return {
      focused: false,
    };
  },
};

NOTE: As opposed to 1.x, in Vue 2.0, directives are updated every time the host component rerenders, not just when the directive expression chages. Somethimes this may be undesirable, especially for the "autofocus" use case. If you want to mimic the 1.x behavior, then add the .lazy modifier to the directive, e.g. v-focus.lazy="true".

mixin

A mixin that makes the v-focus directive available to the component under the default name.

import { mixin as focusMixin }  from 'vue-focus';

export default {
  mixins: [ focusMixin ],
  template: '<input type="text" v-focus="focused" @focus="focused = true" @blur="focused = false">',
  data: function() {
    return {
      focused: false,
    };
  },
};

Caveats

  1. Although you can write an input that gains focus immediately after loosing it, this is not recommended, as two such inputs will fall into infinite recursion and freeze the browser.

Notes

Form elements are not the only elements that are able to receive focus. The list also includes links, elements with tabindex attribute set and elements with contentEditable set to true.

License

MIT

Main metrics

Overview
Name With Ownersimplesmiler/vue-focus
Primary LanguageJavaScript
Program languageJavaScript (Language Count: 1)
Platform
License:MIT License
所有者活动
Created At2015-12-20 03:20:11
Pushed At2021-04-18 05:27:35
Last Commit At2017-02-22 09:24:42
Release Count8
Last Release Name2.1.0 (Posted on )
First Release Name0.1.0 (Posted on )
用户参与
Stargazers Count402
Watchers Count11
Fork Count40
Commits Count30
Has Issues Enabled
Issues Count17
Issue Open Count8
Pull Requests Count0
Pull Requests Open Count3
Pull Requests Close Count1
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private