亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue 自定義右鍵樣式的實例代碼

 更新時間:2019年11月06日 14:18:56   作者:水君子  
這篇文章主要介紹了vue 自定義右鍵樣式的實例代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下

最近用python寫了個小說程序的api,想著用 vue 做個系統(tǒng)管理數(shù)據(jù),腦子里出現(xiàn)的是這個畫面:

 

但是這種樣式的管理后臺已經(jīng)做了太多了,已經(jīng)審美疲勞,后面又想了一種類操作系統(tǒng)的UI界面:

主要是靠 雙擊右鍵 來操作,可操作多個模態(tài)框,跟操作 windows 類似,接下來在里面拆出一個功能塊來寫一篇文章,就是 自定義系統(tǒng)默認(rèn)的右鍵 。

自定義右鍵操作有五個步驟: 阻止 默認(rèn)右鍵。 獲取當(dāng)前右鍵點擊時的 x / y 坐標(biāo),及 id 。 自定義右鍵菜單樣式及內(nèi)容,定位在指定的位置后顯示。 返回對應(yīng)點擊目錄的事件如: 查看 、 刪除 、 編輯 。 在任何地方點擊左鍵時 隱藏右鍵菜單 。 關(guān)鍵方法:

@contextmenu.prevent

這個是vue內(nèi)置的,點擊右鍵(阻止默認(rèn)右鍵的默認(rèn)行為)的一個回調(diào)方法,他返回了一大串東西這里我用到的是這兩個(用于定位顯示菜單的x,y位置)

x_index , y_index 是儲存在 data 中的,用于定位模態(tài)框位置。

ctrlId 用于給接口處理的依據(jù)

showMenu 用于判斷是否顯示右鍵菜單

<!--template-->
<ul>
  <li class="role_list" 
	v-for="(item,index) in role" 
	:key="index"
	@contextmenu.prevent="(e)=>{
		x_index = e.layerX;
	    y_index = e.layerY;
		ctrlId = item.id;
		showMenu = true;
	}">
	  <img :src="item.head_portrait" alt="">
	  <p>{{item.name}}</p>
	</li>
</ul>

需要的參數(shù)(x,y,id)都具備了,因為右鍵操作很多地方都用到了,所以封裝成了一個組件

right_menu.vue 組件代碼 參數(shù)名 注釋 x x坐標(biāo) y y坐標(biāo) showMenu 顯示狀態(tài)

參數(shù)名 注釋
x x坐標(biāo)
y y坐標(biāo)
showMenu 顯示狀態(tài)

組件使用

<template>
  <div class="modal_data_box">
    <ul>
      <li class="role_list" 
        v-for="(item,index) in role" 
        :key="index"
        @contextmenu.prevent="(e)=>{
          x_index = e.layerX;
          y_index = e.layerY;
          ctrlId = item.id;
          showMenu = true;
        }">
        <img :src="item.head_portrait" alt="">
        <p>{{item.name}}</p>
      </li>
    </ul>
	<!--組件-->
	<right-menu :x="x_index"
	      :y="y_index" 
	      :showMenu="showMenu"
	      @close="closeMenu"
	      @open="openDetail"
	      @del="delAttr"
	      @update="updateArr">
	</right-menu>
  </div>
</template>
<script>
  // 導(dǎo)入組件
	import rightMenu from '../module/right_menu.vue';
	export default{
		name:"roleModal",
		components:{rightMenu},
		data(){
			return {
				x_index:0,
				y_index:0,
				ctrlId:'',
				showMenu:false,
				role:[],
			}
		},
		methods:{
		  //關(guān)閉回調(diào) 
		  closeMenu(state){
		    console.log('關(guān)閉')
		    this.showMenu = state;
		  },
		  //打開詳情回調(diào) 			
		  openDetail(){
		    console.log('編輯')
		  },
		  //刪除回調(diào) 			
		  delAttr(){
		    console.log('刪除')
		  },
		  //編輯回調(diào) 			
		  updateArr(){
		    console.log('編輯')
		  },
		}
	}
</script>

修復(fù)漏洞

d[o_0]b同學(xué)發(fā)現(xiàn)了一個漏洞,就是當(dāng)鼠標(biāo)在屏幕右邊點擊時,菜單會被遮擋住,這邊做了一些調(diào)整。

