SELECT2 4.0 与 ASP.Net 中的多选:如何获取和设置所选项目?

Posted

技术标签:

【中文标题】SELECT2 4.0 与 ASP.Net 中的多选:如何获取和设置所选项目?【英文标题】:SELEC2 4.0 with multi select in ASP.Net: How to get and set selected items? 【发布时间】:2016-04-15 01:39:07 【问题描述】:

我正在尝试将 ASP.Net 中的 SELECT2 与下拉列表结合使用。

这是我的 .aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="default.aspx.cs" Inherits="ASPNet_SELECT2_1._default" %>

<!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>a SELECT2 implementation in ASP.NET</title>
    <script src="scripts/js/jquery-1.12.0.js"></script>
    <script src="scripts/js/select2/select2.js"></script>
    <link rel="stylesheet" href="css/select2.css" />

    <script>
            $(document).ready(function () 
                $("#" + "<%=dd.ClientID%>").select2(
                placeholder: "Select a Subject",
                allowClear: true
            );
        );
    </script>
</head>
<body>
    <form id="form1" runat="server">
        <div>
            <asp:DropDownList ID="dd" runat="server" ClientIDMode="Static" Width="300px" multiple="multiple"></asp:DropDownList>
        </div>
        <asp:Button ID="btnGetSelected" runat="server" Text="Get selected items" OnClick="btnGetSelected_Click" />&nbsp;<asp:Button ID="btnSetSelected" runat="server" Text="Set selected items" OnClick="btnSetSelected_Click" />
        <br />
        <asp:Literal ID="lit" runat="server"></asp:Literal>
    </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 ASPNet_SELECT2_1

    public partial class _default : System.Web.UI.Page
    
        protected void Page_Load(object sender, EventArgs e)
        
            if (!Page.IsPostBack)
            
                for (int i = 0; i < 10; i++)
                
                    ListItem l = new ListItem("Item " + i.ToString());
                    dd.Items.Add(l);
                
            
        

        protected void btnGetSelected_Click(object sender, EventArgs e)
        
            lit.Text = dd.Text;
        

        protected void btnSetSelected_Click(object sender, EventArgs e)
        

        
    

SELECT2 控件与我的下拉列表的绑定工作正常。我还为下拉列表设置了“多个”属性以具有多选功能。但我无法获得选定的项目。我也无法设置这些项目。

当我选择多个元素并执行回发(例如单击按钮)时,回发后仅选择一项。而且我总是得到选中的第一个项目。

如何获取所有选定项目并在回发时以及通过代码设置多个选定项目?

【问题讨论】:

【参考方案1】:

我已经通过使用带有 runat="server" 的 HTML 选择标记而不是使用 DropDownList 解决了这个问题,因为我认为 Postback 功能等是默认在控件中实现的,并且无法轻松更改。

这是我的 JS

$(document).ready(function () 
    $("#select1").select2(
        placeholder: "Select a Subject",
        allowClear: true
    );
);

这是我的 .aspx

<select id="select1" name="select1" runat="server" multiple="true" style="width:300px"></select>

这是我在 C# 中的代码隐藏,用于填充选择中的项目

for (int i = 0; i < 10; i++)

    ListItem l = new ListItem("Item " + i.ToString(), i.ToString());
    select1.Items.Add(l);

这是获取和设置所选项目的方式

// GET SELECTED ITEMS
for (int i = 0; i <= select1.Items.Count - 1; i++)

    if (select1.Items[i].Selected)
        lit.Text += "<br /> &nbsp;&nbsp; - " + select1.Items[i].Text + " | " + select1.Items[i].Value;


// SET SELECTED ITEMS
select1.Items[2].Selected = true;
select1.Items[4].Selected = true;

【讨论】:

以上是关于SELECT2 4.0 与 ASP.Net 中的多选:如何获取和设置所选项目?的主要内容,如果未能解决你的问题,请参考以下文章

Gridview 中的 Select2 插件仅适用于 asp.net 中的最后一行网格

无法让 select2.js ajax 与 asp.net webform 一起使用

使用 select2 与 ajax 调用 asp.Net 服务自定义参数

在 C# 的 asp.net 下拉列表中的 select2 上设置多个选定值

jquery select2 与下拉列表 asp.net 服务器控件一起使用

如何对asp.net mvc 4中的select2字段进行强制字段验证