vue-wl-context-menu
v1.0.3
Published
```js npm i vue-wl-context-menu ```
Downloads
10
Readme
vue-wl-context-menu 无依赖,超轻量鼠标右键菜单
安装
npm i vue-wl-context-menu
引用
import contextMenu from 'vue-wl-context-menu'
使用
Vue.use(contextmenu)
配置实例
mounted() {
this.contextmenuObj = this.wlContextmenu({
target: this.$refs.table,
config: [
{
title: '编辑',
slots:
'<div class="editBtn" ><i class="el-icon-edit"></i><span>编辑</span></div>',
handler(data) {
console.log(data)
}
},
{
title: '删除',
disable(data){
return data.date === '2016-05-01'
},
handler(data) {
console.log(data)
}
}
]
})
},
配置说明
this.wlContextmenu({
target: this.$refs.table,//触发右键dom,不选默认整个窗口触发
config:[//菜单配置
{
title: '编辑',//标题项
slots:'<div class="editBtn" ><i class="el-icon-edit"></i><span>编辑</span></div>',//插槽,与title不能共存,
handler(data) {//点击事件,data:为setData()传入参数,
console.log(data)
},
disable(data){ //禁用 , 传入一个函数,返回值布尔值, data:为setData()传入参数,
return data.date === '2016-05-01'
},
}
]
})
this.wlContextmenu()返回一个对象,该对象有setData()方法,常用于右键事件传入参数,例如表格右键事件传入
<!--element ui 表格组件-->
<el-table :data="tableData"
@row-contextmenu="contextmenu">
</el-table>
<!--其他框架用法类似-->
contextmenu(row, column, event) {
this.contextmenuObj.setData(row)
}
样式修改
.contentMenuContent .contentMenu .item {
min-width: 100px;
}
.contentMenuContent .contentMenu .item {
.editBtn { //slots插槽样式
height: 100%;
display: flex;
justify-content: space-between;
align-items: center;
}
}