vue3-enter-to-tab
v3.1.5
Published
[![npm package][npm-img]][npm-url] [data:image/s3,"s3://crabby-images/7addd/7addd48ece27d7c4f0a84b5d62d544f17e074240" alt="Release"](https://github.com/l3d00m/vue3-enter-to-tab/actions/workflows/release.yml) [data:image/s3,"s3://crabby-images/1bb72/1bb7222c9008e18820de419606c837d05227aef6" alt="ci"
useEnterToTab(form)
</script>
Full example
See documentation below.
<template>
<div ref="form">
<input />
<input v-prevent-enter-tab />
</div>
</template>
<script setup lang="ts">
import { useEnterToTab } from 'vue3-enter-to-tab'
import { ref } from 'vue'
const form = ref<HTMLElement | null>(null)
const { vPreventEnterTab, isEnterToTabEnabled } = useEnterToTab(form, {
autoClickButton: false,
initialState: false,
})
// Read and change the status using that ref
isEnterToTabEnabled.value = true
</script>
Minimal example with options API
The code has not been tested yet and it is recommended to use the composition API instead.
<template>
<div ref="form"></div>
</template>
<script lang="ts">
import { defineComponent, ref } from 'vue'
import { useEnterToTab } from 'vue3-enter-to-tab'
export default defineComponent({
setup() {
useEnterToTab(this.$refs.form)
},
})
</script>
API: useEnterToTab(element, options?)
Input element
Type: HTMLElement | null
The parent element. This is where the event listener will be attached.
Enter key will be converted for all children input of this element, except for those with the v-prevent-enter-tab
directive and not including <textarea>
.
Input options
interface UseEnterToTabOptions {
autoClickButton?: boolean
initialState?: boolean
}
autoClickButton
If the next element is a button, it will be clicked. Activating this has the advantage that it's not necessary to press enter twice to click a button (often to submit the form).
Disable this if you don't want to click buttons automatically and instead just focus them like other inputs.
Default: true
initialState
Initial state of the function.
Default: true
Output vPreventEnterTab
Directive to use in those inputs you want to avoid use enter as tab. Inputs with this directive will act as normal when pressing enter.
Output isEnterToTabEnabled
Ref to read and change the status of the function.