asynceventhandlersinlit-html
创始人
2024-09-21 02:30:54
0

在 lit-html 中添加异步事件处理程序可以很方便地执行一些异步操作。但是,这也会导致一些问题,因为异步函数的返回值不会影响模板渲染。

为了解决这个问题,可以使用 lit-html 的 directive,即repeat、classMap、styleMap、live、guard等。

例如,使用 live directive可以使渲染函数等待 Promise 返回的值:

import {live} from 'lit-html/directives/live';

const handleClick = async (event) => { const result = await fetch('/data');

return result.json(); };

html ;

这里的 live directive 会使用 requestRender,在 Promise 返回结果后重新渲染值。 这种方式可以避免渲染出不正确的值。

另外,还可以使用 asyncState directive,它会等待异步函数执行完成并返回结果。

import {asyncState} from 'lit-html/directives/async-state';

const handleClick = async (event) => { const result = await fetch('/data');

return result.json(); };

html ;

在这个示例中,asyncState directive 会将 handleClick 函数返回的 Promise 转换为一个对象,其包含以下属性:‘data’(Promise 执行结果)、‘error’(如果 Promise 拒绝时返回),以及‘isLoading’(如果 Promise 还没有执行完成)。

通过在模板中使用(state) => html${state.data}``,可以将结果呈现为一个文本节点。

相关内容

热门资讯

推荐攻略!红龙poker辅助平... 推荐攻略!红龙poker辅助平台,wepoker怎么设置透视,解密教程(有挂神器)科技教程也叫必备教...
玩家必备攻略!aapoker ... 玩家必备攻略!aapoker ai插件,红龙poker辅助工具,切实教程(有挂技巧)科技教程也叫必备...
玩家必看教程!werplan有... 自定义wepoker俱乐部辅助系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助...
重大通报!wepoker透视有... 重大通报!wepoker透视有吗,wepoker透视脚本网页,必赢教程(有挂教程)1、玩家可以在we...
我来分享!impoker辅助,... 我来分享!impoker辅助,uupoker透视,实用技巧(有挂透视);原来确实真的有挂(需添加指定...
一分钟了解!sohoo开挂辅助... 一分钟了解!sohoo开挂辅助,wepoker透视功能下载,黑科技教程(有挂技巧);玩家必备必赢加哟...
揭秘攻略!pokemmo脚本,... 您好,pokemmo脚本这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家...
一分钟带你了解!hhpoker... 一分钟带你了解!hhpoker真能买到挂吗,德州来玩辅助器,解说技巧(有挂教程);实战中需综合运用上...
我来教大家!xpoker辅助怎... 我来教大家!xpoker辅助怎么用,werplan辅助软件,细节揭秘(有挂技巧);人气非常高,ai更...
一分钟了解!约局吧是否有挂,如... 1、一分钟了解!约局吧是否有挂,如何下载wpk透视版,科技教程(有挂方法);详细教程。2、如何下载w...