// OR
向父组件发出自定义事件
任何Web框架中的常见用例都是希望子组件能够向其父组件发出事件,这也是双向数据绑定原理。
常见一个示例是将数据从 input
组件发送到父表单。
根据我们使用的是Options API还是Composition API,发出事件的语法是不同的。
在 Options API 中,我们可以简单地调用this.$emit(eventName, payload)
,示例如下:
export default {
methods: {
handleUpdate: () => {
this.$emit(‘update’, ‘Hello World’)
}
}
}
但是,Composition API 使用方式与此不同。 需要在 Vue3 提供的 setup
方法使用emit
方法。
只要导入context对象,就可以使用与Options API相同的参数调用emit
。
export default {
setup (props, context) {
const handleUpdate = () => {
context.emit(‘update’, ‘Hello World’)
}
return { handleUpdate }
}
}
当然,我在项目中经常使用解构的方式来使用:
export default {
setup (props, { emit }) {
const handleUpdate = () => {
emit(‘update’, ‘Hello World’)
}
return { handleUpdate }
}
}
完美!
无论我们使用Options 还是 Composition API,父组监听的方式都是一样的。
<HelloWorld @update=‘inputUpdated’/>
首先,我们可以在模板中使用$ event访问传递的值。
如果在组件 emit 出去方法有传递值,我们可以通过两种不同的方式捕获它,这取决于我们是使用内联还是使用方法。
第一种是在模板中使用$event
访问传递的值。
<HelloWorld @update=‘inputUpdated($event)’/>
第二,使用方法来处理事件,则传递的值将作为第一个参数自动传递给我们的方法。
<HelloWorld @update=‘inputUpdated’/>
// …
methods: {
inputUpdated: (value) => {
console.log(value) // WORKS TOO
}
}
鼠标修饰符
下面是我们可以在v-on
指令中捕获的主要DOM鼠标事件列表:
@mousedown=‘handleEvent’
@mouseup=‘handleEvent’
@click=‘handleEvent’
@dblclick=‘handleEvent’
@mousemove=‘handleEvent’
@mouseover=‘handleEvent’
@mousewheel=‘handleEvent’
@mouseout=‘handleEvent’
Interact with Me!
对于单击事件,我们还可以添加鼠标事件修饰符来限制哪个鼠标按钮将触发我们的事件。有三个: left
,right
和 middle
。
键盘修饰符
我们可以听三个DOM键盘事件:
<input
type=‘text’
placeholder=‘Type something’
@keypress=‘handleKeyPressed’
@keydown=‘handleKeyDown’
@keyup=‘handleKeyUp’
/>
通常,我们想检测某个键上的这些事件,有两种方法可以执行此操作。
-
keycodes
-
Vue具有某些键的别名(
enter
,tab
,delete
,esc
,space
,up
,down
,left
,right
)
<input
type=‘text’
placeholder=‘Type something’
@keyup.enter=‘handleEnter’
/>
<input
type=‘text’
placeholder=‘Type something’
@keyup.13=‘handleEnter’
/>
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
2546)]
[外链图片转存中…(img-wqoDpPTK-1715680342546)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!