[ligerUI] grid行编辑示例

摘要:
ligerugrid的行编辑示例具有添加和删除行的功能。修改单元格后,如果输入错误,可以提醒用户。

ligerui grid行编辑示例,具备新增行、删除行功能,可在修改某个cell之后,如果录入错误,可以提醒用户。

<%@ page contentType="text/html; charset=UTF-8" %>
<%
    String path = request.getContextPath();
%>
<!DOCTYPE html>
<HTML>
<HEAD>
    <TITLE> ZTREE DEMO - Simple Data</TITLE>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8">
    <SCRIPT type="text/javascript">
        var contextpath = "<%=path%>";
    </SCRIPT>
    <style type="text/css">
    .myul li{float:left;width:100px;display:inline;}
    </style>
    <link href="<%=path %>/frameworks/ligerUI/skins/Aqua/css/ligerui-all.css" rel="stylesheet" type="text/css" />
    <script src="<%=path %>/frameworks/jquery/jquery-1.4.4.min.js" type="text/javascript"></script>  
    <script src="<%=path %>/frameworks/ligerUI/js/core/base.js" type="text/javascript"></script>      
    <script src="<%=path %>/frameworks/ligerUI/js/plugins/ligerDialog.js" type="text/javascript"></script>
    <script src="<%=path %>/frameworks/ligerUI/js/plugins/ligerTextBox.js" type="text/javascript"></script>
    <script src="<%=path %>/frameworks/ligerUI/js/plugins/ligerCheckBox.js" type="text/javascript"></script>
    <script src="<%=path %>/frameworks/ligerUI/js/plugins/ligerComboBox.js" type="text/javascript"></script>
    <script src="<%=path %>/frameworks/ligerUI/js/plugins/ligerGrid.js" type="text/javascript"></script>
    <script src="<%=path %>/frameworks/ligerUI/js/plugins/ligerDateEditor.js" type="text/javascript"></script>
    <script src="<%=path %>/frameworks/ligerUI/js/plugins/ligerSpinner.js" type="text/javascript"></script>
    <script src="<%=path %>/frameworks/ligerUI/js/plugins/ligerResizable.js" type="text/javascript"></script>
    <script src="<%=path %>/js/json2.js" type="text/javascript"></script>   
    <script src="<%=path %>/js/uuid.js" type="text/javascript"></script> 
    <SCRIPT type="text/javascript">
        var manager, g;
        $(document).ready(function(){
            $("#leafOpt").click(function(){
                $("#urlDom").show();
            });
            $("#dirOpt").click(function(){
                $("#urlDom").hide();
            });
            //初始化grid
            function itemclick(item)
            {
                alert(item.text);
            }
            var typeData = [{ val: 'url', text: 'URL' }, { val: 'btn', text: '按钮'}, { val: 'code', text: '分级编码'}];
            var rowData = { Rows: []};
            g =  manager = $("#maingrid").ligerGrid({
                columns: [
                { display: '名称', name: 'name', align: 'left',  120,editor: { type: 'text' } } ,
                { display: '类型',  60, name: 'type',
                    editor: { type: 'select', data: typeData, valueColumnName: 'val' },
                    render: function (item)
                    {
                        for (var i = 0; i < typeData.length; i++)
                        {
                            if (typeData[i]['val'] == item.type)
                                return typeData[i]['text']
                        }
                    }
                },
                { display: '', name: 'value',  360, align: 'left',editor: { type: 'text' } }
                ], sortName: 'name',enabledEdit: true, data: rowData,
                onSelectRow: function (rowdata, rowindex)
                {
                    $("#txtrowindex").val(rowindex);
                },
                onBeforeEdit: onBeforeEdit, onBeforeSubmitEdit: onBeforeSubmitEdit,onAfterEdit: onAfterEdit,
                 '98%', height: '350', usePager: false, clickToEdit: true, checkbox: true
            });
        });
        function deleteRow()
        {
            g.deleteSelectedRow();
        }
        function addNewRow()
        {
            g.addRow({
                id : 0,
                name:'',
                type:'url',
                value:''
            });
        }
        //设置name前缀
        function onBeforeEdit(e)
        {
            var data = manager.getData();
 
            return true;
        }
        //限制年龄
        function onBeforeSubmitEdit(e)
        {
            if (e.columnname == "Age")
            {
                if (e.value < 20 || e.value > 30) return false;
            }
            return true;
        }
        //编辑后事件
        function onAfterEdit(e)
        {
            //当切换类型时,自动填充名称前缀
            //alert(JSON.stringify(e.record));
            //alert("after, e.column: "+JSON.stringify(e.column));
            if(e.column.name=="type") {
                var data = manager.getData();
                var d = data[e.rowindex];
                var name = '';
                if(d.type=="url")
                    name="url";
                else if(d.type=="code")
                    name="code_";
                else if(d.type=="btn")
                    name="btn_";
                g.updateCell('name', name, e.record);
            }
            //当名称修改后,校验前缀是否与类型匹配
            if (e.column.name == "name")
            {
                var d = e.record;
                var cellObj = g.getCellObj(d, e.column);
                //var name = d[e.column.name];
                var name = $(cellObj).text();
                if(name.length<1)
                    return true;
                if(d.type=="url" && name.indexOf(d.type)!=0) {
                    alert('你刚才编辑的值录入不正确!(类型为URL时,名称必须以url开头(小写))');
                    //cellObj.focus();
                    //g.setCellEditing(d, e.column, editing);
                    return false;
                } else if(d.type=="code" && name.indexOf(d.type)!=0) {
                    alert('你刚才编辑的值录入不正确!(类型为分级编码时,名称必须以code_开头(小写))');
                    //g.setCellEditing(d, e.column, editing);
                    return false;
                } else if(d.type=="url" && name.indexOf(d.type)!=0) {
                    alert('你刚才编辑的值录入不正确!(类型为按钮时,名称必须以btn_开头(小写))');
                    //g.setCellEditing(d, e.column, editing);
                    return false;
                }
            }
            return true;
        }
     </script>
