Avue-curd个性化定制

12 篇文章 0 订阅

在使用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: "状态冻结",
        },
      ],

 

  • 3
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: avue-curd是一款基于Vue框架开发的快速开发平台,它为用户提供了一种简单易用的方式来实现预览与下载功能。要实现这两个功能,首先需要在后台管理系统中上传文件,并将文件信息存储到数据库中。 实现预览功能,可以通过引入第三方插件来完成。例如,使用Vue-pdf插件可以轻松地将PDF文件嵌入到网页中,并提供预览和打印功能。另外,使用Vue-player插件可以将音频和视频文件嵌入到网页中,也可以提供基本的控制功能,如播放、暂停和音量调节等。 实现下载功能也是比较简单的。我们可以在文件列表中为每个文件提供下载链接,这样用户只需点击链接即可下载对应的文件。另外,使用VUE中的ajax请求与后台进行交互,动态的获取可下载文件类型及位置信息。对下载的权限进行相关判断,确保文件暴露问题,同时可以加入防盗链等处理方式。 总之,avue-curd框架提供了丰富的工具和组件,可以轻松实现预览与下载功能,为用户提供更加全面和便捷的前端开发体验。 ### 回答2: avue-curd是一款前端生成页面的工具,它可以快速地生成一些常见的页面,比如CRUD(增删改查)页面。在avue-curd中实现预览与下载非常简单,只需要按照以下步骤操作即可。 首先,在avue-curd中生成相应的页面,包括需要预览或下载的内容。 然后,在生成的页面中添加预览和下载的功能。预览可以使用一些常见的插件,比如PDF.js插件或者video.js插件等。下载功能可以使用一些文件下载插件,比如FileSaver.js插件。 接着,在页面中添加按钮或链接,用于触发预览或下载功能。可以使用一些常见的UI框架,比如ElementUI或者Bootstrap,来添加按钮或链接。 最后,在相应的JavaScript文件中编写预览和下载的逻辑代码。可以通过Ajax请求获取预览或下载的内容,然后使用相关的插件进行处理并展示出来。 综上所述,avue-curd实现预览与下载非常简单,只需要按照以上步骤依次操作即可。同时,开发者也可以根据自己的需求修改相应的代码,来实现更加个性化的预览与下载功能。 ### 回答3: AVUE-CURD是一款基于Vue.js框架封装的通用增删改查组件,它集成了丰富的功能模块,包括预览与下载功能。 实现预览功能可以通过引入第三方组件,例如利用VueCropper组件实现图片的裁剪和压缩,利用vue-pdf组件实现PDF文件的预览等等。我们可以在AVUE-CURD组件内部的自定义列中进行配置,添加对应的预览组件,同时需要将需要预览的数据传入该组件中进行渲染。 实现下载功能也是类似的,可以利用第三方组件或者原生javascript,将需要下载的文件的数据、文件名等信息传入下载组件中,实现文件的下载。 总之,AVUE-CURD提供了丰富的接口和配置项,开发人员可以根据自身业务需求,快速实现预览与下载功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值