zoukankan      html  css  js  c++  java
  • jquery无限级联数据

    (function ($) {
        $.extend($.fn, {
            lSelect: function (options) {
    
                // 默认参数
                var settings = {
                    url: "", // 数据获取url
                    parameter: "pid", // 数据获取参数名称
                    title: "title", // 定义JSON数据格式:选择名称
                    value: "value", // 定义JSON数据格式:选择值
                    emptyOption: "请选择", // 选择提示,null表示无提示
                    cssClass: "lSelect", // 下拉框css名称
                    cssStyle: { "margin-right": "10px" }, // 下拉框左右css样式
                    isFadeIn: true// 是否渐显
                };
                $.extend(settings, options);
    
                return this.each(function () {
    
                    var $this = $(this);
                    $this.hide();
                    var selectGroupClass = "lSelect" + Math.round(Math.random() * 1000000);
                    var items = {};
                    var selectName = $this.attr("name");
                    var defaultSelectedPath = $this.attr("defaultSelectedPath");
    
                    if (defaultSelectedPath == null || defaultSelectedPath == "") {
                        addSelect($this);
                    } else {
                        var $select = $this;
                        var defaultSelectedPathArray = defaultSelectedPath.split(",");
                        for (var i = 0; i < defaultSelectedPathArray.length; i++) {
                            var $nextSelect = addSelect($select, defaultSelectedPathArray[i]);
                            if ($nextSelect) {
                                $select = $nextSelect;
                            }
                        }
                    }
    
                    // 绑定Select元素
                    function bindSelect(element) {
                        element.bind("change", function () {
                            addSelect(element);
                            $this.val(element.val());
                        });
                    }
    
                    // 获取Json数据
                    function getJson(key) {
                        if (typeof (items[key]) == "undefined") {
                            var url = settings.url;
                            if (key != "lSelectRoot") {
                                var parameter = settings.parameter;
                                if (parameter != null) {
                                    if (url.indexOf("?") > 0) {
                                        url = url + "&" + parameter + "=" + key;
                                    } else {
                                        url = url + "?" + parameter + "=" + key;
                                    }
                                }
                            }
                            $.ajaxSetup({ cache: true, async: false }); //新增cache
                            $.getJSON(url, function (json) {
                                items[key] = json;
                            });
                        }
                        return items[key];
                    }
    
                    // 填充option
                    function fill(element, key, selected) {
                        var json = getJson(key);
                        if (!json) {
                            return false;
                        }
                        var length = 0;
                        for (j in json) {
                            length++;
                        }
                        if (length == 0) {
                            return false;
                        } else {
                            element.empty();
                            if (settings.emptyOption != null) {
                                element.append('<option value="">' + settings.emptyOption + '</option>');
                            }
                            $.each(json, function (id, object) {
                                var optionValue = "";
                                if (object.value.indexOf(",") >= 0) {
                                    var optionValueArray = object.value.split(",");
                                    optionValue = optionValueArray[optionValueArray.length - 1];
                                } else {
                                    optionValue = object.value;
                                }
    
                                var option;
                                if (selected && optionValue == selected) {
                                    option = $('<option value="' + object.value + '" selected>' + object.title + '</option>');
                                } else {
                                    option = $('<option value="' + object.value + '">' + object.title + '</option>');
                                }
                                element.append(option);
                            });
                            return true;
                        }
                    }
    
                    // 增加select
                    function addSelect(element, selected) {
                        var $nextSelect;
                        var isFill;
                        if (element.is("select")) {
                            element.nextAll("." + selectGroupClass).remove();
                            if (element.val() == "") {
                                return;
                            }
                            element.after('<select class="' + settings.cssClass + ' ' + selectGroupClass + '" style="display: none;"></select>');
                            $nextSelect = element.next("." + selectGroupClass);
                            isFill = fill($nextSelect, element.val(), selected);
                        } else {
                            element.after('<select class="' + settings.cssClass + ' ' + selectGroupClass + '" style="display: none;"></select>');
                            $nextSelect = element.next("." + selectGroupClass);
                            isFill = fill($nextSelect, "lSelectRoot", selected);
                        }
                        if (isFill) {
                            element.css(settings.cssStyle);
                            if (settings.isFadeIn) {
                                $nextSelect.fadeIn();
                            } else {
                                $nextSelect.show();
                            }
                            bindSelect($nextSelect);
                            return $nextSelect;
                        } else {
                            $nextSelect.remove();
                        }
                    }
                });
    
            }
        });
    })(jQuery);
    <%@ WebHandler Language="C#" Class="ProType" %>
    
    using System;
    using System.Web;
    using System.Data;
    
    public class ProType : IHttpHandler {
        
        public void ProcessRequest (HttpContext context) {
            context.Response.ContentType = "text/plain";        
            Util gj = new Util();
            int pid = gj.getQueryStringInt("pid");
            MySqlExecute mse = new MySqlExecute();
            DataTable dt = mse.getDT("select ID,Name from TB_ProductType where Pid=" + pid);
            if (dt != null && dt.Rows.Count > 0)
            {
                System.Text.StringBuilder sb = new System.Text.StringBuilder();
                foreach (DataRow dr in dt.Rows)
                {
                    sb.Append(",{\"value\":\"" + dr["ID"] + "\",\"title\":\"" + dr["Name"] + "\"}");
                }
                if (sb.Length > 0)
                {
                    context.Response.Write("[" + sb.ToString().Substring(1) + "]");
                }
                else
                {
                    context.Response.Write("[]");
                }
            }
            else
            {
                context.Response.Write("[]");
            }
        }
     
        public bool IsReusable {
            get {
                return false;
            }
        }
    
    }
    
  • 相关阅读:
    十招教你从屌丝变身高富帅【转】
    无法在证书存储区中找到清单签名证书”错误的解决方法【转】
    上传头像进行裁剪——jQuery + HttpHandler 实现图片裁剪(适用于论坛, SNS)【转】
    在类库中获得Session值
    WinForm中Combobox绑定值问题
    Global.cs中自动获取未处理的异常
    程序员的7个坏习惯【转】
    外部JS文件中获取ASPX页面上服务器控件ClientID
    如何使用微软企业库
    防止代码腐烂【转】
  • 原文地址:https://www.cnblogs.com/daixingqing/p/2978625.html
Copyright © 2011-2022 走看看