应用场景:最近的项目中二级子页面遍历生成、操作表格比较多,记录一下一直用的遍历方法。

一般此类表格都是通过ajax请求数据,然后从callbackFunction中获取数据集合,遍历生成表:

eg:

var postData=new Object();

    postData.idString=idString;

    $.ajax({

    url:'debt/findXXXList.do'+'?t='+Math.random()+'&token='+token,

    data:postData,

    type:'POST',

    dataType:'json',

    success:function(data){

        //初始化数据

        $("#confirmInf").empty();

        for(var i=0;i<data.length;i++){

            var inf=data[i];

            var realname=inf.real_name;

            var amount=inf.original_amount_cny;

            var debtID=inf.debtID;

            var html='<tr><td><a class="name" title='+realname+' style="margin-right:0px;">'+realname+'</a></td>';

            var html2='<td class="abstract shuheixian"><input type="text" id="detils" placeholder="摘要内容不超过20个字" debtid='+debtID+' maxlength="20" autofocus></td>';

            var html3='<td class="sum">'+amount+'</td><td class="sum"></td>';

            var html4='<td class="sum">'+amount+'</td></tr>';

            $("#confirmInf").append(html+html2+html3+html4);

        }

        //弹出窗口

        var maskHight=$(document).height();

        var maskWidth=$(document).width();

        $('<div class="mask"></div>').appendTo($('body'));

        $('div.mask').css ({

              'opacity':0.5,

              'background':'#000',

              'position':'absolute',

              'left':0,

              'top':0,

              'width':maskWidth,

              'height':maskHight,

              'z-index':9999

        });

        $('.accept_contain').show();

        gaoduDIV();//样式

        $(".accept_contain input").eq(0).focus();

   },

    error:function(){

        console.log("error初始化数据出错。。。");

        //发送请求给发送邮件接口(邮件接口处理掉异常信息),调用给后台提示尽快修复

        var pageName="new/receivedClaims";

        var type ="findReceivedDebtPageList===初始化弹窗失败===jsp434行";

        tips("系统升级中,请稍后进行尝试。",false);

    },

 });

此时,弹出二级页面,并且循环生成了表格数据。

这时候,需要对表格中的input标签内容进行验证,而常规的通过id获取标签的方式不能准确定位到某条循环生成的数据.

此时分为两种情况:

1、获取某一行中编辑过的多条数据。

这个需要定位到每个标签,并且从标签中获取我们所需要的数据。对应着标签结构慢慢找并不难:

//验证

    if(!validate()){

        return false;

    }

    var dataStr="";

    var flag=1;
    var Obj1=document.getElementsByClassName("dataInfo");//关键!获取所有tr标签,然后根据结构去一层层的找

    for (var i=0;i<Obj1.length;i++ ){

        var obj=Obj1[i].childNodes;

        var type ="claims";

        var debtid=obj[0].attributes["debtid"].value;

        var debtstatus=obj[0].attributes["debtstatus"].value;

        var detils=obj[2].childNodes[0].value;

        var amount1=obj[3].childNodes[0].value;

        var amount2=obj[4].childNodes[0].value;

        //数据合法性调整

        if(amount1==""){amount1=0};

        if(amount2==""){amount2=0};

        

        //str拼接

            if(flag==1){

                dataStr+=debtstatus+"&.&"+debtid+"&.&"+detils+"&.&"+amount1+"&.&"+amount2+"&.&";

                flag=-1;

            }else{

                dataStr+="@*@"+debtstatus+"&.&"+debtid+"&.&"+detils+"&.&"+amount1+"&.&"+amount2+"&.&";

            }

        }

2、对每一行的某一列数据进行验证。

这个用的jquery:

//数据验证

function validate(){

    var result =true;

    //摘要字段验证
    $("#editInf input[id='intro'][type='text']").each(function(){//关键:选择器的使用 id为editInf的标签下所有 id=editInf 类型为text的标签

        var value=$(this).val();

        if(value==null||value==''||value.length==0){

            $(this).val("");

            $(this).attr("style","background-color: #FFC1C1");

            $(this).attr("placeholder","摘要不能为空");

            result = false;

        }

    });

    //金额1验证

    $("#editInf input[id='amount1'][type='text']").each(function(){

        

        var value=$(this).val();

        if(!/(^[1-9]([0-9]+)?(\.[0-9]{1,2})?$)|(^(0){1}$)|(^[0-9]\.[0-9]([0-9])?$)/.test(value)){

            $(this).val("");

            $(this).attr("style","background-color: #FFC1C1");

            $(this).attr("placeholder","请填写数字");

            result = false;

        }

    });

    //金额2验证

    $("#editInf input[id='amount2'][type='text']").each(function(){

        var value=$(this).val();

        if(!/(^[1-9]([0-9]+)?(\.[0-9]{1,2})?$)|(^(0){1}$)|(^[0-9]\.[0-9]([0-9])?$)/.test(value)){

            $(this).val("");

            $(this).attr("style","background-color: #FFC1C1");

            $(this).attr("placeholder","请填写数字");

            result = false;

        }

        

    });

    return result;

}

