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}``,可以将结果呈现为一个文本节点。

相关内容

热门资讯

一分钟了解!wepoker辅助... 一分钟了解!wepoker辅助插件功能,hhpoker到底可以作弊码,2025教程(有挂辅助);建议...
透视好牌!aapoker透视方... 透视好牌!aapoker透视方法(透视)确实真的有挂(详细辅助德州论坛)1、ai辅助优化,发牌逻辑科...
科普!aapoker透视脚本入... 科普!aapoker透视脚本入口,wepoker有没有透视方法,黑科技教程(有挂攻略);亲真的是有正...
透视好友!菠萝德州透视脚本(透... 透视好友!菠萝德州透视脚本(透视)其实是有挂(详细辅助解密教程);1、每一步都需要思考,不同水平的挑...
专业讨论!wepoker免费脚... 此外,数据分析德州(wepoker免费脚本弱密码)辅助神器app还具备辅助透视行为开挂功能,通过对客...
透视ai代打!wepoker手... 透视ai代打!wepoker手机版透视脚本(透视)一贯真的是有挂(详细辅助可靠技巧);1、点击下载安...
一分钟揭秘!wejoker辅助... 一分钟揭秘!wejoker辅助软件视频,hhpoker有后台操作吗,详细教程(有挂辅助)这是由厦门游...
盘点几款!大菠萝免费辅助器,a... 盘点几款!大菠萝免费辅助器,aapoker透视怎么用,可靠教程(有挂透明);支持2-10人实时对战,...
透视玄学!hhpoker免费透... 透视玄学!hhpoker免费透视脚本(透视)一直是有挂(详细辅助可靠技巧);1、起透看视 hhpok...
透视辅助!aapoker透视插... 透视辅助!aapoker透视插件(透视)果然有挂(详细辅助可靠教程)1、在aapoker透视插件ai...