gpt4 book ai didi

javascript - 在React组件中,如何在clickabel中制作并调用该React组件的函数?

转载 作者:行者123 更新时间:2023-11-28 05:12:11 25 4
gpt4 key购买 nike

在 React 组件 MyComp 中,我有一个已解析的 Markdown 文本,我想使该文本中的所有跨度都可单击并调用 MyComp 的函数。

我用这句话来实现,但是只能调用全局的javascript函数。
let clickableSub = sub.replace(/<span>/g, '<span onclick="showDict(this)">')

最佳答案

您应该使用事件委托(delegate)。将事件处理程序绑定(bind)到渲染 markdown 的容器,然后检查事件是否源自 <span>元素。例如

function handler(event) {
if (event.target.tagName === 'SPAN') {
console.log(event);
}
}

function MyComp({html}) {
return <div onClick={handler} dangerouslySetInnerHTML={{ __html: html }} />
}

关于javascript - 在React组件中,如何在clickabel中制作<span>并调用该React组件的函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41273120/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com