</head>
<body>
    <table>
        <tr>
            <td colspan=2>
                <input type=radio id="dirOpt" name="typeOpt" checked><label for="dirOpt">目录节点</label>
                <input type=radio id="leafOpt" name="typeOpt"><label for="leafOpt">叶子节点</label>
            </td>
        </tr>
        <tr>
            <td><label>节点名称</label></td>
            <td><input type="text" id="nodeNameTxt" size="40"></td>
        </tr>
        <tr id="urlDom" style="display:none">
            <td><label>叶子url</label></td>
            <td><input type="text" id="urlTxt" size="70"></td>
        </tr>
        <tr>
            <td><label>分级编码</label></td>
            <td><input type="text" border="0" style="border:0;"  readonly id="nodeCodeTxt" size="40"></td>
        </tr>
    </table>
    <div>
    <a class="l-button" style="60px;float:left; margin-left:10px;" onclick="addNewRow()">新增行</a>
    <a class="l-button" style="60px;float:left; margin-left:10px;" onclick="deleteRow()">删除行</a>
    </div>
    <div id="maingrid"></div>
</body>
</html>

免责声明:文章转载自《[ligerUI] grid行编辑示例》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Winform传统DataGridView和DevExpress控件的GridControl两者表头全选功能的实现airtest和poco中滑动、连续滑动和拖动操作下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

JS 数据转换

转换成字符串类型 toString() var num = 5;console.log(num.toString()); String() String()函数存在的意义:有些值没有toString(),这个时候可以使用String()。比如:undefined和null 拼接字符串方式 num + "",当 + 两边一个操作符是字符串类型,一...

二级动态菜单的功能

二级动态菜单的实现, 我们可能需要一个  下方展示的这样的一种数据结构: { 1: { 'title': '用户管理', 'icon': 'fa fa-envira', 'children': [ {'title': '客户列表', 'url': '/customer/li...

JS 事件绑定、事件监听、事件委托详细介绍

在JavaScript的学习中,我们经常会遇到JavaScript的事件机制,例如,事件绑定、事件监听、事件委托(事件代理)等。这些名词是什么意思呢,有什么作用呢? 事件绑定 要想让 JavaScript 对用户的操作作出响应,首先要对 DOM 元素绑定事件处理函数。所谓事件处理函数,就是处理用户操作的函数,不同的操作对应不同的名称。 在JavaScrip...

javascript 获取当前页面的URL

如图所示:点击录入按钮实际的请求路径是“http://localhost:8081/dodiscovery/ordertaoziController.do?goAdd&_=1622601413035” 接下来测试js脚本获取url路径中的不同信息 1、获取完整URL var url; url = window.location.href;  结果...

nginx 配置的一些参数

/etc/nginx/nginx.conf worker_rlimit_nofile#;      --指定一个worker 进程所能打开的最大文件描述符数量worker_rlimit_sigpending#;    --指定每个用户能够发往进程的信号的数量 性能优化相关的配置  1.work_processes      --worker 进程的个数,通...

js实现点击箭头导航条左右滚动

一、实现效果 二、代码展示 <!-- 导航条点击箭头左右滚动 --> <script type="text/javascript"> $(function() { var oPic = $('.picScroll').find('ul...