弹出代理
当您需要在较大的屏幕上显示 QMenu,在较小的屏幕上显示 QDialog 时,您可以使用 QPopupProxy。它充当一个代理,可在两个组件中挑选一个使用。Qpopupproxy 还可以处理上下文菜单。
QPopupProxy API
target
: Boolean | String | Element
说明
配置一个目标元素来触发组件的切换;'true' 表示启用父级 DOM 元素,'false' 表示禁用将事件附加到任何 DOM 元素;通过使用字符串(CSS 选择器)或 DOM 元素,它会将事件附加到指定的 DOM 元素(如果存在)。
no-parent-event
: Boolean
说明
跳过将事件附加到目标 DOM 元素(触发元素显示)的步骤
context-menu
: Boolean
说明
允许组件像上下文菜单一样行为,通过右键点击(或在移动设备上长按)打开。
breakpoint
: Number | String
说明
窗口宽度/高度(取较小值)的断点(以像素为单位),当达到该断点时,将使用菜单而不是对话框。
用法
TIP
使用浏览器开发工具在移动设备或桌面设备之间切换(每次更改后都会刷新浏览器),或者在点击 QPopupProxy 组件的容器之前,调整浏览器窗口的大小,以观察 QPopupProxy 组件在 QMenu 或 QDialog 之间切换。默认断点设置为 450px。
标准
上下文菜单
断点
下面的实例中,点击输入框中的图标以查看效果。
透传属性
请注意,QMenu 和 QDialog 所有的属性都可以通过这个组件传递。所以类似 offset
或 transition-show
等属性也可以在 QPopupProxy 中使用。
settings_remoteperm_data_setting