1.0.1 • Published 4 years ago

contextmenu-vue v1.0.1

Weekly downloads
1
License
MIT
Repository
-
Last release
4 years ago

Contextmenu Vue

contextmenu developed by vue

install

yarn add contextmenu-vue

or

npm install contextmenu-vue

usage

<template>
  <div style="width:800px;height:800px" @contextmenu="handleContextmenu">
    <context-menu :show.sync="show" :menus="menus" @menuItemClick="handleMenuItemClick" :offset="contextMenuOffset">
      <template #create="menu">
        <div class="content">
          222{{menu.label}}
        </div>
      </template>
      <template #folder="menu">
        <div class="content">
          333{{menu.label}}
        </div>
      </template>
    </context-menu>
  </div>
</template>

<script>
import contextmenu from "vue-contextmenu"
export default {
  components: {
    ContextMenu,
  },
  data() {
    return {
      menus: [
        { 
          label: "刷新",  
          name: "refresh",
          children: [
            { 
              label: "刷新2"
            }
          ]
        },
        {
          label: "创建",
          name: "create",
          children: [
            { 
              label: "文件夹",
              name:"folder" 
            }
          ],
        },
      ],
      contextMenuOffset:{
        left:0,
        top:0
      },
      show:false
    };
  },
  methods:{
    handleContextmenu(e){
      e.preventDefault();
      this.contextMenuOffset.left = e.x;
      this.contextMenuOffset.top = e.y;
      this.show=true
    },
    handleMenuItemClick(menu){
      console.log(menu)
    }
  }
};
</script>

<style lang="less" scoped>
.content{
  padding: 2px 7px;
  user-select: none;
  &:hover {
    color: #fff;
    background: #1890ff;
  }
}
</style>

API

PropsDescriptionTypeDefault
show(sync)show or hidden contextBooleamfalse
offsetposition of contextObject { left: number, top:number}{left:0,top:0}
menuscontextmenu listArray[]

events

Events NameDescriptionArguments
menuItemClickCallback executed when the menu is clickedFunction(clickedMenuInfo)
1.0.1

4 years ago

1.0.0

4 years ago