IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 封装树形控件为组件,后台管理分配权限并禁用。 -> 正文阅读

[JavaScript知识库]封装树形控件为组件,后台管理分配权限并禁用。

做个记录,可能不适用别人,但是能做个参考用。有问题私信

父组件

<!-- 权限分配弹窗 -->
<el-button type="primary" size="small" @click="openAuth(scope.row)">
     分配权限
</el-button>

<role-auth :data="current" :visible.sync="showAuth" />

  import RoleAuth from "./role-auth";
  
  components: {RoleAuth },
  
// 是否显示导入弹窗
     showAuth: false,
// 当前编辑数据
     current: null,
    /* 显示分配权限 */
    openAuth(row) {
      this.current = row;
      this.showAuth = true;
    },

子组件

<!-- 角色权限分配弹窗 -->
<template>
  <el-dialog
    title="分配权限"
    :visible="visible"
    width="400px"
    :destroy-on-close="true"
    :lock-scroll="false"
    @update:visible="updateVisible"
  >
    <el-scrollbar
      v-loading="authLoading"
      style="height: 50vh"
      wrapStyle="overflow-x: hidden;"
    >
      <el-tree
        ref="tree"
        :data="authData"
        :props="{ label: 'title' }"
        :check-strictly="checkStrictly"
        node-key="id"
        :default-expand-all="true"
        show-checkbox
      />
    </el-scrollbar>
    <div slot="footer">
      <el-button @click="updateVisible(false)">取消</el-button>
      <el-button type="primary" @click="save" :loading="loading"
        >保存
      </el-button>
    </div>
  </el-dialog>
</template>

<script>
import request from "@/utils/request";
import { getMenus } from "@/api/menu";

export default {
  name: "RoleAuth",
  props: {
    // 弹窗是否打开
    visible: Boolean,
    // 当前角色数据
    data: Object,
  },
  data() {
    return {
      // 权限数据
      authData: [],
      listone: [],
      list: [],
      // 权限数据请求状态
      authLoading: false,
      checkStrictly: false,
      // 提交状态
      loading: false,
    };
  },
  watch: {
    visible() {
      if (this.visible) {
        this.getRoutes();
        this.query();
        this.hanshu()
      }
    },
  },
  methods: {
    async getRoutes() {
      const res = await getMenus();
      this.authData = res.data;
    },
    hanshu() {
      let bb = this.data.roleList;
      for (let a of bb) {
      //需求是需要禁用多个角色的权限。
        this.jinyong(a.roleId);
      }
    },
    //禁用函数
    jinyong(e) {
      request.get(`role/resourceIds/${e}`).then((res) => {
        if (res.code == 0) {
          this.list = res.data.resourceIds;
          this.getDisabledData();
        }
      });
    },
    /**
     * 禁用节点
     * @param {*} data
     * @param {*} id 值不为undefined设置禁用节点;反之则清除禁用节点
     */
    setDisabledTreeData(data, id) {
      let val = id !== undefined ? true : false;
      data.map((item) => {
        if (id == undefined || item.id == id) {
          this.$set(item, "disabled", val);
        }
        let isFatherNode = item.children && item.children.length > 0;
        isFatherNode && this.setDisabledTreeData(item.children, id);
        let isHadDisabledChild =
          isFatherNode &&
          item.children.some((it) => it.disabled && it.disabled == val);
        if (isHadDisabledChild) this.$set(item, "disabled", val);
      });
    },
    /**
     * 获取有禁用节点的树数据
     */
    getDisabledData() {
      this.list.map((item) => this.setDisabledTreeData(this.authData, item));
    },
    /* 查询权限数据 */
    query() {
      this.authLoading = true;
      this.checkStrictly = true;
      request.get(`admin/resourceIds/${this.data.id}`).then((res) => {
        console.log(res, "看数据");
        this.authLoading = false;
        if (res.code === 0) {
          // this.$nextTick(() => {
          if (res.data) {
            this.listone = res.data;
            this.$refs.tree.setCheckedKeys(res.data);
            this.checkStrictly = false;
          } else {
            this.$refs.tree.setCheckedKeys([]);
          }
          // });
        }
      });
    },
    /* 保存权限分配 */
    save() {
      this.loading = true;
      let ids = this.$refs.tree
        .getCheckedKeys()
        .concat(this.$refs.tree.getHalfCheckedKeys());、
      request
        .post("admin/savePower", { adminId: this.data.id, resourceIds: ids })
        .then((res) => {
          this.loading = false;
          if (res.code === 0) {
            this.$message({ type: "success", message: "成功" });
            this.updateVisible(false);
          }
        })
        .catch((e) => {
          this.loading = false;
          this.$message.error(e.message);
        });
    },
    /* 更新visible */
    updateVisible(value) {
      this.$emit("update:visible", value);
    },
  },
};
</script>

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-14 09:51:45  更:2022-05-14 09:52:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 5:38:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码