Bootstrap

Avue-curd个性化定制

在使用vue(js)+elelment(ui)开发一些后台管理项目的时候,基本会用到 列表页,条件搜索(search),表格数据(table),分页,操作栏的,增、删、改、查几种操作。如下图这样的:

很多的页面都很类似,这里就给大家介绍一个,我自己最近研究的一个插件 avue-curd;整体的一个模块,包含列表,增、删、改、查;还可以通过slot插巣自定义局部组件内容

如下面,我按照产品自定义:隐藏了搜索模块、操作栏(这些都是可配置的)

上代码:主页面

<!--列表-->
<template>
  <div class="execution">
    <basic-container>
      <avue-crud
        ref="crud"
        v-model="form"
        :page="page"
        :data="tableData"
        :permission="permissionList"
        :table-loading="tableLoading"
        :option="tableOption"
        @on-load="getList"
        @refresh-change="refreshChange"
        @size-change="sizeChange"
        @current-change="currentChange"
        @row-update="handleUpdate"
      >
        <template slot-scope="scope" slot="menu">
          <el-link
            v-if="scope.row.status == -1"
            icon="el-icon-edit"
            type="primary"
            @click.stop="handleEdit(scope.row, scope.index)"
            >审核</el-link
          >
        </template>
        <template slot="statusForm">
          <el-form-item style="margin-bottom: 0px">
            <el-radio-group
              @change="changeRequire"
              v-model="form.status"
              size="small"
            >
              <el-radio border label="0">审核通过</el-radio>
              <el-radio border label="-2">审核拒绝</el-radio>
            </el-radio-group>
          </el-form-item>
        </template>
        <template slot="status" slot-scope="scope">
          <span v-if="scope.row.status == 0" style="color: #67c23a"
            >审核通过</span
          >
          <span v-if="scope.row.status == -1" style="color: #409eff"
            >待审核</span
          >
          <span v-if="scope.row.status == -2" style="color: #f56c6c"
            >审核拒绝</span
          >
        </template>
      </avue-crud>
    </basic-container>
  </div>
</template>

<script>
import { tenantPage, checkObj } from "@/api/admin/tenant";
import { tableOption } from "@/const/crud/admin/approval";
import { mapGetters } from "vuex";

export default {
  name: "Tenant",
  data() {
    return {
      tableData: [],
      searchForm: {},
      form: {},
      page: {
        total: 0, // 总页数
        currentPage: 1, // 当前页数
        pageSize: 20, // 每页显示多少条
      },
      tableLoading: false,
      tableOption: tableOption,
    };
  },
  computed: {
    ...mapGetters(["permissions"]),
    permissionList() {
      return {
        editBtn: this.vaildData(this.permissions.admin_systenant_edit, false),
      };
    },
  },
  methods: {
    handleEdit(row, index) {
      this.$refs.crud.rowEdit(row, index);
    },
    changeRequire(e) {
      if (e == "-2") {
        this.$refs.crud.formRules.rejectReason[0].required = true;
      } else {
        this.$refs.crud.formRules.rejectReason[0].required = false;
      }
    },
    getList(page, params) {
      this.tableLoading = true;
      tenantPage(
        Object.assign(
          {
            current: page.currentPage,
            size: page.pageSize,
          },
          params,
          this.searchForm
        )
      )
        .then((response) => {
          this.tableData = response.data.data.records;
          this.page.total = response.data.data.total;
          this.tableLoading = false;
        })
        .catch(() => {
          this.tableLoading = false;
        });
    },
    rowDel: function (row, index) {
      var _this = this;
      this.$confirm("是否确认删除机构名称为:" + row.name, "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning",
      })
        .then(function () {
          return delObj(row.id);
        })
        .then((data) => {
          _this.$message.success("删除成功");
          this.getList(this.page);
        });
    },
    // 编辑弹窗确定
    handleUpdate: function (row, index, done, loading) {
      console.log(123321);
      checkObj(row)
        .then((data) => {
          this.$message.success("修改成功");
          done();
          this.getList(this.page);
        })
        .catch(() => {
          loading();
        });
    },
    searchChange(form, done) {
      this.searchForm = form;
      this.page.currentPage = 1;
      this.getList(this.page, form);
      done();
    },
    refreshChange() {
      this.getList(this.page);
    },
    sizeChange(pageSize) {
      this.page.pageSize = pageSize;
    },
    currentChange(current) {
      this.page.currentPage = current;
    },
  },
};
</script>

