vue如何在表格中實現(xiàn)右鍵菜單
前言
最近公司的管理系統(tǒng)又要添加新功能,需求是為表格數(shù)據(jù)添加右鍵菜單,操作當(dāng)前選中行的屬性。
剛開始想的是直接控制DOM樹生成一個HTML編寫的菜單,掛載到右鍵點擊的位置。
但是我覺得vue這么強大,肯定有右鍵組件,肯定比自己寫的好看。
不查不知道,一查居然發(fā)現(xiàn)vue原生支持右鍵菜單,當(dāng)機立斷,用原生右鍵菜單。
安裝
npm install vue-contextmenujs
一、實現(xiàn)效果
老規(guī)矩,先來個成果圖,有需要再往下看。

二、使用步驟
1、表格實現(xiàn)
我的表格用的是avue-crud,暫時不詳細(xì)介紹這個表格組件了,總之就是功能很強大,比el-table強大的多。
下邊的屬性介紹一下:
page:表格的頁碼顯示,包括currentPage、pageSize、total等等。data:表格數(shù)據(jù)option:表格屬性配置v-loading:加載動畫@row-contextmenu:對表格數(shù)據(jù)的右鍵操作@size-change:對每頁展示多少條數(shù)據(jù)的改變操作@current-change:翻頁操作@select:選中操作@select-all:全選操作
<avue-crud ref="crud" :page.sync="detailPage" :data="tableData" :option="tableOption" v-loading="loading" @row-contextmenu="handleContextMenu" @size-change="sizeChange" @current-change="currentChange" @select="handleSelect" @select-all="handleSelectAll"> </avue-crud>
這些操作可以參考avue官網(wǎng),具體怎么設(shè)置先不細(xì)說了,主要介紹右鍵菜單。
和右鍵菜單對應(yīng)的就是@row-contextmenu方法,監(jiān)聽了對表格數(shù)據(jù)的右鍵點擊事件。
我們在這個方法里綁定生成菜單的函數(shù),我這里起的名字是handleContextMenu
2、生成右鍵菜單
表格做好了,右擊事件也綁定好了,接下來就是生成右鍵菜單。
handleContextMenu(item, index) {
this.$contextmenu.destroy();
this.$contextmenu({
items: [
{
label: "屬性",
onClick: () => {
// 記錄當(dāng)前右鍵操作
store.commit("SET_RIGHT_TYPE", "viewResourceNature");
this.$refs.attrBox.visible = true;
},
},
{
label: "標(biāo)簽設(shè)置",
icon: "el-icon-discount",
disabled: !(current.Editable),
onClick: () => {
// 記錄當(dāng)前右鍵操作
store.commit("SET_RIGHT_TYPE", "setPictureTag");
this.setTag(item);
},
},
{
label: "電子圖冊",
divided: true,
onClick: () => {
// 記錄當(dāng)前右鍵操作
store.commit("SET_RIGHT_TYPE", "electronicAtlas");
this.$refs.electronicBox.visible = true;
},
children: [
{
label: "截取可視化區(qū)域",
onClick: () => {
this.message = "截取可視化區(qū)域";
}
},
{ label: "截取全屏" }
]
},
{
label: "渠道名稱設(shè)置",
onClick: () => {
// 記錄當(dāng)前右鍵操作
store.commit("SET_RIGHT_TYPE", "abilityNames");
this.$refs.abnBox.visible = true;
},
}
],
event,
customClass: "resource-context-menu",
zIndex: 999,
minWidth: 200,
});
return false;
}
生成右鍵菜單要調(diào)用this.$contextmenu()方法。參數(shù)是一個對象:基本包含以下屬性:
{
// 菜單內(nèi)容
item:[],
// 自定義樣式
customClass: "resource-context-menu",
// 層級
zIndex: 999,
// 最小寬度
minWidth: 200,
}
從我的例子也能看出來,最重要的是item屬性,配置的是右鍵菜單中的每一項。
item中可以設(shè)置:
- 菜單名稱:label:“菜單名稱”
- 菜單前置圖標(biāo):icon:“el-icon-discount”
- 菜單底部分割線:divided:true
- 菜單點擊事件:onClick: () => {}
- 子菜單:children:[]
每次生成新的右鍵菜單前,先把舊的銷毀。
this.$contextmenu.destroy();
3、監(jiān)聽鼠標(biāo)滾動事件,清除右鍵菜單
突然發(fā)現(xiàn)有這么個問題:當(dāng)列表數(shù)據(jù)過多時,我們需要滾動表格去查看下面的數(shù)據(jù),這時候右鍵菜單的位置就和表格的數(shù)據(jù)對不上了。
這時候需要加個鼠標(biāo)滾動事件的監(jiān)聽,當(dāng)鼠標(biāo)滾輪事件發(fā)生時,清除右鍵菜單。
代碼實現(xiàn)如下:
mounted() {
// 先把瀏覽器自帶的右鍵功能屏蔽掉
this.$nextTick(() => {
// 禁止右鍵
document.oncontextmenu = new Function("event.returnValue=false");
});
// 監(jiān)聽頁面滾動事件
window.addEventListener('scroll', this.handleScroll, true)
},
beforeDestroy() {
// 離開頁面時,清除頁面滾動事件
window.removeEventListener('scroll', this.handleScroll, true)
this.$nextTick(() => {
// 放開對瀏覽器右鍵的禁止
document.oncontextmenu = new Function();
});
},
methods: {
// 頁面滾動時清除右鍵菜單,避免位置混淆
handleScroll () {
this.$contextmenu.destroy();
}
}
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue中數(shù)組與對象修改觸發(fā)頁面更新的機制與原理解析
這篇文章主要介紹了Vue中關(guān)于數(shù)組與對象修改觸發(fā)頁面更新的機制與原理簡析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-12-12
解決vue+router路由跳轉(zhuǎn)不起作用的一項原因
這篇文章主要介紹了解決vue+router路由跳轉(zhuǎn)不起作用的一項原因,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
Vue.js使用computed屬性實現(xiàn)數(shù)據(jù)自動更新
在Vue組件中,computed屬性是在組件的選項對象中聲明的,你可以把它們想象成組件的一個小功能,告訴Vue當(dāng)某些數(shù)據(jù)變化時,如何更新界面,本文給大家介紹了Vue.js使用computed屬性實現(xiàn)數(shù)據(jù)自動更新,需要的朋友可以參考下2024-06-06

