Ace admin --table(單表)

1、第一步導入依賴js
javascript



2、copy demo 以下
html


<%@ page contentType="text/html; charset=UTF-8" session="false" language="java" %>
<%@ include file="/common/indexJs.jsp" %>
<%@page import="platform.Constants"%>

                    <div class="page-content-area">
                        <div class="page-header">

                        </div><!-- /.page-header -->
                        <div class="row">
                            <div class="col-xs-12">
                                <table id="grid-table"></table>
                                <div id="grid-pager"></div>
                                <script type="text/javascript">
                                    var $path_base = ".";//in Ace demo this will be used for editurl parameter
                                </script>
                                <!-- PAGE CONTENT ENDS -->
                            </div><!-- /.col -->
                        </div><!-- /.row -->
                    </div><!-- /.page-content-area -->
        <!-- inline scripts related to this page -->
        <script type="text/javascript">
            jQuery(function($) {
                var grid_selector = "#grid-table";
                var pager_selector = "#grid-pager";
                
                //resize to fit page size
                $(window).on('resize.jqGrid', function () {
                    $(grid_selector).jqGrid( 'setGridWidth', $(".page-content").width());
                })
                              
                //resize on sidebar collapse/expand
                var parent_column = $(grid_selector).closest('[class*="col-"]');
                $(document).on('settings.ace.jqGrid' , function(ev, event_name, collapsed) {
                    if( event_name == 'sidebar_collapsed' || event_name == 'main_container_fixed' ) {
                        //setTimeout is for webkit only to give time for DOM changes and then redraw!!!
                        setTimeout(function() {
                            $(grid_selector).jqGrid( 'setGridWidth', parent_column.width() );
                        }, 0);
                    }
                })
            
                $(grid_selector).jqGrid({
                    
                    datatype: 'json',
                    url: '<%=request.getContextPath()%>/goodsMessages/list',//dom樹加載完成請求的地址(ajax請求)
                    mtype: 'POST',//請求方式
                    jsonReader: {
                        id: "gdProduktId"//刪除、根據本字段查詢時候向後臺傳的參數「gdProduktId」本身的字段名
                    },
                    height: 250,
                    
                    colNames: ['操做', '產品編碼', '品名', '品牌', '供應商', '入庫時間','庫存量','總量'],
                    colModel: [java

                        //下面的name裏面是操做的屬性不須要的同窗能夠刪掉注意colNames與colModel字段長度對應
                        {name:'myac',index:'', width:80, fixed:true, sortable:false, resize:false,search:false,
                            formatter:'actions',
                            formatoptions:{
                                //keys:true,
                                //editbutton: false,//disable edit button   行編輯是否啓用
                                editOptions:{recreateForm: true, beforeShowForm:beforeEditCallback},
                                //delbutton: false,//disable delete button  行刪除是否啓用
                                delOptions:{recreateForm: true, beforeShowForm:beforeDeleteCallback}
                            }
                        },web

                //如下是數據解析 對應model字段   editable本字段是否可編輯 等等就很少說了
                        {name:'gdProduktId',index:'gdProduktId', width:60, editable: true,hidden:true,editrules:{edithidden:true}},
                        {name:'gdName',index:'gdName', width:60, editable: true,editrules:{required:true}},              
                        {name:'gdTrademark',index:'gdTrademark', width:60, editable: true,editrules:{required:true}},              
                        {name:'gdSuppier',index:'gdSuppier', width:60, editable: true,editrules:{required:true}},              
                        {name:'gdPutInStoreTime',index:'gdPutInStoreTime', width:60, editable: true},              
                        {name:'gdRepertory',index:'gdRepertory', width:60, editable: true},    
                        {name:'gdTotal',index:'gdTotal', width:60, editable: true,hidden:false,editrules:{edithidden:true}},
                    ],
                    
                    viewrecords : true,
                    sortorder: "asc",
                    rowNum:10,
                    rowList:[10,20,30],
                    pager : pager_selector,
                    caption: "測試樣例",
                    multiselect: true,
                    autowidth: true,
            
                    loadComplete : function() {
                        var table = this;
                        setTimeout(function(){
                            updatePagerIcons(table);
                            enableTooltips(table);
                        }, 0);
                    },
            
                    editurl: '<%=request.getContextPath()%>/goodsMessageform'//編輯提交的地址
                    //altRows: true,
                    //multiboxonly: true
            
                });
                
                $(window).triggerHandler('resize.jqGrid');//trigger window resize to make the grid get the correct size
            
                //enable search/filter toolbar
                //jQuery(grid_selector).jqGrid('filterToolbar',{defaultSearch:true,stringResult:true})
                //jQuery(grid_selector).filterToolbar({});
            
            
                //switch element when editing inline
                function aceSwitch( cellvalue, options, cell ) {
                    setTimeout(function(){
                        $(cell) .find('input[type=checkbox]')
                            .addClass('ace ace-switch ace-switch-5')
                            .after('<span class="lbl"></span>');
                    }, 0);
                }
                //enable datepicker
                function pickDate( cellvalue, options, cell ) {
                    setTimeout(function(){
                        $(cell) .find('input[type=text]')
                                .datepicker({format:'yyyy-mm-dd' , autoclose:true});
                    }, 0);
                }
            
            
                //navButtons
                $(grid_selector).jqGrid('navGrid',pager_selector,
                    {     //navbar options//如下是table下方的操做是否啓用
                        edit: true,
                        editicon : 'ace-icon fa fa-pencil blue',
                        add: true,
                        addicon : 'ace-icon fa fa-plus-circle purple',
                        del: true,
                        delicon : 'ace-icon fa fa-trash-o red',
                        search: true,
                        searchicon : 'ace-icon fa fa-search orange',
                        refresh: true,
                        refreshicon : 'ace-icon fa fa-refresh green',
                        view: true,
                        viewicon : 'ace-icon fa fa-search-plus grey',
                    },
                    {
                        //edit record form
                        closeAfterEdit: true,
                        //width: 700,
                        recreateForm: true,
                        beforeShowForm : function(e) {
                            var form = $(e[0]);
                            form.closest('.ui-jqdialog').find('.ui-jqdialog-titlebar').wrapInner('<div class="widget-header" />')
                            style_edit_form(form);
                        }
                    },
                    {
                        //new record form
                        //width: 700,
                        closeAfterEdit: true,
                        recreateForm: true,
                        //viewPagerButtons: false,
                        beforeShowForm : function(e) {
                            var form = $(e[0]);
                            form.closest('.ui-jqdialog').find('.ui-jqdialog-titlebar')
                            .wrapInner('<div class="widget-header" />');
                            form.find('input[name=grid-table_id]').attr("value","");
                            style_edit_form(form);
                        }
                        
                    },
                    {
                        //delete record form
                        recreateForm: true,
                        beforeShowForm : function(e) {
                            var form = $(e[0]);
                            if(form.data('styled')) return false;
                            
                            form.closest('.ui-jqdialog').find('.ui-jqdialog-titlebar').wrapInner('<div class="widget-header" />')
                            style_delete_form(form);
                            
                            form.data('styled', true);
                        },
                        onClick : function(e) {
                            alert(1);
                        },
                        closeAfterDel: true
                    },
                    {
                        //search form
                        recreateForm: true,
                        multipleSearch: true,
                        //multipleGroup: false,
                        afterShowSearch: function(e){
                            var form = $(e[0]);
                            form.closest('.ui-jqdialog').find('.ui-jqdialog-title').wrap('<div class="widget-header" />')
                            style_search_form(form);
                        },
                        afterRedraw: function(){
                            style_search_filters($(this));
                        },
                        closeAfterSearch: true
                        //showQuery: true
                    },
                    {
                        //view record form
                        recreateForm: true,
                        beforeShowForm: function(e){
                            var form = $(e[0]);
                            form.closest('.ui-jqdialog').find('.ui-jqdialog-title').wrap('<div class="widget-header" />')
                        }
                    }
                )
                
                function style_edit_form(form) {
                    //enable datepicker on "sdate" field and switches for "stock" field
                    form.find('input[name=sdate]').datepicker({format:'yyyy-mm-dd' , autoclose:true})
                        .end().find('input[name=accountExpired]')
                            .addClass('ace ace-switch ace-switch-5').after('<span class="lbl"></span>');
                               //don't wrap inside a label element, the checkbox value won't be submitted (POST'ed)
                              //.addClass('ace ace-switch ace-switch-5').wrap('<label class="inline" />').after('<span class="lbl"></span>');
            
                    //update buttons classes
                    var buttons = form.next().find('.EditButton .fm-button');
                    buttons.addClass('btn btn-sm').find('[class*="-icon"]').hide();//ui-icon, s-icon
                    buttons.eq(0).addClass('btn-primary').prepend('<i class="ace-icon fa fa-check"></i>');
                    buttons.eq(1).prepend('<i class="ace-icon fa fa-times"></i>')
                    
                    buttons = form.next().find('.navButton a');
                    buttons.find('.ui-icon').hide();
                    buttons.eq(0).append('<i class="ace-icon fa fa-chevron-left"></i>');
                    buttons.eq(1).append('<i class="ace-icon fa fa-chevron-right"></i>');        
                }
            
                function style_delete_form(form) {
                    var buttons = form.next().find('.EditButton .fm-button');
                    buttons.addClass('btn btn-sm btn-white btn-round').find('[class*="-icon"]').hide();//ui-icon, s-icon
                    buttons.eq(0).addClass('btn-danger').prepend('<i class="ace-icon fa fa-trash-o"></i>');
                    buttons.eq(1).addClass('btn-default').prepend('<i class="ace-icon fa fa-times"></i>')
                }
                
                function style_search_filters(form) {
                    form.find('.delete-rule').val('X');
                    form.find('.add-rule').addClass('btn btn-xs btn-primary');
                    form.find('.add-group').addClass('btn btn-xs btn-success');
                    form.find('.delete-group').addClass('btn btn-xs btn-danger');
                }
                function style_search_form(form) {
                    var dialog = form.closest('.ui-jqdialog');
                    var buttons = dialog.find('.EditTable')
                    buttons.find('.EditButton a[id*="_reset"]').addClass('btn btn-sm btn-info').find('.ui-icon').attr('class', 'ace-icon fa fa-retweet');
                    buttons.find('.EditButton a[id*="_query"]').addClass('btn btn-sm btn-inverse').find('.ui-icon').attr('class', 'ace-icon fa fa-comment-o');
                    buttons.find('.EditButton a[id*="_search"]').addClass('btn btn-sm btn-purple').find('.ui-icon').attr('class', 'ace-icon fa fa-search');
                }
                
                function beforeDeleteCallback(e) {
                    var form = $(e[0]);
                    if(form.data('styled')) return false;
                    
                    form.closest('.ui-jqdialog').find('.ui-jqdialog-titlebar').wrapInner('<div class="widget-header" />')
                    style_delete_form(form);
                    
                    form.data('styled', true);
                }
                
                function beforeEditCallback(e) {
                    var form = $(e[0]);
                    form.closest('.ui-jqdialog').find('.ui-jqdialog-titlebar').wrapInner('<div class="widget-header" />')
                    style_edit_form(form);
                }
                
                //replace icons with FontAwesome icons like above
                function updatePagerIcons(table) {
                    var replacement =
                    {
                        'ui-icon-seek-first' : 'ace-icon fa fa-angle-double-left bigger-140',
                        'ui-icon-seek-prev' : 'ace-icon fa fa-angle-left bigger-140',
                        'ui-icon-seek-next' : 'ace-icon fa fa-angle-right bigger-140',
                        'ui-icon-seek-end' : 'ace-icon fa fa-angle-double-right bigger-140'
                    };
                    $('.ui-pg-table:not(.navtable) > tbody > tr > .ui-pg-button > .ui-icon').each(function(){
                        var icon = $(this);
                        var $class = $.trim(icon.attr('class').replace('ui-icon', ''));
                        
                        if($class in replacement) icon.attr('class', 'ui-icon '+replacement[$class]);
                    })
                }
            
                function enableTooltips(table) {
                    $('.navtable .ui-pg-button').tooltip({container:'body'});
                    $(table).find('.ui-pg-div').tooltip({container:'body'});
                }
            
            
                $(document).on('ajaxloadstart', function(e) {
                    $(grid_selector).jqGrid('GridUnload');
                    $('.ui-jqdialog').remove();
                });
            });
        </script>