引用配置表格配置字段option

/*
 *   列表表格数据字段信息
 */
var validatePhone = (rule, value, callback) => {
  const reg = /^1[3|4|5|7|8|9][0-9]{9}$/;
  if (reg.test(value)) {
    callback();
  } else {
    callback(new Error("手机号格式不正确"));
  }
};
var validateEmail = (rule, value, callback) => {
  const reg = /^([a-zA-Z]|[0-9])(\w|\-)+@[a-zA-Z0-9]+\.([a-zA-Z]{2,4})$/;
  if (reg.test(value)) {
    callback();
  } else {
    callback(new Error("邮箱格式不正确"));
  }
};
var dicStatus = [
  {
    value: "0",
    label: "审核通过",
    type: "status_type",
    description: "审核通过"
  },
  {
    value: "-2",
    label: "审核拒绝",
    type: "status_type",
    description: "审核拒绝"
  },
  {
    value: "-1",
    label: "待审核",
    disabled: true,
    type: "status_type",
    description: "待审核"
  }
];
export const tableOption = {
  border: true,
  index: true,
  indexLabel: "序号",
  stripe: true,
  menuAlign: "center",
  align: "center",
  labelWidth: 120, // 弹出框表单lable宽度
  span: 24, // 弹出框表单项
  dialogWidth: 600, // 弹出框宽度
  addBtn: false, // 添加按钮
  columnBtn: false, // 列显隐按钮
  delBtn: false, // 行内删除按钮
  refreshBtn: false, // 刷新按钮
  editBtn: false, // 表格编辑按钮
  editBtnText: "审核",
  editTitle: "租户注册审核",
  menuWidth: 150,
  // menu: false, // 隐藏菜单
  column: [
    {
      label: "ID",
      prop: "id",
      editDisabled: true,
      editDisplay: false,
      addDisplay: false
    },
    {
      label: "机构名称",
      prop: "name",
      width: 200,
      editDisabled: true,
      rules: [
        { required: true, message: "请输入机构名称", trigger: "blur" },
        { min: 3, max: 32, message: "长度在 3 到 32 个字符", trigger: "blur" }
      ]
    },
    {
      label: "租户编号",
      prop: "code",
      editDisabled: true,
      editDisplay: false,
      addDisplay: false
    },
    {
      label: "联系人账号",
      prop: "contactUsername",
      width: 120,
      hide: true,
      editDisplay: false,
      addDisplay: false,
      rules: [
        {
          required: true,
          message: "请输入联系人",
          trigger: "blur"
        }
      ]
    },
    {
      label: "联系人姓名",
      prop: "contactRealName",
      width: 120,
      editDisabled: true,
      addDisplay: false,
      rules: [
        {
          required: true,
          message: "请输入联系人",
          trigger: "blur"
        }
      ]
    },
    {
      label: "手机号",
      prop: "contactPhone",
      width: 150,
      editDisabled: true,
      addDisplay: false,
      rules: [
        {
          required: true,
          message: "请输入手机号",
          trigger: "blur"
        },
        {
          validator: validatePhone,
          trigger: "blur"
        }
      ],
      editDisabled: true
    },
    {
      label: "邮箱",
      prop: "contactEmail",
      width: 180,
      editDisabled: true,
      addDisplay: false,
      rules: [
        {
          required: true,
          message: "请输入邮箱",
          trigger: "blur"
        },
        {
          validator: validateEmail,
          trigger: "blur"
        }
      ]
    },
    {
      label: "审核状态",
      prop: "status",
      type: "radio",
      border: true,
      dicData: dicStatus,
      addDisplay: false,
      formslot: true,
      typeslot: true,
      slot: true,
      rules: [
        {
          required: true,
          message: "请选择审核状态",
          trigger: "blur"
        }
      ]
    },
    {
      label: "提交时间",
      prop: "createTime",
      width: 180,
      type: "datetime",
      format: "yyyy-MM-dd hh:mm:ss",
      valueFormat: "yyyy-MM-dd hh:mm:ss",
      rules: [
        {
          required: true,
          message: "请输入创建时间",
          trigger: "blur"
        }
      ],
      editDisabled: true,
      addDisplay: false,
      editDisplay: false
    },
    {
      label: "拒绝原因",
      prop: "rejectReason",
      editDisabled: false,
      addDisplay: false,
      hide: true,
      rules: [
        {
          required: false,
          message: "请输入拒绝原因",
          trigger: "blur"
        }
      ]
    }
  ]
};

