vue-wl-context-menu

1.0.3 • Public • Published

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;
  }
}

Readme

Keywords

Package Sidebar

Install

npm i vue-wl-context-menu

Weekly Downloads

1

Version

1.0.3

License

ISC

Unpacked Size

6.4 kB

Total Files

4

Last publish

Collaborators

  • fredbedder