I'm trying to trigger a function when I leave an input, but how I configured the input is by using vue-bootstrap-typehead
. By inspecting the input element in the DOM it would be structured like this:
<div id="myElement">
<div class="input-group input-group-sm">
<input type="search" autocomplete="off" class="form-control">
and this is my code:
<vue-bootstrap-typeahead
id="myElement"
v-model="plateNumberFilter"
:data="plateNumberOptions"
size="sm"
required
@blur="myFunctionIsnnotTriggered"
@hit="returnPlateNumberId()"
/>
I've tried adding the id="myElement"
on the typeahead itself but it puts the id
in the div
instead, which kinda makes sense, but I would've wanted it to be in the input
tag instead.
So I have 3 questions:
- How do I add an @blur on the input of
vue-bootstrap-typeahead
component? - How do I add an
id
in the input of avue-bootstrap-typeahead
component? - How do I add an eventListener in the
input
tag inside thevue-bootstrap-typeahead
component?
You don't need to answer 2 if you have an answer for 1 and so on. But it would be cool to have an answer to all 3 of them.
CodePudding user response:
The vue-typeahead-component
available events only include hit
and input
events, so you can't apply @blur
to the component itself.
To add an event listener on the inner <input>
of vue-bootstrap-typeahead
:
- Use a template ref on the
<vue-bootstrap-typeahead>
component. - From the ref, get its root DOM element via
vm.$el
. - Use
Element.querySelector()
to get the inner<input>
. - Use
EventTarget.addEventListener('blur', handler)
to listen to theblur
event on the<input>
.
<template>
<vue-bootstrap-typeahead ref="typeahead" 1️⃣ />
</template>
<script>
export default {
async mounted() {
await this.$nextTick()
this.$refs.typeahead.$el 2️⃣
.querySelector('input') 3️⃣
.addEventListener('blur', (e) => console.log('blur', e)) 4️⃣
},
}
</script>