在剃刀中下拉列表刷新

时间:2015-03-24 04:57:15

标签: c# jquery asp.net-mvc asp.net-mvc-4 razor

我有一个表示状态的下拉列表,根据选择的状态,我需要刷新城市下拉列表,该列表代表所选州的城市。如何刷新城市下拉?

这是我的代码:

 public class AccountController : Controller
        {
    public static List<SelectListItem> StateListItem()
            {
                var stateList = new List<SeraydarBL.Accounts.State>();
                var selectListItems = new List<SelectListItem>();
                stateList = SeraydarBL.Accounts.SelectStates();
                foreach (var state in stateList)
                {
                    var selectListItem = new SelectListItem();
                    selectListItem.Text = state.name;
                    selectListItem.Value = state.id.ToString();
                    selectListItems.Add(selectListItem);
                }
                return selectListItems;
            }

}

这是剃刀:

    @using (Html.BeginForm())
    {
        <fieldset>
            <legend>Registration Form</legend>
            <ol>
                <li>
        //-------------------------------------------------------
        var stateList = new List<SelectListItem>();
        stateList = AccountController.StateListItem();
                    }


                    @Html.LabelFor(model => model.StateId)
                    @Html.DropDownListFor(model => model.StateId, stateList, " Select your State ...")
                    @Html.ValidationMessageFor(m => m.StateId)

                    @*HERE MUST BE THE DROP DOWN LIST OF CITIES*@


                </li>
            </ol>
            <input type="submit" value="Register" />
        </fieldset>


    <script>
        $('#StateId').change(function () {

        });

    </script>
}

1 个答案:

答案 0 :(得分:0)

您可以使用jquery ajax调用来实现此目的。

 <script type="text/javascript">
    $(document).ready(function () {
        //Dropdownlist Selectedchange event
        $("#StateId").change(function () {
            $("#CityId").empty();
            $.ajax({
                type: 'POST',
                url: '@Url.Action("GetCity")', 
                dataType: 'json',
                data: { id: $("#StateId").val() },
                success: function (cities) {
                    $.each(cities, function (i, city) {
                        $("#CityId").append('<option value="' + city.Value + '">' +``});
                },
                error: function (ex) {
                    alert('Failed to retrieve states.' + ex);
                }
            });
            return false;
        })
    });
</script>

参考几篇文章

http://www.codeproject.com/Articles/730953/Cascading-Dropdown-List-With-MVC-LINQ-to-SQL-and-A http://www.c-sharpcorner.com/UploadFile/4d9083/creating-simple-cascading-dropdownlist-in-mvc-4-using-razor/