mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-12 12:25:16 +08:00
1.7 KiB
1.7 KiB
Manually Positioned
For some special case, you may want to manually position the dropdown. For example, right click to activate dropdown in some area.
<div style="width: 200px; height: 200px; background-color: rgba(0, 128, 0, .5);" @contextmenu="handleContextMenu">
Right Click
</div>
<n-dropdown
placement="bottom-start"
trigger="manual"
manually-positioned
@select="handleSelect"
@blur="handleBlur"
:x="x"
:y="y"
:options="options"
:show="showDropdown"
/>
const options = [
{
label: 'Jay Gatsby',
key: 'jay gatsby'
},
{
label: 'Daisy Buchanan',
key: 'daisy buchanan'
},
{
type: 'divider'
},
{
label: 'Nick Carraway',
key: 'nick carraway'
},
{
type: 'submenu',
label: 'Others',
key: 'others',
children: [
{
label: 'Jordan Baker',
key: 'jordan baker'
},
{
label: 'Tom Buchanan',
key: 'tom buchanan'
},
{
type: 'submenu',
label: 'Others',
key: 'others',
children: [
{
label: 'Chicken',
key: 'chicken'
},
{
label: 'Beef',
key: 'beef'
}
]
}
]
}
]
export default {
methods: {
handleSelect (name) {
this.showDropdown = false
this.$NMessage.info(name)
},
handleBlur () {
this.showDropdown = false
},
handleContextMenu (e) {
e.preventDefault()
this.showDropdown = false
this.$nextTick().then(() => {
this.showDropdown = true
this.x = e.clientX
this.y = e.clientY
})
}
},
data () {
return {
options,
showDropdown: false,
x: 0,
y: 0
}
}
}