当前位置: 代码迷 >> JavaScript >> 百货公司简单产品筛选jq
  详细解决方案

百货公司简单产品筛选jq

热度:113   发布时间:2012-08-24 10:00:20.0
商城简单产品筛选jq
【1】初始状态,如图


【2】点击"电脑控温",“控温方式”这一栏隐藏,已选条件中显示“控温方式”,如图



求前段实现代码

------解决方案--------------------
花了我半个小时..
跟你搞定了. .
就是元素节点比较难找.
HTML code
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>360buy多条件筛选</title>
    <style type="text/css">
        #filter
        {
            width:620px;
            height:auto;
            margin-left:auto;
            margin-right:auto;
            font-size:12px;
        }
        
        #filter dl
        {
            padding:0;
            margin-top:0;
            margin-bottom:0;
            clear:both;
            padding:4px 0;        
        }
        
        #filter dt,dd
        {
            display:block;
            float:left;
            width:auto;
            padding:0;
            margin:3px 0;                       
        }
        
        #filter dt
        {
            height:14px;
            padding-bottom:4px;
            font-weight:bold;
            color:#333333;            
        }
        
        #filter dd
        {
            color:#005AA0;
            margin-right:8px;
        }
        
        #filter a
        {
            cursor:pointer;
        }
        
        .seling
        {
            background-color:#005AA0;
            color:#FFFFFF;
        }
        
        .seled
        {
            background-color:#005AA0;
            color:#FFFFFF;
        }
    </style>
</head>
<body>
    <div style="float:left;"><div style="float:left;">已选条件:</div><div id="condition" style="float:left;"></div></div>
    <div id="filter">
        <dl>
            <dt>品牌:</dt>
            <dd><div><a>全部</a></div></dd>
            <dd><div><a>惠普(hp)</a></div></dd>
            <dd><div><a>联想(Lenovo)</a></div></dd>
            <dd><div><a>联想(ThinkPad)</a></div></dd>
            <dd><div><a>宏基(acer)</a></div></dd>
            <dd><div><a>华硕</a></div></dd>
            <dd><div><a>戴尔</a></div></dd>
            <dd><div><a>三星</a></div></dd>
            <dd><div><a>索尼</a></div></dd>
            <dd><div><a>东芝</a></div></dd>
            <dd><div><a>Gateway</a></div></dd>
            <dd><div><a>微星</a></div></dd>
            <dd><div><a>海尔</a></div></dd>
            <dd><div><a>清华同方</a></div></dd>
            <dd><div><a>富士通</a></div></dd>
            <dd><div><a>苹果(Apple)</a></div></dd>
            <dd><div><a>神舟</a></div></dd>
            <dd><div><a>方正</a></div></dd>
            <dd><div><a>优雅</a></div></dd>
        </dl>
        <dl>
            <dt>价格:</dt>
            <dd><div><a>全部</a></div></dd>
            <dd><div><a>1000-2999</a></div></dd>
            <dd><div><a>3000-3499</a></div></dd>
            <dd><div><a>3500-3999</a></div></dd>
            <dd><div><a>4000-4499</a></div></dd>
            <dd><div><a>4500-4999</a></div></dd>
            <dd><div><a>5000-5999</a></div></dd>
            <dd><div><a>6000-6999</a></div></dd>
            <dd><div><a>7000-9999</a></div></dd>
            <dd><div><a>10000以上</a></div></dd>
        </dl>
        <dl>
            <dt>尺寸:</dt>
            <dd><div><a>全部</a></div></dd>
            <dd><div><a>8.9英寸及以下</a></div></dd>
            <dd><div><a>11英寸</a></div></dd>
            <dd><div><a>12英寸</a></div></dd>
            <dd><div><a>13英寸</a></div></dd>
            <dd><div><a>14英寸</a></div></dd>
            <dd><div><a>15英寸</a></div></dd>
            <dd><div><a>16英寸-17英寸</a></div></dd>
        </dl>
        <dl>
            <dt>平台:</dt>
            <dd><div><a>全部</a></div></dd>
            <dd><div><a>AMD Brazos APU平台</a></div></dd>
            <dd><div><a>Intel Sandy Bridge平台</a></div></dd>
            <dd><div><a>Intel平台</a></div></dd>
            <dd><div><a>AMD平台</a></div></dd>
        </dl>
        <dl>
            <dt>显卡:</dt>
            <dd><div><a>全部</a></div></dd>
            <dd><div><a>独立显卡</a></div></dd>
            <dd><div><a>集成显卡</a></div></dd>
            <dd><div><a>核芯显卡</a></div></dd>            
        </dl>
    </div>
<script type="text/javascript" src="jquery-1.7.2.js"></script>
<script type="text/javascript">
var abc = [];
    $(function () {
        //选中filter下的所有a标签,为其添加hover方法,该方法有两个参数,分别是鼠标移上和移开所执行的函数。
        $("#filter a").hover(
            function () {
                $(this).addClass("seling");
            },
            function () {
                $(this).removeClass("seling");
            }
        );


        //选中filter下所有的dt标签,并且为dt标签后面的第一个dd标签下的a标签添加样式seled。(感叹jquery的强大)
        $("#filter dt+dd a").attr("class", "seled"); /*注意:这儿应该是设置(attr)样式,而不是添加样式(addClass),
                                                      不然后面通过$("#filter a[class='seled']")访问不到class样式为seled的a标签。*/       

        //为filter下的所有a标签添加单击事件
        $("#filter a").click(function () {
            $(this).parents("dl").children("dd").each(function () {
                $(this).children("div").children("a").removeClass("seled");
            });
            $(this).attr("class", "seled");
            var needhide = $(this);
            needhide.parentsUntil("dl").parent().hide();
            abc.push(needhide);
            var val = $(this).html().replace(/ /g, "kongge");
            var condition = '<div rel="'+$(this).html()+'" style="border:1px solid #006699;">'+$(this).html()+'<span stlye="float:right;border:1px solid #ff9900;" onclick=deleteC("'+val+'")>X</span></div>';
            $("#condition").append(condition);
           // alert(RetSelecteds()); //返回选中结果
        });
       // alert(RetSelecteds()); //返回选中结果
    });
    
    
    function deleteC(v) {
        var val = v.replace(/kongge/g, " ");
        $("#condition").find("div[rel='"+val+"']").remove();
        for(var i = 0; i<abc.length; i++){
            if(abc[i].html() == val){
                abc[i].parentsUntil("dl").parent().show();
                abc.splice(i, 1);
                i--;
            }else{
            abc[i].parentsUntil("dl").parent().hide();
            }
        }
    }
    function RetSelecteds() {
        var result = "";
        $("#filter a[class='seled']").each(function () {
            result += $(this).html()+"\n";
        });
        return result;
    }
</script>
</body>
</html> 
  相关解决方案