jQuery+EasyUI实现treegrid/datagride所绑定列只能够输入数字,且保留N位小数

本文详细介绍了如何使用EasyUI datagrid的可编辑列只允许输入数字,并保留两位小数的操作方法,包括在表头设置要求和通过Ajax获取JSON数据源的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

关于jQuery和EasyUI我就不多做介绍了,都是JS框架,而EasyUI是建立在jQuery的基础之上的框架而已。用过EasyUI的童鞋可能都很习惯性地使用过其treegrid和datagride。这两个东西比asp.net内的列表控件DataTable、Repeater好用多了的。treegrid和datagrid的最大特征就是灵活性够强,数据源都是通过Ajax页面获取,以Json格式返回。

        有些时候,我们在项目中需要对treegrid和datagrid的可编辑列的格式有所要求,比如我只能够输入汉字、只能够下拉选择等等。这里就以datagrid的可编辑列只允许输入数字,且保留两位小数为例:

或许一说到这个问题,很多人都会选择直接在table内绑定列,如下:      

 $('#table').datagrid({

                rownumbers: "true", idField: "L_ID", treeField: "L_NAME", nowrap: false, animate: true,

                collapsible: true, loadMsg: "加载数据,请稍候...", singleSelect: true,

                columns: [[

        {

            field: 'L_NAME',

            title: '组织节点名称',

            width: 200

        },

        {

            field: 'L_USERS',

            title: '成员',

            width: 400

        }

    ]]

            });
就是直接利用JS往table内附加行的方式,但是如果要在列上要求我只能够输入数字,且保留2为小数或许就不行了吧。这里我采用了是如下:

1、先在table内加上表头,在表头的指定列说明其要求。如下:

        <table id="table">
        <thead>
            <tr>
                <th field = "USER_NAME" width="200">
                    成员名称
                </th>
                <th field = "U_WORK" width="100" editor="{type:'numberbox',options:{precision:2}}">
                   工作量比重
                </th>
            </tr>
        </thead>
        </table>
2、然后在将ajax返回过来的Json数据格是以数据源的形式附加到table上,当对某行某列进行编辑的时候,此时的格式要求就会生效。

3、说明:type:numberbox 说明类型为数据类型     options:{precision:2} 说明保留两位小数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值