javascript - 在 ASP.NET Core MVC 应用程序中的 Controller 和 JavaScript 之间传递参数?

标签 javascript c# jquery asp.net-core asp.net-core-mvc

我有一个 ASP.NET Core MVC 应用程序,其中包含 View 、 Controller 和一个小的 JavaScript 文件。当用户单击列表框中的项目时,将调用 JavaScript 函数。 JavaScript 调用 Controller 上的函数, Controller 创建 SelectedListItem 列表并设置“Selected”、“Value”和“Text”的值。 “选定”设置为true

我注意到,当 JavaScript 函数接收数据时,一切都是正确的,但“选定”字段设置为 false”,我不确定这是怎么回事。感谢您的帮助!

查看

        <div class="form-group">
          @Html.LabelFor(x => Model.SelectedBaselines, htmlAttributes: new { @class = "col-form-label" })
          @Html.ListBoxFor(x => Model.SelectedBaselines, new SelectList(Model.BaselinesList, "Value", "Text"), htmlAttributes: new { @class = "form-control", id = "baselines", @multiple = true, size = "10", style = "width:200px;" })
          @Html.ValidationMessageFor(x => Model.SelectedBaselines, "", new { @class = "text-danger" })
        </div>

enter image description here

Controller

public IEnumerable<SelectListItem> GetSelectedBaselines(string meterId)
{
  IQueryable<SelectListItem> baselines =
    from mlookup in _dbContext.MeterBaselineLookup.AsNoTracking()
    join baseline in _dbContext.MeterBaseline on mlookup.MeterBaselineId equals baseline.Id
    where mlookup.MeterId == Convert.ToInt32(meterId)
    orderby baseline.Id
    select new SelectListItem
    {
      Selected = true,
      Value = baseline.Id.ToString(),
      Text = baseline.Name
    };

  return new SelectList(baselines, "Value", "Text");
}

enter image description here

JavaScript

$('#meters').change(function() {
    var url = "/Meters/GetSelectedBaselines";

    $.getJSON(url,
        { meterId: $("#meters option:selected").val() },
        function(data) {

            $('#baselines option').prop('selected', false); // Clear selected baselines

            var len = $('#baselines option').length;

            for (var i = 1; i <= len; i++) {  
                $("#baselines option[value=" + i + "]").attr("selected", true);
            }  
        });
});

最佳答案

尝试在下面返回

public IEnumerable<SelectListItem> GetSelectedBaselines(string meterId)
{
 IQueryable<SelectListItem> baselines =
from mlookup in _dbContext.MeterBaselineLookup.AsNoTracking()
join baseline in _dbContext.MeterBaseline on mlookup.MeterBaselineId equals baseline.Id
where mlookup.MeterId == Convert.ToInt32(meterId)
orderby baseline.Id
select new SelectListItem
{
  Selected = true,
  Value = baseline.Id.ToString(),
  Text = baseline.Name
};

return baselines ;

}

相关问题引用链接:

https://stackoverflow.com/a/25714016/10201850 https://forums.asp.net/t/1382564.aspx?SelectListItem+losting+select+value+in+View+page

关于javascript - 在 ASP.NET Core MVC 应用程序中的 Controller 和 JavaScript 之间传递参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55520616/

相关文章:

javascript - ng-bind-html 不能正常工作

c# - 如何从另一个类或窗口访问 WPF 中的控件

javascript - 请求问题 : Uncaught SyntaxError: Unexpected token/

jquery - 在html元素中动态保存数据

Javascript/jquery setTimeout 变得更快

javascript - OnSen UI 滑动菜单未出现

javascript - 如何提醒javascript对象

javascript - 删除包装 div

c# - 对于传入并需要转换为通用参数的对象,抛出什么适当的异常?

c# - 如何在运行时更改按钮的背景图像?