element 表格组件实现右键菜单

在 elment 表格组件上实现右键菜单功能

  • demo 示例:
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>右键菜单</title>
	</head>
	<!-- import CSS -->
	<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
	<style>
		.menuDiv {
			display: none;
			position: absolute;

		}

		.menuUl {
			height: auto;
			width: auto;
			font-size: 14px;
			text-align: left;
			border-radius: 4px;
			border: none;
			background-color: #ffffff;
			color: #606266;
			list-style: none;
			border: 1px solid #ebeef5;
			padding: 5px;

		}

		.menuUl li {
			height: 35px;
			line-height: 35px;
			padding: 0 10px;
			cursor: pointer;
			border-bottom: 1px solid rgba(255, 255, 255, 0.47);
		}

		.menuUl li:hover {
			display: block;
			background-color: #ecf5ff;
			color: #7abbff;
		}
	</style>
	<body>
		<div id="app">
			<el-table highlight-current-row :data="tableData" @row-click="clickRow" @row-contextmenu="right"
				style="width: 100%">
				<el-table-column prop="date" label="日期" width="180">
				</el-table-column>
				<el-table-column prop="name" label="姓名" width="180">
				</el-table-column>
				<el-table-column prop="address" label="地址">
				</el-table-column>
			</el-table>


			<div id="menu" class="menuDiv">
				<ul class="menuUl">
					<li v-for="(item, index) in menus" :key="index" @click.stop="infoClick(item)">
						<i :class="item.icon"></i> {{ item.name }}
					</li>
				</ul>
			</div>
		</div>



		<script src="https://unpkg.com/vue@2/dist/vue.js"></script>
		<!-- import JavaScript -->
		<script src="https://unpkg.com/element-ui/lib/index.js"></script>
		<script>
			new Vue({
				el: '#app',
				data: function() {
					return {
						visible: false,
						tableData: [{
							date: '2016-05-02',
							name: '王小虎',
							address: '上海市普陀区金沙江路 1518 弄'
						}, {
							date: '2016-05-04',
							name: '王小虎',
							address: '上海市普陀区金沙江路 1517 弄'
						}],
						menus: [{
								name: "菜单一",
								operType: 1,
								icon: "el-icon-upload2"
							},
							{
								name: "菜单二",
								operType: 2,
								icon: "el-icon-download"
							},
						],
					}
				},
				methods: {
					right(row, column, event) {
						console.log(row);
						console.log(column);
						console.log(event);
						event.preventDefault();
						let menu = document.querySelector("#menu");
						// 根据事件对象中鼠标点击的位置,进行定位
						menu.style.left = event.clientX + "px";
						menu.style.top = event.clientY + "px";
						// 改变自定义菜单的隐藏与显示
						menu.style.display = "block";
						menu.style.zIndex = 1000;

					},
					clickRow(row, column, event) {
						let menu = document.querySelector("#menu");
						menu.style.display = "none";
					},
					// 右击自定义菜单的点击事件
					infoClick(item) {
						console.log(item); 
						// 要做的事情

						let menu = document.querySelector("#menu");
						menu.style.display = "none";
					},
				}
			})
		</script>
	</body>
</html>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Element UI 中实现多级右键菜单可以通过自定义指令和事件监听来实现。下面是一个简单的示例: 首先,你需要创建一个自定义指令来监听鼠标右键事件,并在触发时显示菜单。可以在 `main.js` 文件中注册该指令: ```javascript import Vue from 'vue' import { Dropdown, DropdownMenu, DropdownItem } from 'element-ui' Vue.directive('contextmenu', { bind: function (el, binding, vnode) { el.addEventListener('contextmenu', function (event) { event.preventDefault() const dropdown = new Vue({ render: h => { return h(Dropdown, { props: { trigger: 'manual' }, on: { command: command => { vnode.context.$emit('command', command) dropdown.$destroy() } } }, [ h(DropdownMenu, null, binding.value.map(item => { return h(DropdownItem, { props: { command: item.command }, domProps: { innerHTML: item.label } }) })) ]) }, mounted() { this.$refs.dropdown.$el.style.position = 'fixed' this.$refs.dropdown.$el.style.left = `${event.clientX}px` this.$refs.dropdown.$el.style.top = `${event.clientY}px` this.$refs.dropdown.show() }, destroyed() { this.$refs.dropdown.hide() } }).$mount() document.body.appendChild(dropdown.$el) }) } }) ``` 然后,在你需要使用右键菜单组件中,使用 `v-contextmenu` 指令来绑定右键菜单的内容和事件: ```html <template> <div v-contextmenu="contextMenuItems" @command="handleCommand"> Right click me </div> </template> <script> export default { data() { return { contextMenuItems: [ { label: 'Item 1', command: 'item1' }, { label: 'Item 2', command: 'item2' }, { label: 'Submenu', children: [ { label: 'Subitem 1', command: 'subitem1' }, { label: 'Subitem 2', command: 'subitem2' } ] } ] } }, methods: { handleCommand(command) { console.log('Command:', command) } } } </script> ``` 在这个例子中,右键菜单的内容由 `contextMenuItems` 数组定义,每个菜单项包括 `label` 和 `command` 两个属性。当菜单项被点击时,将会触发 `@command` 事件,并将对应的 `command` 参数传递给 `handleCommand` 方法进行处理。 通过这种方式,你可以实现多级的右键菜单。当右键点击目标元素时,菜单会在鼠标位置显示,并且可以处理菜单项的点击事件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值