如何通过 Javascript 设置 Blazor 输入控件
How To set a Blazor Input Control via Javascript
我尝试通过 javascript 设置 Blazor InputCheckbox 并期望执行数据绑定并将值写入模型。但无济于事。
我做错了什么?
// blazor
<EditForm Model="@Model" OnValidSubmit="@HandleValidSubmit" >
<InputCheckbox @bind-Value="Model.Checked" class="tripCheckbox" />
</EditForm>
// javascript
const tripCheckBox = container.querySelector('.tripCheckbox');
if (tripCheckBox.checked === false) {
tripCheckBox.setAttribute('checked', 'checked');
tripCheckBox.checked = true;
} else {
tripCheckBox.removeAttribute('checked');
tripCheckBox.checked = false;
}
我认为你想在某些事件中执行你的js:
<InputCheckbox @bind-Value="Model.Checked" class="tripCheckbox" @onclick=OnMyCheckboxClick />
// Code behind
[Inject]
private IJRunTime Js {get; set;}
private async task OnMyCheckboxClick() {
Js.InvokeVoidAsync("YourJSMethod");
}
使用 JS 更改值的问题是不会调用 Blazor 事件。您必须自己调用 DOM 事件。
这是一个演示页面和代码,使用了您的大部分代码:
我的 JS 函数在 _layout.cshtml 中加载。
<script>
window.SetMyCheckBox = function()
{
const tripCheckBox = document.getElementById('tripCheckbox');
if (tripCheckBox.checked === false) {
tripCheckBox.setAttribute('checked', 'checked');
tripCheckBox.checked = true;
var event = new Event('change');
tripCheckBox.dispatchEvent(event);
} else {
tripCheckBox.removeAttribute('checked');
tripCheckBox.checked = false;
var event = new Event('change');
tripCheckBox.dispatchEvent(event);
}
}
</script>
这是一个测试页:
@page "/"
@inject IJSRuntime JS
<PageTitle>Index</PageTitle>
<h1>Hello, world!</h1>
<EditForm Model="@model">
<InputCheckbox @bind-Value="model.Checked" id="tripCheckbox" />
</EditForm>
<div class="m-2">
Checked: @model.Checked
</div>
<div class="m-2">
<button class="btn btn-primary" @onclick="Clicked"> Change </button>
</div>
@code {
private Model model = new Model();
class Model
{
public bool Checked { get; set; }
}
private async Task Clicked()
{
await JS.InvokeVoidAsync("SetMyCheckBox");
}
}
我尝试通过 javascript 设置 Blazor InputCheckbox 并期望执行数据绑定并将值写入模型。但无济于事。 我做错了什么?
// blazor
<EditForm Model="@Model" OnValidSubmit="@HandleValidSubmit" >
<InputCheckbox @bind-Value="Model.Checked" class="tripCheckbox" />
</EditForm>
// javascript
const tripCheckBox = container.querySelector('.tripCheckbox');
if (tripCheckBox.checked === false) {
tripCheckBox.setAttribute('checked', 'checked');
tripCheckBox.checked = true;
} else {
tripCheckBox.removeAttribute('checked');
tripCheckBox.checked = false;
}
我认为你想在某些事件中执行你的js:
<InputCheckbox @bind-Value="Model.Checked" class="tripCheckbox" @onclick=OnMyCheckboxClick />
// Code behind
[Inject]
private IJRunTime Js {get; set;}
private async task OnMyCheckboxClick() {
Js.InvokeVoidAsync("YourJSMethod");
}
使用 JS 更改值的问题是不会调用 Blazor 事件。您必须自己调用 DOM 事件。
这是一个演示页面和代码,使用了您的大部分代码:
我的 JS 函数在 _layout.cshtml 中加载。
<script>
window.SetMyCheckBox = function()
{
const tripCheckBox = document.getElementById('tripCheckbox');
if (tripCheckBox.checked === false) {
tripCheckBox.setAttribute('checked', 'checked');
tripCheckBox.checked = true;
var event = new Event('change');
tripCheckBox.dispatchEvent(event);
} else {
tripCheckBox.removeAttribute('checked');
tripCheckBox.checked = false;
var event = new Event('change');
tripCheckBox.dispatchEvent(event);
}
}
</script>
这是一个测试页:
@page "/"
@inject IJSRuntime JS
<PageTitle>Index</PageTitle>
<h1>Hello, world!</h1>
<EditForm Model="@model">
<InputCheckbox @bind-Value="model.Checked" id="tripCheckbox" />
</EditForm>
<div class="m-2">
Checked: @model.Checked
</div>
<div class="m-2">
<button class="btn btn-primary" @onclick="Clicked"> Change </button>
</div>
@code {
private Model model = new Model();
class Model
{
public bool Checked { get; set; }
}
private async Task Clicked()
{
await JS.InvokeVoidAsync("SetMyCheckBox");
}
}