如何用 yew 查询和更新 DOM?
有没有办法通过 use_node_ref
进行 DOM 操作?或者,如何使用 yew 在 Rust 中执行 document.query_selector()
?
use web_sys::HtmlInputElement;
use yew::{
function_component, functional::*, html,
NodeRef, Html
};
#[function_component(UseRef)]
pub fn ref_hook() -> Html {
let input_ref = use_node_ref();
let all_editables = input_ref.query_selector("[contenteditable]")
web_sys::console::(all_editables)
html! {
<div>
<input ref={input_ref} type="number" />
</div>
}
}
目标:我有一个富文本编辑器应用程序。我有一个像这样的字符串形式的缩小的 html ;这是标题
hello world
,我需要获取 DOM 并更改 innerHTML
以将其设置为此值。
目标2:当用户在contenteditable
元素中写入内容时,我还需要更新innerHtml
。例如,当用户输入 @john smith
时,我将使用 href
创建一个 元素,其中包含指向
的链接>约翰·史密斯
的个人资料。
Is there any way to make DOM action via use_node_ref
? or alternatively, how to do document.query_selector()
in Rust using yew?
use web_sys::HtmlInputElement;
use yew::{
function_component, functional::*, html,
NodeRef, Html
};
#[function_component(UseRef)]
pub fn ref_hook() -> Html {
let input_ref = use_node_ref();
let all_editables = input_ref.query_selector("[contenteditable]")
web_sys::console::(all_editables)
html! {
<div>
<input ref={input_ref} type="number" />
</div>
}
}
Goal: I have a rich text editor app. And I have a minified html in form of string like this <h1> this is title</h1><p>hello world</>
and I need to get the DOM and change the innerHTML
to set it to this value.
Goal2: I will also need to update the innerHtml
as the user write things in the contenteditable
elements. Fore example when the user type @john smith
I will make a create an <a>
element with href
the have the link to John smith
's profile.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
你的问题有很多事情需要解决。
#1 不要设置内部 html
更多内容请阅读 innerHTML 的替代方案?
,而是创建文本节点。
因此,使用 web-sys 你会做类似的事情:
#2 如何从输入查询数据
有很多方法可以做到这一点,所以我只向你展示其中一种 -
受控输入的
核心思想是将输入值保留在
use_state
中,并使用value
和oninput
属性将其与输入元素同步。#3 更新 DOM
**在 yew 外部,因为您通常应该避免更新由 yew 控制的 DOM
然后您可以使用
use_effec_with_deps
对您的输入更改做出反应并在那里更新您的外部预览Many things to tackle with your question.
#1 Do not set inner html
More to read about this in Alternative for innerHTML?
But instead create text nodes.
So using web-sys you would do something like:
#2 How to query data from an input
There are many ways to do this so ill just show you one of them -
controlled input
core idea is keep your input value in
use_state
and sync it with the input element usingvalue
andoninput
attributes.#3 Update DOM
**External to yew as you should generally avoid updating DOM that is controlled by yew
You can then use
use_effec_with_deps
to react to your input changing and update your external preview there