• 可输入的 Combox(DropDownList)


    aspx页面中需要可以输入的combox,在网上找了一个js的插件,效果图如下:

    前台代码

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="InputComBox.aspx.cs" Inherits="School.Web.TestDemo.InputComBox" %>
    
    <!DOCTYPE html>
    
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>可输入的combox</title>
        <link type="text/css" href="/Scripts/jquery-1.10.4/jquery-ui.min.css" rel="stylesheet" />
        <script type="text/javascript" src="/Scripts/jquery-1.10.4/jquery.min.js"></script>
        <script type="text/javascript" src="/Scripts/jquery-1.10.4/jquery-ui.min.js"></script>
        <style type="text/css">
            .appcusser li a {
                 32px;
                background: url(/Images/pro_down.gif);
                float: left;
                display: block;
                height: 33px;
                line-height: 30px;
                text-align: center;
                color: #2b7fbf;
                font-weight: bold;
                margin-right: 5px;
            }
    
            .appcusser li span {
                display: block;
                float: left;
                 100px;
                text-align: right;
                padding-right: 5px;
                color: #666;
            }
            .appcusser li label {
                display: block;
                float: left;
                line-height: 28px;
                margin-right: 5px;
            }
    
            ul, li {
                list-style: none;
            }
    
            .custom-combobox {
                position: relative;
                display: inline-block;
            }
    
            .custom-combobox-toggle {
                position: absolute;
                top: 5px;
                bottom: 0;
                left: 160px;
                top: 0;
                padding: 0;
                height: 32px;
                /* 支持: IE7 */
                *height: 1.7em;
                *top: 0.1em;
            }
    
            .custom-combobox-input {
                margin: 0;
                padding: 0.3em;
                background-color: #fff;
                background-image: none;
                color: #333;
                height: 22px;
                 150px;
            }
    
            .hideA {
                background: #f3f3f3;
            }
    
            .clear {
                clear: both;
                height: 0;
                overflow: hidden;
            }
        </style>
        <script type="text/javascript">
            (function ($) {
                $.widget("custom.combobox", {
                    _create: function () {
                        this.wrapper = $("<span>")
                          .addClass("custom-combobox")
                          .insertAfter(this.element);
    
                        this.element.hide();
                        this._createAutocomplete();
                        this._createShowAllButton();
                    },
    
                    _createAutocomplete: function () {
                        var selected = this.element.children(":selected"),
                          value = selected.val() ? selected.text() : "";
    
                        this.input = $("<input>")
                          .appendTo(this.wrapper)
                          .val(value)
                          .attr("id", "btnShowPro")
                          .addClass("custom-combobox-input ui-widget ui-widget-content ui-state-default ui-corner-left")
                            .addClass(" validate[required,maxSize[200]]")
                          .autocomplete({
                              delay: 0,
                              minLength: 0,
                              source: $.proxy(this, "_source")
                          })
                          .tooltip({
                              tooltipClass: "ui-state-highlight"
                          });
    
                        this._on(this.input, {
                            autocompleteselect: function (event, ui) {
                                ui.item.option.selected = true;
                                this._trigger("select", event, {
                                    item: ui.item.option
                                });
                            },
    
                            autocompletechange: "_removeIfInvalid"
                        });
                    },
    
                    _createShowAllButton: function () {
                        var input = this.input,
                          wasOpen = false;
    
                        $("<a>")
                          .attr("tabIndex", -1)
                          //.attr("title", "aShow")
                          .attr("id", "aShow")
                          //.tooltip()
                          .appendTo(this.wrapper)
                          .button({
                              //icons: {
                              //    primary: "ui-icon-triangle-1-s"
                              //},
                              text: false
                          })
                          .removeClass("ui-corner-all")
                          .addClass("custom-combobox-toggle ui-corner-right")
                          .mousedown(function () {
                              wasOpen = input.autocomplete("widget").is(":visible");
                          })
                          .click(function () {
                              input.focus();
    
                              // 如果已经可见则关闭
                              if (wasOpen) {
                                  return;
                              }
    
                              // 传递空字符串作为搜索的值,显示所有的结果
                              input.autocomplete("search", "");
                          });
                    },
    
                    _source: function (request, response) {
                        var matcher = new RegExp($.ui.autocomplete.escapeRegex(request.term), "i");
                        response(this.element.children("option").map(function () {
                            var text = $(this).text();
                            if (this.value && (!request.term || matcher.test(text)))
                                return {
                                    label: text,
                                    value: text,
                                    option: this
                                };
                        }));
                    },
    
    
                    _removeIfInvalid: function (event, ui) {
    
                        // 选择一项,不执行其他动作
                        if (ui.item) {
                            return;
                        }
    
                        // 搜索一个匹配(不区分大小写)
                        var value = this.input.val(),
                          valueLowerCase = value.toLowerCase(),
                          valid = false;
                        this.element.children("option").each(function () {
                            if ($(this).text().toLowerCase() === valueLowerCase) {
                                this.selected = valid = true;
                                return false;
                            }
                        });
    
                        // 找到一个匹配,不执行其他动作
                        if (valid) {
                            return;
                        }
    
                        // 移除无效的值
                        //this.input
                        //  .val("")
                        //  .attr("title", value + " didn't match any item")
                        //  .tooltip("open");
                        this.element.val("");
                        this._delay(function () {
                            this.input.tooltip("close").attr("title", "");
                        }, 2500);
                        //this.input.data("ui-autocomplete").term = "";
                    },
    
                    _destroy: function () {
                        this.wrapper.remove();
                        this.element.show();
                    }
                });
            })(jQuery);
    
            $(function () {
                $("#<%=ddlName.ClientID%>").combobox();
                $("#toggle").click(function () {
                    $("#<%=ddlName.ClientID%>").toggle();
                });
            });
        </script>
    </head>
    <body>
        <form id="form1" runat="server">
            <div>
                <ul class="appcusser">
                    <li>
                        <span><asp:TextBox ID="txtID" runat="server" Width="80"></asp:TextBox></span>
                        <label><asp:DropDownList ID="ddlName" runat="server" CssClass="app_txt2 fl"></asp:DropDownList></label>
                        <div class="clear"></div>
                    </li>
                    <li>
                        <asp:Button ID="btnSeach" Text="查询" runat="server" />
                    </li>
                </ul>
            </div>
        </form>
    </body>
    </html>
    

     后台代码

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    
    namespace School.Web.TestDemo
    {
        public partial class InputComBox : System.Web.UI.Page
        {
            protected void Page_Load(object sender, EventArgs e)
            {
                string tID = txtID.Text.Trim();
                //if (!IsPostBack)
                //{
                    if (string.IsNullOrEmpty(tID))
                    {
                        BindDrop();
                        ddlName.Items.Insert(0, new ListItem(" ", ""));
                    }
                    else
                    {
                        BindDrop();
                        int id = 0;
                        int.TryParse(tID, out id);
                        Bind(id);
                    }
                //}
            }
    
            public void Bind(int id)
            {
                Student student = InitData().SingleOrDefault(s => s.ID == id);
                if (student != null)
                {
                    if (ddlName.Items.Contains(new ListItem(student.userName))) //判断ddlName下拉列表中是否存在该值,存在则赋值,不存在则插入ddlName下拉列表中
                    {
                        ddlName.SelectedValue = student.userName;
                    }
                    else
                    {
                        ddlName.Items.Insert(0, new ListItem(txtID.Text.Trim()));
                    }
                }
                else
                {
                    ddlName.Items.Insert(0, new ListItem(txtID.Text.Trim()));
                }
            }
    
            public void BindDrop()
            {
                ddlName.DataSource = InitData();
                ddlName.DataTextField = "userName"; //ddlName中DataTextField和DataValueField设置为同一个值,在查询是否存在该值是才可以;或者new ListItem("text", "value")设置text、value值不一样
                ddlName.DataValueField = "userName";
                ddlName.DataBind();
            }
    
    
            public List<Student> InitData()
            {
                List<Student> listStudent = new List<Student>();
                for (int i = 1; i < 11; i++)
                {
                    Student student = new Student();
    
                    student.ID = i;
                    student.userName = "学生" + i;
                    student.passWord = "123456";
                    student.Age = i + 20;
                    student.Address = "北京市顺义区天竺镇" + i + "区";
                    listStudent.Add(student);
                }
                return listStudent;
            }
        }
    
    
        public class Student
        {
            public int ID { get; set; }
            public string userName { get; set; }
    
            public string passWord { get; set; }
    
            public int Age { get; set; }
    
            public string Address { get; set; }
        }
    }
    
  • 相关阅读:
    精准医疗
    生物信息学的研究过程
    蛋白质结构预测
    CP
    基因组大小控制因素
    RNA组研究困难
    输入input文本框的 U+202D和U+202C是什么
    ruby-get-url-query-params
    golang send post request
    nginx location配置
  • 原文地址:https://www.cnblogs.com/ZJ199012/p/5694403.html
Copyright © 2020-2023  润新知