jquery 無限極下拉列表

 <PHP天工作需要寫樹形的聯動,於是寫了個可擴展的無限極聯動下拉選項
代碼寫的比較凌亂 先mark有空再整理spacer.gif

隨便截個圖!
先貼數據庫
idcategory_name 分類名pid 父分類idorders 排序122223331012222211111124444411052222116222211113332013555555120
頁面代碼 用的SMARTY

複製代碼 代碼如下:

<div id="select" >
    <select name="category_1" id="category_1" onChange="change(category_1);">
        <option>請選擇分類</option>
        <!-- {foreach from=$galleryCategory item=category} -->
            <option value="{$category.id}">{$category.category_name}</option>
        <!-- {/foreach} -->    
    <spacer.giflect>
</div>

$galleryCategory 去數據的PHP代碼爲

複製代碼 代碼如下:

$sql = " select * from yl_gallery_category where pid = 0"; 
$galleryCategory = $db->query($sql); 
$smarty->assign("galleryCategory",$galleryCategory); 

用的原生態代碼 還是比較容易理解的
然後就是關鍵的 JS代碼了function change(val) {

複製代碼 代碼如下:

var str = val; /spacer.giflect的id
    var num; //當前級數
    var id; // 分類id
    num = str.substr(9,10);
    //alert(num);
    var nownum = parseInt(num)+1; // 將字符串轉換爲數字
    id = $("#"+str+"").val();
    var r = /^[1-9]+[0-9]*]*$/; //正整數
    if (!r.test(id)) {
        //清空過時的選項
        $("select").each(function(index){
            if(index+1 > num) {
                $(this).remove();
            }
        })

        return false;
    }
    var url = gallery.php?act=category&pid=+id;
    $.ajax({
        type: "POST",
        cache: false,
        url: url,
        datatype : json,
        timeout : 3000,
        success: function(result){
            if ( result != 0) {    
                var html = "<select name=category_"+nownum+"     id=category_"+nownum+"  onChange=change(category_"+nownum+"); >";
                html += "<option>請選擇分類 </option>";
                var datas = eval(result);
                $.each(datas, function(i,val){      
                    html += "<option value="+val.id+" >"+val.category_name+"</option>";
                });   
                html += "<spacer.giflect>";

                //清空過時的選項
                $("select").each(function(index){
                    if(index+1 > num) {
                        $(this).remove();
                    }
                })

                $("#select").append(html);
            } else {
          //清空過時的選項
                $("select").each(function(index){
                    if(index+1 > num) {
                        $(this).remove();
                    }
                })       }

        },
        error: false
    });

}

AJAX 取數據的PHP代碼 

複製代碼 代碼如下:

$sql = " select * from yl_gallery_category where pid = " .$pid; 
    $res = $db->query($sql); 
    if (empty($res)) { 
        $res = 0; 
    } 
    echo json_encode($res); 

OK 大功告成! 


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章