Die*_*ava 11 keyboard-events blazor blazor-webassembly
我正在尝试 Microsoft 的待办事项列表示例:https ://docs.microsoft.com/en-us/aspnet/core/tutorials/build-a-blazor-app?view=aspnetcore- 3.1
我想添加一个待办事项,而不是用鼠标点击按下按钮,我想按下回车键。我对在这个解决方案中使用 JS 不满意:How to set the focus to an InputText element? 我尝试通过这行代码触发方法 private void Enter(KeyboardEventArgs e):
<button @onclick="AddTodo" @onkeypress="@(e=>Enter(e)" tabindex="0" >Add todo</button>
Run Code Online (Sandbox Code Playgroud)
它没有用。
enter code here
<input placeholder="Something todo" @bind="newTodo" />
<button @onclick="AddTodo" @onkeypress="Enter" tabindex="0" >Add todo</button>
@code {
private IList<TodoItem> todos = new List<TodoItem>();
private string newTodo;
private void AddTodo()
{
if (!string.IsNullOrWhiteSpace(newTodo))
{
todos.Add(new TodoItem { Title = newTodo });
newTodo = string.Empty;
}
}
//private void Enter(KeyboardEventArgs e)
private void Enter()
{
//if (e.Key == "Enter")
{
if (!string.IsNullOrWhiteSpace(newTodo))
{
todos.Add(new TodoItem { Title = newTodo });
newTodo = string.Empty;
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
Uma*_*air 29
onkeypress仅对字符键触发。onkeydown将触发所有按下的键。我在这里找到了所有关键事件之间差异的一些解释
试试看 onkeydown,它奏效了:
<input type="text" @onkeydown="@Enter" />
Run Code Online (Sandbox Code Playgroud)
在事件处理程序中,您必须这样做(请注意,我检查了Enter和NumpadEnter键):
public void Enter(KeyboardEventArgs e)
{
if (e.Code == "Enter" || e.Code == "NumpadEnter")
{
// ...
}
}
Run Code Online (Sandbox Code Playgroud)
如果您使用 HTML 表单,这很简单 - 无需寻找按键,只需让浏览器完成工作:
<form @onsubmit=Enter>
<label for="todo">What to do?</label>
<input id="todo" placeholder="Something todo" @bind="newTodo" />
<button>Add todo</button>
</form>
<ul>
@foreach(var item in todos)
{
<li @key=item>@item.Title</li>
}
</ul>
Run Code Online (Sandbox Code Playgroud)
@code {
private class TodoItem { public string Title { get; set; } }
private IList<TodoItem> todos = new List<TodoItem>();
private string newTodo;
private void Enter()
{
if (!string.IsNullOrWhiteSpace(newTodo))
{
todos.Add(new TodoItem { Title = newTodo });
newTodo = string.Empty;
}
}
}
Run Code Online (Sandbox Code Playgroud)
你可以在这里试试:https : //blazorrepl.com/repl/wPabvwlv138n6KMN23
| 归档时间: |
|
| 查看次数: |
9124 次 |
| 最近记录: |