具体的配置可以自己看avue-curd的文档配置:https://www.bookstack.cn/read/avue-2.x/391487d752fdf241.md

官方文档地址:https://avuejs.com/doc/crud/crud-doc

再结合solt的使用,你就可以实现以下,个性化的配置了。

<!----------------------------------------------------2020.12.15此处更新一处,crud里面自定义搜索项,本例子已状态项status为例 ------------------------------->

需求是列表上方的状态需要加个全部的选项,如下图

如果直接修改数据源改成这样的

var dicStatus = [
  {
    value: null,
    label: "全部",
    type: "status_type",
    description: "全部"
  },
  {
    value: "0",
    label: "正常",
    type: "status_type",
    description: "状态正常"
  },
  {
    value: "9",
    label: "冻结",
    type: "status_type",
    description: "状态冻结"
  }
];

新增或者编辑回显的时候,就是出现尴尬的一幕,如下图,不需要全部啊,

因为avue-crud里面,所有的封装的参数项都是,同一出处;这里就需要搜索框自定义了,search: true,  searchslot: true, 代码如下:

<avue-crud
        ref="crud"
        v-model="form"
        :page="page"
        :data="tableData"
        :permission="permissionList"
        :table-loading="tableLoading"
        :option="tableOption"
        :search.sync="search" // 此处绑定搜索条件
        @on-load="getList"
        @search-change="searchChange"
        @refresh-change="refreshChange"
        @size-change="sizeChange"
        @current-change="currentChange"
        @row-update="handleUpdate"
        @row-save="handleSave"
        @row-del="rowDel"
        @sort-change="sortChange"
      >
        <template slot="status" slot-scope="scope">
          <el-tag v-if="scope.row.status == 0">正常</el-tag>
          <el-tag v-if="scope.row.status == 9" type="info">冻结</el-tag>
          <el-tag v-if="scope.row.status == -1" type="warning">待审核</el-tag>
          <el-tag v-if="scope.row.status == -2" type="danger">审核拒绝</el-tag>
        </template> 
        // 此处注意slot是 参数名字(status)+ Search
        <template slot="statusSearch" slot-scope="scope">
          <el-select v-model="search.status" placeholder="请选择">
            <el-option
              v-for="item in statusOptions"
              :key="item.value"
              :label="item.label"
              :value="item.value"
            >
            </el-option>
          </el-select>
        </template>
      </avue-crud>



// data()里面新增search,这是crud搜索条件的集合
 search: {},
 statusOptions: [
        {
          value: null,
          label: "全部",
          type: "status_type",
          description: "全部",
        },
        {
          value: "0",
          label: "正常",
          type: "status_type",
          description: "状态正常",
        },
        {
          value: "9",
          label: "冻结",
          type: "status_type",
          description: "状态冻结",
        },
      ],

 

;