zoukankan      html  css  js  c++  java
  • JSP前端数据本地排序

    在前端中我们经常需要数据的排序,首先写引入我写好的js

    $(function($) {
        $('#sclazzId').val($('#voId').val());
        document.getElementsByName('nameup')[0].style.display = "none";
        document.getElementsByName('nameup')[1].style.display = "none";
        document.getElementsByName('nameup')[2].style.display = "none";
        document.getElementsByName('nameup')[3].style.display = "none";
        var tabobj = document.getElementById("tbValue");
        /*
         * for (var i = 2; i < tabobj.rows.length; i++) {
         * 
         * if (tabobj.rows[i].cells[1].innerHTML == code) {
         * 
         * tabobj.rows[i].style.backgroundColor = "red";
         * 
         * break; } }
         */
    });
    function OnChange(code) {
        // alert(document.getElementById("drpIndustry").value+"_"+code+".html");
        window.location.href = document.getElementById("drpIndustry").value + "_"
                + code + ".html";
    
    }
    
    // 转换器,将列的字段类型转换为可以排序的类型:String,int,float
    function convert(sValue, sDataType) {
        switch (sDataType) {
        case "int":
            if (sValue != "--")
                return parseInt(sValue);
            else
                return -10000000000000;
        case "float":
            if (sValue != "--")
                return parseFloat(sValue);
            else
                return -10000000000000.0;
        case "date":
            if (sValue != "--")
                return new Date(Date.parse(sValue));
            else
                return "1900-01-01";
        default:
            return sValue.toString();
    
        }
    }
    
    // 排序函数产生器,iCol表示列索引,sDataType表示该列的数据类型
    function generateCompareTRs(iCol, sDataType) {
    
        return function compareTRs(oTR1, oTR2) {
            var vValue1 = convert(oTR1.cells[iCol].firstChild.nodeValue, sDataType);
            var vValue2 = convert(oTR2.cells[iCol].firstChild.nodeValue, sDataType);
    
            if (vValue1 < vValue2) {
                return -1;
            } else if (vValue1 > vValue2) {
                return 1;
            } else {
                return 0;
            }
        };
    }
    // 排序方法
    function sortTable(sTableID, iCol, sDataType) {
        if (document.getElementsByName('nameup')[parseInt(iCol) - 1].style.display == 'none') {
            document.getElementsByName('nameup')[parseInt(iCol) - 1].style.display = 'block';
            document.getElementsByName('namedown')[parseInt(iCol) - 1].style.display = 'none';
        } else {
            document.getElementsByName('nameup')[parseInt(iCol) - 1].style.display = 'none';
            document.getElementsByName('namedown')[parseInt(iCol) - 1].style.display = 'block';
        }
        var oTable = document.getElementById(sTableID);
        var oTBody = oTable.tBodies[0];
        var colDataRows = oTBody.rows;
        var aTRs = new Array;
        // 将所有列放入数组
        for (var i = 0; i < colDataRows.length; i++) {
            aTRs[i] = colDataRows[i];
        }
        // 判断最后一次排序的列是否与现在要进行排序的列相同,是的话,直接使用reverse()逆序
        if (oTable.sortCol == iCol) {
            aTRs.reverse();
        } else {
            // 使用数组的sort方法,传进排序函数
            aTRs.sort(generateCompareTRs(iCol, sDataType));
        }
    
        var oFragment = document.createDocumentFragment();
        for (var i = 0; i < aTRs.length; i++) {
            aTRs[i].cells[0].innerHTML = i + 1;
            oFragment.appendChild(aTRs[i]);
        }
    
        oTBody.appendChild(oFragment);
        // 记录最后一次排序的列索引
        oTable.sortCol = iCol;
    }
    
    function detatilWork(id) {
        alert(id);
        $.post("", {
            id : id
        }, function() {
    
        });
    }
    
    function reflash() {
        window.location.reload(true);
    }
    
    function openSearch() {
        var name = $('#sname').val();
        var clazzId = $('#sclazzId').val();
        window.location.href = "assistantWork.action?name=" + name + "&clazzId="
                + clazzId;
    }
    
    function lastPage(page) {
        var name = $('#sname').val();
        var clazzId = $('#sclazzId').val();
        page = (page - 1 < 0) ? 0 : (page - 1);
        window.location.href = "assistantWork.action?page=" + page + "&name="
                + name + "&clazzId=" + clazzId;
    }
    function selPage(page) {
        var name = $('#sname').val();
        var clazzId = $('#sclazzId').val();
        window.location.href = "assistantWork.action?page=" + page + "&name="
                + name + "&clazzId=" + clazzId;
    }
    function nextPage(page, pages) {
        var name = $('#sname').val();
        var clazzId = $('#sclazzId').val();
        page = (page + 1 > pages) ? pages : (page + 1);
        window.location.href = "assistantWork.action?page=" + page + "&name="
                + name + "&clazzId=" + clazzId;
    }
    
    function detail(id, type) {
        $.ajax({
            url : 'selectOneWork.action?id=' + id,
            async : false, // 同步请求
            error : function() {
                alert("失败");
            },
            success : function(data) {
                data = eval("(" + data + ")");
                $('#workid').val(data.id);
                $('#cname').val(data.name);
                $('#sclazzIdM').val(data.clazzId);
                $('#cdescription').val(data.description);
            },
        }, 'json');
        if(type==1){
            //查看 需要改成不可编辑
            setDisabled();
        }else if(type==2){
            cleanDisabled();
        }
    }
    
    function add(){
        cleanDisabled();
    }
    function setDisabled(){
        $('#cname').attr("disabled",true);
        $('#sclazzIdM').attr("disabled",true);
        $('#cdescription').attr("disabled",true);
        $('#submitWork').attr("disabled",true);
    }
    
    function cleanDisabled(){
        $('#cname').attr("disabled",false);
        $('#sclazzIdM').attr("disabled",false);
        $('#cdescription').attr("disabled",false);
        $('#submitWork').attr("disabled",false);
    }

    这里写图片描述在jsp页面中我们只需要在字段中嵌入这两div就可以实现视觉上的升序或降序,真正实现排序的是字段上面的那个点击事件,事件的执行方法在上面的脚本中都已经写好了,就这么简单,你就实现了表格数据的本地排序,大大的减少了与服务器之间的访问次数。

    • 另外在说一句就是在我们的jsp中我们有的时候并不是很需要数据库数据的格式,这个时候我们需要将数据的格式进行转化,转化的方式有很多种,我们可以将数据在后台的时候进行格式处理,但是这样做的话在效率上并不是很快,我们在jsp中就有这样的标签这里写图片描述
    • 这里写图片描述
    • 这样我们就实现了日期的格式化处理,值得注意的是这里的fmt只能用我页面上的布局,不能用工具上的格式化处理,处理过就会影响我们上面的本地排序,所以只能用我的格式
  • 相关阅读:
    绝对差不超过限制的最长连续子数组
    单调栈的认识及其应用
    寻找两个正序数组的中位数寻找两个正序数组的中位数
    JVM垃圾回收机制和python的垃圾回收
    K 个不同整数的子数组
    python中闭包
    2021/2/8_ 最长湍流子数组
    python中的函数
    python中可变类型与不可变类型 + 类型转换
    python的元组
  • 原文地址:https://www.cnblogs.com/zhangxinhua/p/8319250.html
Copyright © 2011-2022 走看看