我有一个自定义组件,当它在浏览器中呈现时,我需要测量它的大小(在 JavaScript 中)并回调 Blazor。
如何在特定组件的渲染完成后注册 JavaScript 以调用?
我有一个自定义组件,当它在浏览器中呈现时,我需要测量它的大小(在 JavaScript 中)并回调 Blazor。
如何在特定组件的渲染完成后注册 JavaScript 以调用?
@inject IJSRuntime JSRuntime
@ref
到您要测量的元素<div @ref=MeasureMe>
@code
声明一个字段ElementReference MeasureMe
var whatever = JSRuntime.InvokeAsync<YourResultType>("yourJSFunctionName", MeasureMe)
注意:如果您启用了服务器端预渲染,请不要在第一次使用 JSRuntime 之前OnAfterRenderAsync
使用firstRender == true
.
另请注意:调整浏览器大小时组件不会重新渲染。
我在Blazor University上有一个关于 JSInterop 的部分。