【问题标题】:Blazor binding multiple select to a valueBlazor 将多选绑定到一个值
【发布时间】:2021-08-24 10:28:03
【问题描述】:

我正在尝试将多选绑定到一个值,然后将其传递给模型,但目前它只返回一个值,我尝试将其从字符串更改为字符串数组但出现很多错误并且无法找到解决办法。

有谁知道我如何返回用户选择的所有值?

谢谢!

<div class="form-group col-md-6">
   <label for="dur">Duration</label>
   <select @bind="Duration" class="custom-select" id="dur" multiple>
      <option value="12" selected>One Year</option>
      <option value="24">Two Year</option>
      <option value="36">Three Year</option>
      <option value="48">Four year</option>
      <option value="60">Five Year</option>
   </select>
   <small class="form-text text-muted">Hold <b>'CTRL'</b> to select multiple.</small>
</div>

@code {

 private string _Duration;

       private string Duration
        {
            get => _Duration;
            set
            {
                if (value != _Duration)
                {
                    _Duration = value;
                    UpdateModel();
                }
            }
        }
}

【问题讨论】:

  • 结帐this workaround 可能会有所帮助。它涵盖了如何绑定到可能适合您的数组中的各个索引。
  • 您遇到的“许多错误”是什么?您能否将错误添加到问题中以帮助澄清?
  • @Joshua Bullock - 这是 AspNetCore 团队 github.com/dotnet/aspnetcore/issues/5519 的一个实时问题的已知问题。这个问题有一个解决方法,下面有 Cem Erim 的答案,或者你可以改变你的方法并使用说复选框。

标签: c# html asp.net-core razor blazor


【解决方案1】:
<select multiple >
@foreach (var item in myVar)
{
   <option value="@item.SlctValue" @onclick=@((e) => OptionClickEvent(@item.SlctValue,e))>@item.SlctName</option>
}
</select>

@foreach (var holderItem in myHolder)
{
   @holderItem
}



@code  {
   private List<string> myHolder = new List<string>();

   private List<SelectModel> myVar = new List<SelectModel>()
   {
      new SelectModel(){ SlctValue = 1, SlctName="One Year" },
      new SelectModel(){ SlctValue = 2, SlctName="Two Year" },
      new SelectModel(){ SlctValue = 3, SlctName="Three Year"},
      new SelectModel(){ SlctValue = 4, SlctName="Four Year" },
   };

   public void OptionClickEvent(int values,MouseEventArgs evnt)
   {
       if (evnt.CtrlKey)
       {
           myHolder.Add(values.ToString());
       }
   }

   public class SelectModel
   {
       public string SlctName { get; set; }
       public int SlctValue { get; set; }
   }

}

【讨论】:

  • 欢迎来到 Stack Overflow!纯代码答案并不是特别有用。请添加一些关于此代码如何解决问题的说明。
  • 从 net core 6 开始,默认情况下应该是:devblogs.microsoft.com/dotnet/…
猜你喜欢
  • 2023-03-06
  • 1970-01-01
  • 1970-01-01
  • 2023-03-29
  • 1970-01-01
  • 1970-01-01
  • 2020-11-17
  • 2020-07-05
  • 1970-01-01
相关资源
最近更新 更多