DWZ动态Table

<!-- index.jsp>>>index>>>固定资产管理 -->
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@include file="/context/devuxTags.jsp"%>
<div class="pageContent">
    <div class="panelBar">
        <ul class="toolBar">
            <li><a class="add"><span>添加</span></a></li>
            <li><a class="delete"><span>删除</span></a></li>
            <li><a class="edit" title="修改"><span>修改</span></a></li>
            
            <li class="line">line</li>
            
        </ul>
        <select class="combox" id="fixedAssetsType">
            <option value="computer">计算机主机</option>
            <option value="50">计算机显示器</option>
            <option value="100">办公桌</option>
            <option value="200">办公座椅</option>
        </select>
    </div>
    
    <div id="jTableDynamic99999"></div>

 

<script type="text/javascript">
(function($) {
    $.fn.jTableDynamic = function(options) {
        options = $.extend(true, {
            cols: [],
            url: "",
            pagging: false,
            numPerPage: 10
        }, options);

        var $table = $(this);
        loadDynamicTableData = function(numPerPage, pageNum) {
            $table.html('<table class="table" width="100%"><thead></thead><tbody></tbody></table>');
            if (options.pagging) {
                var pagination = '<div class="panelBar">' + '<div class="pages"><span>每页显示</span>' + '<select class="combox" name="numPerPage"><option value="10">10</option><option value="20">20</option><option value="50">50</option></select>' + '<span>条,共<label id="totalCount"></label>条</span></div>' + '<div class="pagination" targetType="" totalCount="150" numPerPage="10" pageNumShown="10" currentPage="1"></div></div>';
                $table.append(pagination);
            }
            var cols = options.cols;
            var fixedAssetsHead = "<tr>";
            for (var idx = 0; idx < cols.length; idx++) {
                var col = cols[idx];
                fixedAssetsHead += '<th width="' + col.width + 'px">' + '<div class="gridCol" title="' + col.name + '" style="text-align:center;">' + col.name + '</div></th>';
            }
            fixedAssetsHead += '</tr>';
            $table.find('thead').html(fixedAssetsHead);
            $.ajax({
                type: 'POST',
                url: options.url,
                data: {
                    numPerPage: numPerPage,
                    pageNum: pageNum
                },
                dataType: 'json',
                contentType: "application/x-www-form-urlencoded; charset=utf-8",
                async: false, // 处理页面初始化用ajax获取并设置表格内容后,表格没有点击事件、单元格不对齐等。
                success: function(respMsg, textStatus, jqXHR) {
                    if (respMsg.code == 200) {
                        var data = respMsg.data;
                        var rows = data.rows;
                        var total = data.total;
                        if (rows instanceof Array) {
                            $table.find('#totalCount').html(total);
                            var content = "";
                            try {
                                for (var idxd = 0; idxd < rows.length; idxd++) {
                                    content += '<tr target="sid_user" rel="' + idxd + '" class="">';
                                    for (var idx = 0; idx < cols.length; idx++) {
                                        var col = cols[idx];
                                        content += "<td>" + rows[idxd][col.code] + "</td>";
                                    }
                                    content += "</tr>";
                                }
                                $table.find("select[name='numPerPage']").val(numPerPage);
                                $table.find('.pagination').attr("totalCount", total);
                                $table.find('.pagination').attr("currentPage", pageNum);
                                $table.find('.pagination').attr("numPerPage", numPerPage);
                            } catch (exception) {
                                content = "";
                                alertMsg.error('表格数据格式不正确!');
                            }
                            $table.find('tbody').html(content);
                        } else {
                            alertMsg.error('服务器返回的表格数据格式不正确!');
                        }
                    } else {
                        alertMsg.error('查询表格数据时发生错误!\n' + respMsg.msg);
                    }
                },
                error: function(XMLHttpRequest, textStatus, errorThrown) {
                    alertMsg.error('请求表格数据时发生错误!');
                }
            });
        }

        loadDynamicTableData(10, 1);

        dwzPageBreak = function(options) {
            var numPerPage = $table.find("select[name='numPerPage']").val();
            var pageNum = options.data.pageNum;
            loadDynamicTableData(numPerPage, pageNum);
            $($('div.page.unitBox')[1]).initUI();
        }

        $table.find('select[name="numPerPage"]').live("change", function() {
            loadDynamicTableData($(this).val(), 1);
            $($('div.page.unitBox')[1]).initUI();
        });
        $table.selectedRow = function() {
            if (!$table.find("tr.selected").length)
                return null;
            else
                return $table.find("tr.selected");
        }

        return $table;
    };
})(jQuery);

$(function() {
    var fixedAssetsOptions = {
        computer: {
            url: "fixedAssets/computerList",
            options: [{
                code: "id",
                name: "设备编号",
                width: 100
            }, {
                code: "brand",
                name: "品牌",
                width: 200
            }, {
                code: "cpu",
                name: "CPU",
                width: 300
            }, {
                code: "memory",
                name: "内存",
                width: 200
            }, {
                code: "harddisk",
                name: "硬盘",
                width: 300
            }]
        },
        monitor: {}
    };
    var fixedAssetsTypeOptions = fixedAssetsOptions[$('#fixedAssetsType').val()].options;
    var fixedAssetsTypeURL = fixedAssetsOptions[$('#fixedAssetsType').val()].url;


    var $table = $('#jTableDynamic99999').jTableDynamic({
        cols: fixedAssetsTypeOptions,
        pagging: true,
        url: '<%= basePath%>' + fixedAssetsTypeURL
    });

    $(".toolBar").find(".delete").live("click", function() {
        var selectedRow = $table.selectedRow();
        if (selectedRow) {
            alertMsg.confirm("您确定要将选中的数据删除?!", {
                okCall: function() {
                    var rel = selectedRow.attr("rel");
                }
            });
        } else
            alertMsg.error('未选中行!');

    });

    $(".toolBar").find(".edit").live("click", function() {
        var selectedRow = $table.selectedRow();
        if (selectedRow) {
            var rel = selectedRow.attr("rel");
            var url = "<%= basePath%>fixedAssets/computerEdit?cid=" + rel; 
            $.pdialog.open(url, "rel", "修改信息", {mask:true});
        } else
            alertMsg.error('未选中行!');
    });

});
</script>

  

posted @ 2015-12-17 10:29  貂蝉爱戏水  阅读(2073)  评论(0编辑  收藏  举报