Fastadmin根据链接参数显示不同列表格

前端有不同的角色,我在后台设置了不同的菜单管理账号,如下图:

不同的账号表格中要展示不同的内容,要显示不同的列。

解决办法是在定义表格前获取url中的group_id参数,根据不同参数定义不同的表格。

代码如下:

javascript 复制代码
define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {

    var Controller = {
        index: function () {
            // 初始化表格参数配置
            Table.api.init({
                extend: {
                    //group_id的值传递给后台接口处理相应逻辑
                    index_url: 'user/user/index'+location.search,
                    add_url: 'user/user/add'+location.search,
                    edit_url: 'user/user/edit'+location.search,
                    del_url: 'user/user/del'+location.search,
                    multi_url: 'user/user/multi',
                    table: 'user',
                }
            });

            var table = $("#table");
            // 解析 URL 查询参数 获取group_id的值
            var queryParams = new URLSearchParams(location.search);
            var groupId = queryParams.get('group_id');

            if (groupId == 1) {
                // 学员表格
                table.bootstrapTable({
                    url: $.fn.bootstrapTable.defaults.extend.index_url,
                    pk: 'id',
                    sortName: 'user.id',
                    columns: [
                        [
                            {checkbox: true},
                            {field: 'id', title: __('Id'), sortable: true,operate:false},
                            {field: 'group.name', title: __('Group'),operate:false},
                            {field: 'username', title: __('Username'), operate: 'LIKE'},
                            {field: 'nickname', title: __('Nickname'), operate: 'LIKE'},
                            // {field: 'email', title: __('Email'), operate: 'LIKE'},
                            {field: 'mobile', title: __('Mobile'), operate: 'LIKE'},
                            {field: 'avatar', title: __('Avatar'), events: Table.api.events.image, formatter: Table.api.formatter.image, operate: false},
                            // {field: 'level', title: __('Level'), operate: 'BETWEEN', sortable: true},
                            // {field: 'gender', title: __('Gender'), visible: false, searchList: {1: __('Male'), 0: __('Female')}},
                            // {field: 'score', title: __('Score'), operate: 'BETWEEN', sortable: true},
                            // {field: 'successions', title: __('Successions'), visible: false, operate: 'BETWEEN', sortable: true},
                            // {field: 'maxsuccessions', title: __('Maxsuccessions'), visible: false, operate: 'BETWEEN', sortable: true},
                            // {field: 'logintime', title: __('Logintime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
                            // {field: 'loginip', title: __('Loginip'), formatter: Table.api.formatter.search},
                            {field: 'createtime', title: __('Createtime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
                            // {field: 'joinip', title: __('Joinip'), formatter: Table.api.formatter.search},
                            {field: 'status', title: __('Status'), formatter: Table.api.formatter.status, searchList: {normal: __('Normal'), hidden: __('Hidden')}},
                            {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
                        ]
                    ]
                });
            } else if (groupId == 2) {
                // 家长表格
                table.bootstrapTable({
                    url: $.fn.bootstrapTable.defaults.extend.index_url,
                    pk: 'id',
                    sortName: 'user.id',
                    columns: [
                        [
                            {checkbox: true},
                            {field: 'id', title: __('Id'), sortable: true,operate:false},
                            {field: 'group.name', title: __('Group'),operate:false},
                            {field: 'username', title: __('Username'), operate: 'LIKE'},
                            {field: 'nickname', title: __('Nickname'), operate: 'LIKE'},
                            // {field: 'email', title: __('Email'), operate: 'LIKE'},
                            {field: 'mobile', title: __('Mobile'), operate: 'LIKE'},
                            {field: 'avatar', title: __('Avatar'), events: Table.api.events.image, formatter: Table.api.formatter.image, operate: false},
                            // {field: 'level', title: __('Level'), operate: 'BETWEEN', sortable: true},
                            // {field: 'gender', title: __('Gender'), visible: false, searchList: {1: __('Male'), 0: __('Female')}},
                            // {field: 'score', title: __('Score'), operate: 'BETWEEN', sortable: true},
                            // {field: 'successions', title: __('Successions'), visible: false, operate: 'BETWEEN', sortable: true},
                            // {field: 'maxsuccessions', title: __('Maxsuccessions'), visible: false, operate: 'BETWEEN', sortable: true},
                            // {field: 'logintime', title: __('Logintime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
                            // {field: 'loginip', title: __('Loginip'), formatter: Table.api.formatter.search},
                            {field: 'createtime', title: __('Createtime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
                            // {field: 'joinip', title: __('Joinip'), formatter: Table.api.formatter.search},
                            {field: 'status', title: __('Status'), formatter: Table.api.formatter.status, searchList: {normal: __('Normal'), hidden: __('Hidden')}},
                            {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
                        ]
                    ]
                });
            } else if (groupId == 3)  {
                // 经销商表格
                table.bootstrapTable({
                    url: $.fn.bootstrapTable.defaults.extend.index_url,
                    pk: 'id',
                    sortName: 'user.id',
                    columns: [
                        [
                            {checkbox: true},
                            {field: 'id', title: __('Id'), sortable: true,operate:false},
                            {field: 'group.name', title: __('Group'),operate:false},
                            {field: 'username', title: __('Username'), operate: 'LIKE'},
                            {field: 'nickname', title: __('Nickname'), operate: 'LIKE'},
                            // {field: 'email', title: __('Email'), operate: 'LIKE'},
                            {field: 'mobile', title: __('Mobile'), operate: 'LIKE'},
                            {field: 'avatar', title: __('Avatar'), events: Table.api.events.image, formatter: Table.api.formatter.image, operate: false},
                            // {field: 'level', title: __('Level'), operate: 'BETWEEN', sortable: true},
                            // {field: 'gender', title: __('Gender'), visible: false, searchList: {1: __('Male'), 0: __('Female')}},
                            // {field: 'score', title: __('Score'), operate: 'BETWEEN', sortable: true},
                            // {field: 'successions', title: __('Successions'), visible: false, operate: 'BETWEEN', sortable: true},
                            // {field: 'maxsuccessions', title: __('Maxsuccessions'), visible: false, operate: 'BETWEEN', sortable: true},
                            // {field: 'logintime', title: __('Logintime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
                            // {field: 'loginip', title: __('Loginip'), formatter: Table.api.formatter.search},
                            {field: 'createtime', title: __('Createtime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
                            // {field: 'joinip', title: __('Joinip'), formatter: Table.api.formatter.search},
                            {field: 'status', title: __('Status'), formatter: Table.api.formatter.status, searchList: {normal: __('Normal'), hidden: __('Hidden')}},
                            {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
                        ]
                    ]
                });
            }else{
                // 体验账号表格
                table.bootstrapTable({
                    url: $.fn.bootstrapTable.defaults.extend.index_url,
                    pk: 'id',
                    sortName: 'user.id',
                    columns: [
                        [
                            {checkbox: true},
                            {field: 'id', title: __('Id'), sortable: true,operate:false},
                            {field: 'group.name', title: __('Group'),operate:false},
                            {field: 'username', title: __('Username'), operate: 'LIKE'},
                            {field: 'nickname', title: __('Nickname'), operate: 'LIKE'},
                            // {field: 'email', title: __('Email'), operate: 'LIKE'},
                            {field: 'mobile', title: __('Mobile'), operate: 'LIKE'},
                            {field: 'avatar', title: __('Avatar'), events: Table.api.events.image, formatter: Table.api.formatter.image, operate: false},
                            // {field: 'level', title: __('Level'), operate: 'BETWEEN', sortable: true},
                            // {field: 'gender', title: __('Gender'), visible: false, searchList: {1: __('Male'), 0: __('Female')}},
                            // {field: 'score', title: __('Score'), operate: 'BETWEEN', sortable: true},
                            // {field: 'successions', title: __('Successions'), visible: false, operate: 'BETWEEN', sortable: true},
                            // {field: 'maxsuccessions', title: __('Maxsuccessions'), visible: false, operate: 'BETWEEN', sortable: true},
                            // {field: 'logintime', title: __('Logintime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
                            // {field: 'loginip', title: __('Loginip'), formatter: Table.api.formatter.search},
                            {field: 'createtime', title: __('Createtime'), formatter: Table.api.formatter.datetime, operate: 'RANGE', addclass: 'datetimerange', sortable: true},
                            // {field: 'joinip', title: __('Joinip'), formatter: Table.api.formatter.search},
                            {field: 'status', title: __('Status'), formatter: Table.api.formatter.status, searchList: {normal: __('Normal'), hidden: __('Hidden')}},
                            {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
                        ]
                    ]
                });
            }


            // 为表格绑定事件
            Table.api.bindevent(table);
        },
        add: function () {
            Controller.api.bindevent();
        },
        edit: function () {
            Controller.api.bindevent();
        },
        api: {
            bindevent: function () {
                Form.api.bindevent($("form[role=form]"));
            }
        }
    };
    return Controller;
});
相关推荐
zhangyao9403306 小时前
开发pc端时,表格的高度怎么设置才能铺满页面
前端·javascript·elementui
XinZong7 小时前
实测OpenClaw虾淘:全民工具AI时代,冷门非工具类的Skill还能出圈吗?
javascript
烛衔溟7 小时前
TypeScript 类的类型 —— 作为类型使用
javascript·ubuntu·typescript
之歆7 小时前
Day16_JavaScript 轮播图与事件工程实战(下篇)
服务器·开发语言·前端·javascript·网络·性能优化
会Tk矩阵群控的小木7 小时前
云控系统在TikTok多账号管理中的核心应用与技术实现
开发语言·php·开源软件·个人开发·tk矩阵
kyriewen7 小时前
我关掉了Copilot:因为我写的代码出现在了别人的建议里
前端·javascript·ai编程
SmartRadio8 小时前
STM32WLE5 LoRa Smart TDMA 完整协议栈实现(工程级可直接编译)-【1】
javascript·stm32·单片机·嵌入式硬件·lora·自组网·smart tdma
傻啦嘿哟8 小时前
降低首字延迟(TTFB):专线节点与TCP Fast Open的配置
开发语言·php
竹林8188 小时前
用 wagmi v2 踩坑两天,我终于搞懂了多链钱包切换
前端·javascript
介一安全9 小时前
【漏洞学习】PHP+Windows环境通用文件上传漏洞深度剖析
windows·web安全·php·文件上传·安全性测试