开发者

End user add values to a dropdownlist?

开发者 https://www.devze.com 2022-12-17 23:31 出处:网络
I\'m populating a dropdownlist in c# asp.net-MVC from a SQL table using Linq2Sql.I\'d like for the user to be able to enter something that isn\'t in the list into the drop down and ha开发者_开发问答ve

I'm populating a dropdownlist in c# asp.net-MVC from a SQL table using Linq2Sql. I'd like for the user to be able to enter something that isn't in the list into the drop down and ha开发者_开发问答ve it add to the table. Is this possible?


Sounds like you need to add a radio button labeled "Other". When the user clicks the radio button a text box would appear that allows the user to input a new value that you can save to your DB and display in the drop down.

EDIT:
Quick snippet to enable the control using JavaScript:

    <script language="javascript" type="text/javascript">
       function radioclicked() {
        textObj = document.getElementById('<NAME OF TEXT BOX');
        textObj.disabled = false;
        }     
    </script>

You can use a check box instead of a radio button so that the enabled property can be toggled.

To completely hide the text box then you will have to look into jQuery/Ajax.


Why can't we use a lightweight Add-on like www.combodropdown.info for this purpose? You can even consider AutoComplete plugin from jQuery, if your app already references jQuery.


Also a combobox will allow a user to enter a value in addition to picking from a list.


My MVC is not so so, but I assume this still applies as MVC is just model view controller. What if you throw a drop down on your form visible=true, and a textbox on your form visible =false.

<asp:DropDownList ID="DropDownList1" runat="server" AutoPostBack="True" 
    onselectedindexchanged="DropDownList1_SelectedIndexChanged">
</asp:DropDownList>
<asp:TextBox ID="TextBox1" runat="server" Visible="False"></asp:TextBox>

Fill your drop down:

  protected void Page_Load(object sender, EventArgs e)
    {
        if (!Page.IsPostBack)
        {
            List<int> s = Enumerable.Range(1, 10).ToList();
            DropDownList1.DataSource = s;
            DropDownList1.DataBind();

            DropDownList1.Items.Add("Other");
        }
    }

Add an event to handle if someone selects other. If they do make the textbox visible:

protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
    switch (this.DropDownList1.SelectedItem.Text)
        {
        case "Other":
            this.TextBox1.Visible=true;
            break;
        default:
            this.TextBox1.Visible=false;
            break;
        }
}

Now you can enter your value and re-store back to the db.

0

精彩评论

暂无评论...
验证码 换一张
取 消