Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 473|回复: 0

使用Jquery EasyUi常见问题解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-17 19:01:31 | 显示全部楼层 |阅读模式
    /**
    *清空指定表单中的内容,参数为目标form的id
    *注:在使用Jquery EasyUI的弹出窗口录入新增内容时,每次打开必须清空上次输入的历史
    *数据,此时通常采用的方法是对每个输入组件进行置空操作:$("#name").val(""),这样做,
    *当输入组件比较多时会很繁琐,产生的js代码很长,这时可以将所有的输入组件放入个form表单
    *中,然后调用以下方法即可。
    *
    *@param formId将要清空内容的form表单的id
    */
    function resetContent(formId) {
        var clearForm = document.getElementById(formId);
        if (null != clearForm && typeof (clearForm) != "undefined") {
            clearForm.reset();
        }
    }
    
    
    
    
    /**
    *刷新DataGrid列表(适用于Jquery Easy Ui中的dataGrid)
    *注:建议采用此方法来刷新DataGrid列表数据(也即重新加载数据),不建议直接使用语句
    *$('#dataTableId').datagrid('reload');来刷新列表数据,因为采用后者,如果日后
    *在修改项目时,要在系统中的所有刷新处进行其他一些操作,那么你将要修改系统中所有涉及刷新
    *的代码,这个工作量非常大,而且容易遗漏;但是如果使用本方法来刷新列表,那么对于这种修
    *该需求将很容易做到,而去不会出错,不遗漏。
    *
    *@paramdataTableId将要刷新数据的DataGrid依赖的table列表id
    */
    function flashTable(dataTableId) {
        $('#' + dataTableId).datagrid('reload');
    }
    
    
    
    
    
    
    
    /**
    *取消DataGrid中的行选择(适用于Jquery Easy Ui中的dataGrid)
    *注意:解决了无法取消"全选checkbox"的选择,不过,前提是必须将列表展示
    *数据的DataGrid所依赖的Table放入html文档的最全面,至少该table前没有
    *其他checkbox组件。
    *
    *@paramdataTableId将要取消所选数据记录的目标table列表id
    */
    function clearSelect(dataTableId) {
        $('#' + dataTableId).datagrid('clearSelections');
        //取消选择DataGrid中的全选
        $("input[type='checkbox']").eq(0).attr("checked", false);
    }
    
    
    
    
    
    
    
    /**
    *关闭Jquery EasyUi的弹出窗口(适用于Jquery Easy Ui)
    *
    *@paramdialogId将要关闭窗口的id
    */
    function closeDialog(dialogId) {
        $('#' + dialogId).dialog('close');
    }
    
    
    
    
    
    
    
    /**
    *自适应表格的宽度处理(适用于Jquery Easy Ui中的dataGrid的列宽),
    *注:可以实现列表的各列宽度跟着浏览宽度的变化而变化,即采用该方法来设置DataGrid
    *的列宽可以在不同分辨率的浏览器下自动伸缩从而满足不同分辨率浏览器的要求
    *使用方法:(如:{field:'ymName',title:'编号',width:fillsize(0.08),align:'center'},)
    *
    *@parampercent当前列的列宽所占整个窗口宽度的百分比(以小数形式出现,如0.3代表30%)
    *
    *@return通过当前窗口和对应的百分比计算出来的具体宽度
    */
    function fillsize(percent) {
        var bodyWidth = document.body.clientWidth;
        return (bodyWidth - 90) * percent;
    }
    
    /**
    * 获取所选记录行(单选)
    *
    * @paramdataTableId目标记录所在的DataGrid列表的table的id
    * @paramerrorMessage 如果没有选择一行(即没有选择或选择了多行)的提示信息
    *
    * @return 所选记录行对象,如果返回值为null,或者"null"(有时浏览器将null转换成了字符串"null")说明没有
    *选择一行记录。
    */
    function getSingleSelectRow(dataTableId, errorMessage) {
        var rows = $('#' + dataTableId).datagrid('getSelections');
        var num = rows.length;
        if (num == 1) {
            return rows[0];
        } else {
            $.messager.alert('提示消息', errorMessage, 'info');
            return null;
        }
    }
    
    
    
    
    
    
    
    /**
    * 在DataGrid中获取所选记录的id,多个id用逗号分隔
    * 注:该方法使用的前提是:DataGrid的idField属性对应到列表Json数据中的字段名必须为id
    * @paramdataTableId目标记录所在的DataGrid列表table的id
    *
    * @return 所选记录的id字符串(多个id用逗号隔开)
    */
    function getSelectIds(dataTableId, noOneSelectMessage) {
        var rows = $('#' + dataTableId).datagrid('getSelections');
        var num = rows.length;
        var ids = null;
        if (num < 1) {
            if (null != noOneSelectMessage) $.messager.alert('提示消息', noOneSelectMessage, 'info');
            return null;
        } else {
            for (var i = 0; i < num; i++) {
                if (null == ids || i == 0) {
                    ids = rows.id;
                } else {
                    ids = ids + "," + rows.id;
                }
            }
            return ids;
        }
    }
    
    
    
    
    
    
    
    /**
    *删除所选记录(适用于Jquery Easy Ui中的dataGrid)(删除的依据字段是id)
    *注:该方法会自动将所选记录的id(DataGrid的idField属性对应到列表Json数据中的字段名必须为id)
    *动态组装成字符串,多个id使用逗号隔开(如:1,2,3,8,10),然后存放入变量ids中传入后台,后台
    *可以使用该参数名从request对象中获取所有id值字符串,此时在组装sql或者hql语句时可以采用in
    *关键字来处理,简介方便。
    *另外,后台代码必须在操作完之后以ajax的形式返回Json格式的提示信息,提示的json格式信息中必须有一个
    *message字段,存放本次删除操作成功与失败等一些提示操作用户的信息。
    *
    *@paramdataTableId将要删除记录所在的列表table的id
    *@paramrequestURL与后台服务器进行交互,进行具体删除操作的请求路径
    *@paramconfirmMessage 删除确认信息
    */
    
    
    
    
    function deleteNoteById(dataTableId, requestURL, confirmMessage) {
        if (null == confirmMessage || typeof (confirmMessage) == "undefined" || "" == confirmMessage) {
            confirmMessage = "确定删除所选记录?";
        }
        var rows = $('#' + dataTableId).datagrid('getSelections');
        var num = rows.length;
        var ids = null;
        if (num < 1) {
            $.messager.alert('提示消息', '请选择你要删除的记录!', 'info');
        } else {
            $.messager.confirm('确认', confirmMessage, function (r) {
                if (r) {
                    for (var i = 0; i < num; i++) {
                        if (null == ids || i == 0) {
                            ids = rows.id;
                        } else {
                            ids = ids + "," + rows.id;
                        }
                    }
                    $.getJSON(requestURL, { "ids": ids }, function (data) {
                        if (null != data && null != data.message && "" != data.message) {
                            $.messager.alert('提示消息', data.message, 'info');
                            flashTable(dataTableId);
                        } else {
                            $.messager.alert('提示消息', '删除失败!', 'warning');
                        }
                        clearSelect(dataTableId);
                    });
                }
            });
        }
    }

     

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 21:45 , Processed in 0.114887 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表