修復(fù)前:

//原來的代碼
<ul>
  <li class="role_list" 
	v-for="(item,index) in role" 
	:key="index"
	@contextmenu.prevent="(e)=>{
		x_index = e.layerX;
	    y_index = e.layerY;
		ctrlId = item.id;
		showMenu = true;
	}">
	  <img :src="item.head_portrait" alt="">
	  <p>{{item.name}}</p>
	</li>
</ul>

修復(fù)后:

//修改后的代碼,(由于要判斷,所以單獨寫了個方法,把e跟item都傳過去)
<ul>
	<li class="role_list" 
		v-for="(item,index) in role" 
		:key="index"
		@contextmenu.prevent="(e)=>{
			rightClick(e,item)
		}">
		<img :src="item.head_portrait" alt="">
		<p>{{item.name}}</p>
	</li>
</ul>

//對應(yīng)的rightClick方法
rightClick(e,item){
	// 屏幕可見寬
	let clientWidth = document.body.clientWidth;
	// 菜單寬
	let menuWidth = 150;
	// 點擊右鍵時會返回對應(yīng)的clientX,用這個值與(clientWidth+菜單寬度)對比,如果大于的話,就把菜單左偏移一個菜單寬
	let clickClientX = e.clientX + menuWidth
	if(clickClientX > clientWidth){
		console.log("菜單超出視線范圍")
		this.x_index = e.layerX - menuWidth;
	}else{
		this.x_index = e.layerX;
	}
	this.y_index = e.layerY;
	this.ctrlId = item.id;
	this.showMenu = true;
},

總結(jié)

以上所述是小編給大家介紹的vue 自定義右鍵樣式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • Vue的export?default和帶返回值的data()及@符號的用法說明

    Vue的export?default和帶返回值的data()及@符號的用法說明

    這篇文章主要介紹了Vue的export?default和帶返回值的data()及@符號的用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 詳解Nuxt.js Vue服務(wù)端渲染摸索

    詳解Nuxt.js Vue服務(wù)端渲染摸索

    本篇文章主要介紹了詳解Nuxt.js Vue服務(wù)端渲染摸索,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • vite2打包的時候vendor-xxx.js文件過大的解決方法

    vite2打包的時候vendor-xxx.js文件過大的解決方法

    vite2是一個非常好用的工具,只是隨著代碼的增多,打包的時候?vendor-xxxxxx.js?文件也越來越大,本文主要介紹了vite2打包的時候vendor-xxx.js文件過大的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 如何為vue的項目添加單元測試

    如何為vue的項目添加單元測試

    這篇文章主要介紹了如何為vue的項目添加單元測試,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • vue定義私有過濾器和基本使用

    vue定義私有過濾器和基本使用

    這篇文章主要介紹的是 vue定義私有過濾器和基本使用,下面文章圍繞vue定義私有過濾器的相關(guān)資料展開內(nèi)容,需要的朋友可以參考一下,希望對大家有所幫助
    2021-11-11
  • 詳解vue-cli 腳手架項目-package.json

    詳解vue-cli 腳手架項目-package.json

    本篇文章主要介紹了詳解vue-cli 腳手架項目-package.json,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • vue v-model動態(tài)生成詳解

    vue v-model動態(tài)生成詳解

    本篇文章給大家分享了vue v-model動態(tài)生成的相關(guān)知識點以及實例代碼,有興趣的朋友參考學(xué)習(xí)下。
    2018-06-06
  • vue tab滾動到一定高度,固定在頂部,點擊tab切換不同的內(nèi)容操作

    vue tab滾動到一定高度,固定在頂部,點擊tab切換不同的內(nèi)容操作

    這篇文章主要介紹了vue tab滾動到一定高度,固定在頂部,點擊tab切換不同的內(nèi)容操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • antd form表單數(shù)據(jù)回顯操作

    antd form表單數(shù)據(jù)回顯操作

    這篇文章主要介紹了antd form表單數(shù)據(jù)回顯操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue引入jquery實現(xiàn)平滑滾動到指定位置

    Vue引入jquery實現(xiàn)平滑滾動到指定位置

    這篇文章主要介紹了Vue引入jquery實現(xiàn)平滑滾動到指定位置的效果,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-05-05

最新評論