Primero, quiero decir que soy nuevo en Vue, y este es mi primer proyecto usando Vue. Tengo un cuadro combinado y quiero hacer algo diferente en función del cuadro combinado seleccionado. Utilizo archivos vue.html y mecanografiado separados. Aquí está mi código.
<select name="LeaveType" @change="onChange()" class="form-control">
<option value="1">Annual Leave/ Off-Day</option>
<option value="2">On Demand Leave</option>
</select>
y aquí está mi archivo ts
onChange(value) {
console.log(value);
}
¿Cómo obtener el valor de la opción seleccionada en mi función de mecanografiado? Gracias.
@ es una opción de acceso directo para v-on . Utilice @ solo cuando desee ejecutar algunos métodos de Vue. Como no está ejecutando métodos Vue, en su lugar está llamando a la función javascript, debe usar el atributo onchange para llamar a la función javascript
<select name="LeaveType" onchange="onChange(this.value)" class="form-control"> <option value="1">Annual Leave/ Off-Day</option> <option value="2">On Demand Leave</option> </select> function onChange(value) { console.log(value); }
Si desea llamar a los métodos de Vue, hágalo así:
<select name="LeaveType" @change="onChange($event)" class="form-control"> <option value="1">Annual Leave/ Off-Day</option> <option value="2">On Demand Leave</option> </select> new Vue({ ... ... methods:{ onChange:function(event){ console.log(event.target.value); } } })
Puede utilizar el atributo de datos del modelo v en el elemento de selección para vincular el valor.
<select v-model="selectedValue" name="LeaveType" onchange="onChange(this.value)" class="form-control"> <option value="1">Annual Leave/ Off-Day</option> <option value="2">On Demand Leave</option> </select> new Vue({ data:{ selectedValue : 1, // First option will be selected by default }, ... ... methods:{ onChange:function(event){ console.log(this.selectedValue); } } })
Espero que esto ayude :-)
fuente
El valor cambiado estará en
event.target.value
const app = new Vue({ el: "#app", data: function() { return { message: "Vue" } }, methods: { onChange(event) { console.log(event.target.value); } } })
<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/vue.js"></script> <div id="app"> <select name="LeaveType" @change="onChange" class="form-control"> <option value="1">Annual Leave/ Off-Day</option> <option value="2">On Demand Leave</option> </select> </div>
fuente
También puedes usar v-model para el rescate.
<template> <select name="LeaveType" v-model="leaveType" @change="onChange()" class="form-control"> <option value="1">Annual Leave/ Off-Day</option> <option value="2">On Demand Leave</option> </select> </template> <script> export default { data() { return { leaveType: '', } }, methods: { onChange() { console.log('The new value is: ', this.leaveType) } } } </script>
fuente
Puede guardar su @ change = "onChange ()" y usar observadores. Vue calcula y observa, está diseñado para eso. En caso de que solo necesite el valor y no otros atributos de evento complejos.
Algo como:
... watch: { leaveType () { this.whateverMethod(this.leaveType) } }, methods: { onChange() { console.log('The new value is: ', this.leaveType) } }
fuente