1.使用场景
data:image/s3,"s3://crabby-images/c9b26/c9b264577ad64029350c0c3030989076a2f0b139" alt=""
data:image/s3,"s3://crabby-images/35043/35043e4698cfec45e8928732dfb75a7a27fd80b5" alt=""
2.代码
1.给你的menu组件起个引用名
data:image/s3,"s3://crabby-images/52ef7/52ef7c166f6513b126b45b2174e3b8d222ad8275" alt=""
2.<Menu>组件需要一个MenuItem[]
data:image/s3,"s3://crabby-images/a874c/a874cb43a631de16bafd54149738375b9ada379c" alt=""
3.你要知道MenuItem[ ]的特殊的数据格式,就像TreeNode[ ]一样,数据格式不对是不渲染的。。。。
常用的属性就这几种,js语言和java不一样,Java靠类名识别类的数据结构
js靠数据结构来判断这个数据是哪一类型的。。。。也是很癫了,
这就是为什么在js里很少见到 声明一个对象{ }的类型,因为人家压根不cue,
换句话说,你把这个{ }的数据结构写的像什么对象,他就是什么对象。。。。。。。哪有类型
data:image/s3,"s3://crabby-images/ec3d2/ec3d27ea6d4f566294933865d9ed81d49d9f0292" alt=""
data:image/s3,"s3://crabby-images/9b847/9b8475453d1db2603360810a7ee9518581c088d2" alt=""
4.点击事件触发的函数要获取到本行的业务数据
data:image/s3,"s3://crabby-images/76268/76268688651c611b731da7d0537c467b58526906" alt=""
data:image/s3,"s3://crabby-images/08afd/08afd02581732c5081263396ce237b62d9c32367" alt=""
3.源码
data:image/s3,"s3://crabby-images/61b9f/61b9f8b2d7ee40a96453ec96428e92efe934a256" alt=""
toggle这个方法会隐式传递一个参数过去
data:image/s3,"s3://crabby-images/6b4e5/6b4e5ce41d2be192dffcdd2f73243299df4e3dde" alt=""
data:image/s3,"s3://crabby-images/cafbf/cafbfd41174fb115721f4e03d3c484433d9dd3bc" alt=""
类似用法
data:image/s3,"s3://crabby-images/3ffdd/3ffdd9526d95b7ddc49696922a3286741da94e44" alt=""
data:image/s3,"s3://crabby-images/1ef35/1ef352b8fc84010e6e846a67760fb376fdb29b0d" alt=""
4.语法
-
插槽(Slot)语法
<template #body="{ node }">
是Vue.js中的插槽语法。在Vue组件中,插槽用于在父组件中向子组件传递内容。这里的#body
表示具名插槽(named slot),它的名称是body
。- 花括号中的
{ node }
表示插槽作用域绑定。这意味着父组件在使用这个插槽时,可以将一个包含node
属性的数据对象传递给子组件中的这个插槽。
-
事件绑定语法
<Button type="button" icon="pi pi - ellipsis - v" @click="toggle(node,$event)" aria - haspopup="true" aria - controls="overlay_menu" />
- 这里的
@click
是Vue.js中的事件绑定指令。它绑定了一个名为toggle
的方法到按钮的click
事件上。 - 在
toggle
方法调用时,传递了node
变量和$event
。其中$event
是Vue.js自动提供的,表示触发事件的原生DOM事件对象,而node
是从插槽作用域绑定中获取的值。
-
:model
和:popup
属性绑定- 在
<Menu ref="menu" id="overlay_menu" :model="items" :popup="true"></Menu>
中,:
开头的属性是Vue.js中的动态属性绑定语法。 :model="items"
表示将组件内部的model
属性与父组件中的items
变量进行绑定。这里的items
应该是一个在父组件中定义的数据,它可能包含了Menu
组件所需要的菜单模型数据,例如菜单项的结构、标签、图标等信息。:popup="true"
将Menu
组件的popup
属性绑定为true
,这可能用于控制Menu
是否以弹出式的方式显示等功能。
- 在
5.点击事件发生时,事件对象会被隐式传递给点击事件所绑定的函数
data:image/s3,"s3://crabby-images/80ba9/80ba9ef5bafbd43787735f8a80086c5db5aeb05c" alt=""
data:image/s3,"s3://crabby-images/36a05/36a05e94f4970cac3aae82b06e64e2aaae016b97" alt=""
1.首先,为什么没有参数,却可以接到一个事件对象
1.隐式传递:只是原生事件PointerEvent
data:image/s3,"s3://crabby-images/28ac4/28ac4bc9d19c12bf3dcee9b503b1e665e6d80a07" alt=""
data:image/s3,"s3://crabby-images/592af/592af03d8fb52cbe883b47a53f28efaff2c7f236" alt=""
2.显式传递:也是原生事件PointerEvent。。。。
data:image/s3,"s3://crabby-images/36235/3623557ed6cee796c4fb505cb303eb7a3065413c" alt=""
data:image/s3,"s3://crabby-images/ec894/ec89457ad0ffdfe10ec94b45bf08215891124e2d" alt=""
1.原生事件:看一下调试,主要看target部分
data:image/s3,"s3://crabby-images/d2e25/d2e257ad7791c93c24908fa50668ee3ac104e880" alt=""