zoukankan      html  css  js  c++  java
  • html5中的input和label写法与取值

    demo 效果图如上

    label是html5特有的,是定义 input 元素的标注。
    凡是input前面要有个label标识下,label和input真是一对好兄弟啊。
    <label> 标签的 for 属性应当与相关元素的 id 属性相同。

                <div class="blocks mgtop0 brdbtm0 clearFix">
                    <div class="addareaBox">
                        <label class="stateTitle"><em class="redStar">*</em>国家</label>
                        <ul class="listInfoUl">
                            <li id="states" class="statesLi">                
                            <label class="arealabel" for="areaInput0">
                            <input type="checkbox" name="areaInputConts" id="areaInput0" value="9">法国</label>
                            <label class="arealabel" for="areaInput1">
                            <input type="checkbox" name="areaInputConts" id="areaInput1" value="10">比利时</label>                        
                            </li>        
                        </ul>
                    </div>
                
                    <div class="addareaBox">
                        <label><em class="redStar">*</em>城市</label>
                        <ul class="listInfoUl">
                        <li id="areaInput0-citys" class="citysLi">                        
                                <label class="arealabel all">法国</label>                        
                                <label class="arealabel" for="areaInput0-citys-Input0">
                                <input type="checkbox" name="areaInputCitys" id="areaInput0-citys-Input0" value="27">尼斯</label>
                                <label class="arealabel" for="areaInput0-citys-Input1">
                                <input type="checkbox" name="areaInputCitys" id="areaInput0-citys-Input1" value="26">巴黎</label>
                                <label class="arealabel" for="areaInput0-citys-Input2">
                                <input type="checkbox" name="areaInputCitys" id="areaInput0-citys-Input2" value="28">马赛</label>                
                        </li>
                        <li id="areaInput1-citys" class="citysLi">                        
                                <label class="arealabel all">比利时</label>                        
                                <label class="arealabel" for="areaInput1-citys-Input0">
                                <input type="checkbox" name="areaInputCitys" id="areaInput1-citys-Input0" value="82">安特卫普</label>
                                <label class="arealabel" for="areaInput1-citys-Input1">
                                <input type="checkbox" name="areaInputCitys" id="areaInput1-citys-Input1" value="83">西弗兰德</label>
                                <label class="arealabel" for="areaInput1-citys-Input2">
                                <input type="checkbox" name="areaInputCitys" id="areaInput1-citys-Input2" value="84">东弗兰德</label>    
                        </li>    
                        </ul>
                    </div>                
                </div>




    通过lable来控制 input的样式和选择状态。

    .newCityguide .addareaBox li .arealabel.checked {
        background-color: #e93854;
        color: #fff;
    }
    .newCityguide .addareaBox li .arealabel {
        display: inline-block;
        margin-bottom: 0.5em;
        margin-right: 0.5em;
        padding-bottom: 0.25em;
        padding-left: 0.5em;
        padding-right: 0.5em;
        padding-top: 0.25em;
         auto;
    }




    通过下面两行,获取input的上一级 label
                        thisstatelabelDoms = $(".arealabel");
                        console.log("thisstatelabelDoms:"+thisstatelabelDoms);
    然后通过绑定click事件,实现选择与否的状态切换
    thisstatelabelDoms.click(function(){});

    核心代码如下:

          //也不是没有bug,好像初始加载后,头次需要点两次才能实现checked状态的切换。
                    var thisstatelabelDoms;
                    if(conid){
                        thisstatelabelDoms = $(conid).find(".arealabel");
                        console.log("thisstatelabelDoms-confid:"+thisstatelabelDoms);
                    }else{
                        //input 上一级 label
                        thisstatelabelDoms = $(".arealabel");
                        console.log("thisstatelabelDoms:"+thisstatelabelDoms);
                    }

    //国家的父ID是states ;城市父ID是areaInput0-citys
                        var statesId = $(this).parent().attr("id");
                        var thisInpt = $(this).find("input[type=checkbox]");                
                        //状态
                        var thisinptckeck= thisInpt.attr("checked");
                        var contname=$(this).parent().html();
                        if(thisinptckeck=="checked"){
                            $(this).addClass("checked");
                            if(statesId=="states"){
                                var thisInptId = thisInpt.attr("id");
                                $("#"+thisInptId+"-citys").show();
                            }
                            $("#inputHidden").val(getCheckboxV);    
                        }else{                        
                            $(this).removeClass("checked");
                            if(statesId=="states"){
                                var thisInptId = thisInpt.attr("id");
                                $("#"+thisInptId+"-citys").hide();
                                $("#"+thisInptId+"-citys").find("label input[type=checkbox]").each(function(k,n){
                                    $(n).attr("checked",false);
                                    $(n).parent().removeClass("checked");
                                });
                            }
                            $("#inputHidden").val(getCheckboxV);
                        }        



    通过getCheckboxV函数,遍历获取选择的国家和城市ID

    function getCheckboxV(selecter){
        var thisSelecterDoms;
        var thisSelecterContDoms;
        var thisStr="";
    
            if(selecter){
                thisSelecterDoms = $(selecter);
                $(thisSelecterDoms).each(function(){
                    if($(this).find("input[type=checkbox]:checked").val() != undefined){
                     thisStr+=$(this).find("input[type=checkbox]:checked").val()+",";
                    }
                });
    
            }else{
                //cont id
                //注意同类input的写法$("input[name=areaInputConts]:checked"),name相同 checked状态相同
                thisSelecterContDoms = $("input[name=areaInputConts]:checked");
                $(thisSelecterContDoms).each(function(){
                    if($(this).val() != undefined){
                        //判断国家下是否有城市,没选城市flag=true,勾选了flag=false
                        var flag=true;
                        var thisContId = $(this).attr("id");        
                        $("#"+thisContId+"-citys").find("label input[type=checkbox]").each(function(k,n){
                                if($(n).attr("checked")=="checked")    {
                                    flag=false;
                                }
                            }
                        );                    
                        if(flag){
                            thisStr+=$(this).val()+",";    
                        }            
                    }
                });
                //city id  
                thisSelecterDoms = $("input[name=areaInputCitys]:checked");
                $(thisSelecterDoms).each(function(){
                    if($(this).val() != undefined){
                        thisStr+=$(this).val()+",";
                    }
                });
            }
        return thisStr;
    }                    

                    
                        
    也不是没有bug,好像初始加载后,头次需要点两次才能实现checked状态的切换。出现这样的问题,是因为click绑定在了label上了,改绑定到input上就不是响应两次了。。                    

  • 相关阅读:
    Button 的CommandName 用法
    如何循序渐进向DotNet架构师发展
    用sqlserver进行分布式查询(链接服务器)(转)
    关于.resx
    OO设计原则总结
    为ASP.NET 2.0网站生成唯一程序集
    依赖倒置、控制反转和依赖注入辨析(转)
    通过http地址获取页面内容
    Sql同表去除重复
    动态启动WCF服务
  • 原文地址:https://www.cnblogs.com/wellsoho/p/5067362.html
Copyright © 2011-2022 走看看