Vue.js基础-10-监听子组件事件(v-on)、绑定子组件数据(v-model)
1. 监听子组件触发的事件(v-on)
说明
父组件可以在使用子组件的地方直接用 v-on 来监听子组件触发的事件
完整示例
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>CROW-宋</title> <script src="https://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script> </head> <body> <div id="app"> <div id="counter-event-example"> <p>蜀国新兵:{{ total }} 万</p> <!-- 打印三个按钮,每个绑定 "incrementTotal"以计算total值 --> <button-counter v-on:increment="incrementTotal"></button-counter> 汉中招兵<br> <button-counter v-on:increment="incrementTotal"></button-counter> 益州招兵<br> <button-counter v-on:increment="incrementTotal"></button-counter> 蜀郡招兵<br> </div> </div> <script> // 注册组件 Vue.component('button-counter', { //绑定incrementHandler函数以计算counter值,在按钮中打印counter值 template: '<button v-on:click="incrementHandler">{{ counter }}</button>', data: function () { return { counter: 0 } }, //为组件提供 counter的计算 methods: { incrementHandler: function () { this.counter += 1 //子组件中使用$emit方法调用该事件并传参 this.$emit('increment') } }, }) new Vue({ el: '#counter-event-example', data: { total: 0 }, methods: { incrementTotal: function () { this.total += 1 } } }) </script> </body> </html>
- 结果显示
2. 双向绑定prop和 子组件数据(v-model)
说明
组件上的 v-model 默认会利用名为 value 的 prop 和名为 input 的事件
完整示例
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>CROW-宋</title> <script src="https://cdn.staticfile.org/vue/2.2.2/vue.min.js"></script> </head> <body> <div id="app"> <we-input v-model="num"></we-input> <p>输入的数字为:{{num}}</p> </div> <script> Vue.component('we-input', { template: ` <p> <input ref="input" :value="value" @input="$emit('input', $event.target.value)" > </p> `, props: ['value'], }) new Vue({ el: '#app', data: { num: 100, } }) </script> </body> </html>
说明:
ref="input"
:获取input的值:value="value"
:
即v-bind:value 单向绑定data中的数据到input上(给input一个初始值,之后input改变,data不会跟随改变。)@input="$emit('input', $event.target.value)"
:
让父组件监听到自定义事件 $emit( eventName, […args] )
- 结果显示
分类:
前端开发 / vue框架学习
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?