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

Vue按鈕權限的實現(xiàn)示例

 更新時間:2024年08月01日 08:51:56   作者:勇寶趣學前端  
在編寫Vue代碼的時候,經(jīng)常會碰到各種權限問題,本文主要介紹了Vue按鈕權限的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下

在編寫Vue代碼的時候,經(jīng)常會碰到各種權限問題,如:登錄權限、路由權限、按鈕權限等。今天我們就好好來說一說這個按鈕權限到底是怎么一回事。

一、概念

權限字面理解的意思就是權力限制,體現(xiàn)在日常業(yè)務開發(fā)中就是不同的角色對應不同的權力。打個比方:老師的權力是教書育人,醫(yī)生的權力是救死扶傷,律師的權力是懲惡揚善。

在我們的工作中,經(jīng)常有一些按鈕是需要特定的角色來操作的,比如刪除按鈕只有管理員可以看到。
嘮叨兩句:按鈕權限是我們開發(fā)中很重要的一環(huán),這個思想我們一定要掌握。這才是我們開發(fā)一個大型系統(tǒng)所必須的技能。

二、按鈕權限的方式

通過本章我講教給小伙伴們三種實現(xiàn)按鈕權限的方式:自定義指令、函數(shù)式渲染、v-if判斷。

關于按鈕權限的場景一般是這樣的:比如當我們登錄成功之后,后臺會返回給我們當前用戶對應的角色信息,可能是一個字符串,或者可能是一個字符串數(shù)組。這樣我們就可以通過角色信息來判斷是否渲染當前按鈕。

2.1 自定義指定

首先我們先使用自定義指令來演示一下我們上邊的業(yè)務功能。關于自定義指令如何書寫,我就不做過多的解釋,如果需要,以后會補充相關知識。

1、編寫template部分

<div class="container">
    <button>admin權限按鈕</button>
</div>

模板中button標簽是我們的權限按鈕

2、編寫自定義指定:el是我們掛載的元素,binging可以獲取傳入的值

<div class="container">
    <button v-permission="['admin', 'apadmin']">admin權限按鈕</button>
</div>

<script setup>
const vPermission = (el, binding) => {
    // 獲取角色數(shù)組
    const roles = binding.value;
    if (!roles.includes('admin')) {
        el.remove();
    }
}
<script>

注意:通過自定義指令來判斷當前角色是否為admin,如果不滿足條件我們就移除button標簽。

2.2 v-if

v-if和自定義指令類似,我們通過綁定一個函數(shù)通過返回值來判斷是否顯示當前的button標簽,具體代碼如下:

代碼實現(xiàn)

<div class="container">
    <button v-if="!isPermission()">admin權限按鈕</button>
</div>

<script setup>
// 1. 這里模擬后臺返回的角色權限列表
const roles = ['admin', 'apadmin'];

const isPermission = () => {
    let flag = false;
    if (!roles.includes('admin')) {
        flag = true;
    }
    return flag;
}

2.3 函數(shù)式渲染

這種方式不同于前兩種,它是通過一個函數(shù)來動態(tài)渲染插槽中的內容,這個就類似于我們寫一個組件。我認為這種方式要明顯好于前面兩種,尤其是v-if。

1、函數(shù)實現(xiàn)

我們創(chuàng)建一個PermComp.js文件,我們暴露出一個方法。

// PermComp.js 
import { getCurrentInstance } from 'vue';

export default ({ roles }) => {
    // 1. 獲取組件實例
    const instance = getCurrentInstance();
    if (roles.includes('admin')) {
        // 2. 渲染插槽內容
        return instance.slots && instance.slots.default();
    }
}

2、組件使用

<template>
    <div class="container">
        <PermComp :roles="roles">
            <button>admin權限按鈕</button>
        </PermComp>
    </div>
</template>
<script setup>
import PermComp from './views/test/components/PermComp.js';

// 后臺返回的角色權限列表
const roles = ['admin', 'apadmin'];
</script>

2.4 小結

這里演示了三種按鈕權限實現(xiàn)的方式,然后我有說到最后一個是我比較推薦的,為什么?
因為通過v-if的實現(xiàn)方式我們可以看到,根據(jù)Vue的生命周期我們發(fā)現(xiàn),v-if的執(zhí)行是在我們DOM掛載之后完成的,所以這樣會浪費性能。因為這個按鈕我們可能根本就不需要,但是我們會有一個掛載-> v-if判斷-> 卸載, 這么一個過程。

三、總結

到此這篇關于Vue按鈕權限的實現(xiàn)示例的文章就介紹到這了,更多相關Vue按鈕權限內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vuejs在解析時出現(xiàn)閃爍的原因及防止閃爍的方法

    vuejs在解析時出現(xiàn)閃爍的原因及防止閃爍的方法

    這篇文章主要介紹了vuejs在解析時出現(xiàn)閃爍的原因及防止閃爍的方法,本文介紹的非常詳細,具有參考借鑒價值,感興趣的朋友一起看看吧
    2016-09-09
  • vue組件中使用props傳遞數(shù)據(jù)的實例詳解

    vue組件中使用props傳遞數(shù)據(jù)的實例詳解

    這篇文章主要介紹了vue組件中使用props傳遞數(shù)據(jù)的實例詳解,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-04-04
  • vue自定義組件@click點擊失效問題及解決

    vue自定義組件@click點擊失效問題及解決

    這篇文章主要介紹了vue自定義組件@click點擊失效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 如何使用 vue-cli 創(chuàng)建模板項目

    如何使用 vue-cli 創(chuàng)建模板項目

    這篇文章主要介紹了如何使用 vue-cli 創(chuàng)建模板項目,幫助大家更好的理解和學習vue框架的知識,感興趣的朋友可以了解下
    2020-11-11
  • 在vue自定義組件中使用?v-model指令詳情

    在vue自定義組件中使用?v-model指令詳情

    這篇文章主要介紹了在vue自定義組件中使用?v-model指令詳情,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-06-06
  • Vite3結合Svelte3使用@import導入scss樣式

    Vite3結合Svelte3使用@import導入scss樣式

    這篇文章主要為大家介紹了Vite3結合Svelte3使用@import導入scss樣式實現(xiàn)實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • axios的interceptors多次執(zhí)行問題解決

    axios的interceptors多次執(zhí)行問題解決

    這篇文章主要為大家介紹了axios中interceptors多次執(zhí)行問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • vue使用原生js實現(xiàn)滾動頁面跟蹤導航高亮的示例代碼

    vue使用原生js實現(xiàn)滾動頁面跟蹤導航高亮的示例代碼

    這篇文章主要介紹了vue使用原生js實現(xiàn)滾動頁面跟蹤導航高亮的示例代碼,滾動頁面指定區(qū)域導航高亮。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • vue深入解析之render function code詳解

    vue深入解析之render function code詳解

    vue對大家來說應該再熟悉不過了,下面這篇文章主要給大家深入的解析了vue之render function code的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。
    2017-07-07
  • Vue.extend構造器的詳解

    Vue.extend構造器的詳解

    這篇文章主要介紹了Vue.extend構造器的詳解的相關資料,需要的朋友可以參考下
    2017-07-07

最新評論