MVC DropDownList OnChange to update other form fields

后端 未结 2 1673
余生分开走
余生分开走 2021-01-31 20:40

I am new to MVC (I am moving over from the dark side of traditional ASP.Net) and I know that SO is more of a \"why doesn\'t this work\" but, being new to MVC, I just wanted to

相关标签:
2条回答
  • 2021-01-31 20:42
    1. Make a Controller "Action" that return "Json" data.
    2. Make Ajax call "onchange" of dropdown to that "Action".
    3. On ajax "response" (json) u will get values then set those values to fields from json response.

    This is the way to update field values.

    0 讨论(0)
  • 2021-01-31 21:03

    In Asp.Net MVC, There is no postback behaviour like you had in the web forms when a control value is changed. You can still post the form and in the action method, you may read the selected value(posted value(s)) and load the values for your text boxes and render the page again. This is complete form posting. But there are better ways to do this using ajax so user won't experience the complete page reload.

    What you do is, When user changes the dropdown, get the selected item value and make a call to your server to get the data you want to show in the input fields and set those.

    Create a viewmodel for your page.

    public class CreateViewModel
    {
        public int Width { set; get; }
        public int Height{ set; get; }
    
        public List<SelectListItem> Widgets{ set; get; }
    
        public int? SelectedWidget { set; get; }    
    }
    

    Now in the GET action, We will create an object of this, Initialize the Widgets property and send to the view

    public ActionResult Create()
    {
      var vm=new CreateViewModel();
      //Hard coded for demo. You may replace with data form db.
      vm.Widgets = new List<SelectListItem>
                {
                    new SelectListItem {Value = "1", Text = "Weather"},
                    new SelectListItem {Value = "2", Text = "Messages"}
                };
     return View(vm);
    }
    

    And your create view which is strongly typed to CreateViewModel

    @model ReplaceWithYourNamespaceHere.CreateViewModel
    @using(Html.BeginForm())
    {
        @Html.DropDownListFor(s => s.SelectedWidget, Model.Widgets, "Select");
    
        <div id = "editablePane" >
             @Html.TextBoxFor(s =>s. Width,new { @class ="myEditable", disabled="disabled"})
             @Html.TextBoxFor(s =>s. Height,new { @class ="myEditable", disabled="disabled"})
        </div>
    }
    

    The above code will render html markup for the SELECT element and 2 input text fields for Width and Height. ( Do a "view source" on the page and see)

    Now we will have some jQuery code which listens to the change event of the SELECT element and reads the selected item value, Makes an ajax call to server to get the Height and Width for the selected widget.

    <script type="text/javascript">
     $(function(){
    
          $("#SelectedWidget").change(function() {
    
                var t = $(this).val();
    
                if (t !== "") {               
                    $.post("@Url.Action("GetDefault", "Home")?val=" + t, function(res) {
                        if (res.Success === "true") {
    
                          //enable the text boxes and set the value
    
                            $("#Width").prop('disabled', false).val(res.Data.Width);
                            $("#Height").prop('disabled', false).val(res.Data.Height);
    
                        } else {
                            alert("Error getting data!");
                        }
                    });
                } else {
                    //Let's clear the values and disable :)
                    $("input.editableItems").val('').prop('disabled', true);
                }
    
            });
     });
    
    </script>
    

    We need to make sure that we have an action method called GetDetault inside the HomeController to handle the ajax call.

    [HttpPost]
    public ActionResult GetDefault(int? val)
    {
        if (val != null)
        {
            //Values are hard coded for demo. you may replae with values 
           // coming from your db/service based on the passed in value ( val.Value)
    
            return Json(new { Success="true",Data = new { Width = 234, Height = 345}});
        }
        return Json(new { Success = "false" });
    }
    
    0 讨论(0)
提交回复
热议问题