这完全是关于拥有翻译文本字符串并在 JSX 中实现它们。
假设我有两个字符串。一个用于英语,另一个用于西班牙语,如下所示:
英语
const phrase = `this is just a string with some [replace]weird[/replace] link inside`
西班牙语
const phrase = `esto es solo un string con un [replace]raro[/replace] enlace dentro`
当我处于英语模式时,字符串当然会作为第一个示例。
我正在尝试用这样的组件替换 [/replace] 中的 [replace] 单词。
<p dangerouslySetInnerHTML={{
__html: phrase.replace(/\[replace\](.*)\[\/replace\]/, <Link to={linkurl} >test</Link>)
}}>
输出是:这只是一个字符串,里面有一些 [object Object] 链接
这个工作正常,只使用普通的 html 标签
<p dangerouslySetInnerHTML={{
__html: phrase.replace(/\[replace\](.*)\[\/replace\]/, "<b>$1</b")
}}>
</p>
输出是:这只是一个字符串,里面有一些奇怪的链接
我还尝试了以下方法:
<p dangerouslySetInnerHTML={{
__html: phrase.replace(/\[replace\](.*)\[\/replace\]/, "<Link to=\""+linkurl+"\">$1</Link>")
}}>
</p>
输出是:this is just a string with some weird link inside
但是“奇怪”这个词应该是一个链接元素,而不是......
顺便说一句,该组件只是 gatsby 的一个组件,它允许您使用路由导航(当前使用到达路由器)。