html、jsp页面标签的遍历的更多相关文章

  1. jsp 页面标签 积累

    http://www.cnblogs.com/xiadongqing/p/5232592.html <%@ taglib %>引入标签库 ========================= ...

  2. jsp页面中同时遍历多个list集合

    在Jsp页面中,我们也许有这样的需求:从后端获取到多个List,但又想将这些List的值同时打印出来 比如, 有用户列表userList,user类有用户ID.用户名.用户性别等基本信息 有用户关系列 ...

  3. JSP页面标签

    1.EL表达式中empty的用法 EL表达式中empty的用法 <c:if test="${! empty key}">${key}</c:if> < ...

  4. jsp c标签不遍历的方法

    生产中遇到过不需要遍历的事情. 一般遍历必须要 <c:forEach items="${resultObj.xxx}" var="data" varSta ...

  5. jsp页面中jstl标签详解

    JSLT标签库,是日常开发经常使用的,也是众多标签中性能最好的.把常用的内容,放在这里备份一份,随用随查.尽量做到不用查,就可以随手就可以写出来.这算是Java程序员的基本功吧,一定要扎实. JSTL ...

  6. 【转】jsp页面中jstl标签详解

    原文地址: JSLT标签库,是日常开发经常使用的,也是众多标签中性能最好的.把常用的内容,放在这里备份一份,随用随查.尽量做到不用查,就可以随手就可以写出来.这算是Java程序员的基本功吧,一定要扎实 ...

  7. 关于jsp中jstl-core标签循环遍历的使用

    JSP标准标签库(JSTL)是一个JSP标签集合,它封装了JSP应用的通用核心功能. JSTL支持通用的.结构化的任务,比如迭代,条件判断,XML文档操作,国际化标签,SQL标签. 除了这些,它还提供 ...

  8. jsp页面中jstl标签详解[转]

    JSLT标签库,是日常开发经常使用的,也是众多标签中性能最好的.把常用的内容,放在这里备份一份,随用随查.尽量做到不用查,就可以随手就可以写出来.这算是Java程序员的基本功吧,一定要扎实. JSTL ...

  9. jsp页面file标签上传图片以及blob类型数据库存取。

    我的jsp页面表单如下: <form name="form1" action="/YiQu/AddUserServlet?jurisdiction=1" ...

随机推荐

  1. Windows Serverserver结束MySQL自己主动数据库备份

    1.给root所有授权的帐户sql才干 grant all privileges on *.* to root@"%" identified by "."; f ...

  2. ATS项目更新(4) 更新DLL到远程服务器

    rem by jin tao rem upload dll to ta1bbn01 rem rem @echo off echo %time% set time1 = %,%%,%%,% rem ** ...

  3. 文章之间的基本总结Activity生命周期

    子曰:溫故而知新,能够為師矣.<論語> 学习技术也一样,对于技术文档或者经典的技术书籍来说,指望看一遍就全然掌握,那基本不大可能,所以我们须要常常回过头再细致研读几遍,以领悟到作者的思想精 ...

  4. Java数组List换算方法

    1.List转换到一个数组.(这里List它是实体是ArrayList) 调用ArrayList的toArray方法. toArray public <T> T[] toArray(T[] ...

  5. Angular route传参

    从 router-link-page1 跳转 router-link-page2 和 router-link-page3 通过自定义路由 设置router-link-page2的路由后有3个参数,pa ...

  6. [GEiv]第七章:着色器 高效GPU渲染方案

    第七章:着色器 高效GPU渲染方案 本章介绍着色器的基本知识以及Geiv下对其提供的支持接口.并以"渐变高斯模糊"为线索进行实例的演示解说. [背景信息] [计算机中央处理器的局限 ...

  7. 搭建本地yum源和局域网yum源

    搭建本地yum源和局域网yum源 由于很多客户环境是专网,不允许连网,无法使用网上的各种yum源,来回拷贝rpm包安装麻烦,还得解决依赖问题.所以想着搭建个本地/局域网YUM源,方便安装软件. 1   ...

  8. socket上http协议应用(使用socket进行http通信的例子,准备好报头以后,简单read/write就可以了)

    前几天看socket本有点晕, 好不容易弄明白了,才发现公司服务器用的是http的. 找了好久也没发现linux下直接用http的api, 不过今日偶然发现了使用socket进行http通信的例子, ...

  9. Win10《芒果TV》春季商店版更新v3.3.0:全新视觉蜕变&支持快男直播

    在微软发布Win10创意者更新正式版前夕,Win10版<芒果TV>迅速更新至v3.3.0,主要是全新升级视觉交互,新增大咖快男个人直播,全面优化底层架构,启动大提速. Win10版< ...

  10. 零元学Expression Blend 4 - Chapter 9 用实例了解布局容器系列-「Canvas」

    原文:零元学Expression Blend 4 - Chapter 9 用实例了解布局容器系列-「Canvas」 本系列将教大家以实做案例认识Blend 4 的布局容器,此章介绍的布局容器是Blen ...