其餘參數能夠根據本身的須要去研究   不知道怎麼貼圖阿 圖後補吧ajax

3、json

後臺主要代碼session

     @RequestMapping(value="list",method = RequestMethod.POST)
    public void listGoodsMessage(HttpServletRequest request, HttpServletResponse response) throws JsonGenerationException, JsonMappingException, IOException {
        
        JqGridHandler jqh = new JqGridHandler(request);
        FilterSearch filtersearch = jqh.getFilterSearch();
        int rows = jqh.getRows();
        int page = jqh.getPage();
        PageNation pagenation = new PageNation(page, rows);
        
        Map m = new HashMap();
        if (null != filtersearch)
            m = UPlatEntityUtils.searchRule2Map(filtersearch);
        List<GoodsMessage> list = goodsMessageManager.getByPagination(pagenation, null, m);
        
        int records = pagenation.getRecords();
        int totalPage = pagenation.getTotalPages();
        
        StringBuilder json = new StringBuilder("{");
        json.append("\"total\":").append(totalPage)
            .append(",\"page\":").append(page)
            .append(",\"records\":").append(records)
            .append(",\"rows\":");
        
        String jsonData = UPlatJsonUtils.list2json(list);
        json.append(jsonData);
        json.append("}");
        
        response.getWriter().write(json.toString());
        
    }app

相關文章
相關標籤/搜索