如何强制视图刷新而不从可观察对象自动触发它?

发布于 2024-12-21 17:36:52 字数 204 浏览 2 评论 0原文

注意:这主要是为了调试和理解 KnockoutJS。

有没有办法显式请求 Knockout 从(已绑定)视图模型刷新视图?我正在寻找类似的东西:

ko.refreshView();

我知道这不是 Knockout 的预期用途,但我仍然想知道是否有这样的方法用于调试和学习目的。

Note: this is mostly for debugging and understanding KnockoutJS.

Is there a way to explicitly request Knockout to refresh the view from (already bound) view model? I am looking for something like:

ko.refreshView();

I understand that this is not an intended use of Knockout, but I still want to know if there is a such method for debugging and learning purposes.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

笙痞 2024-12-28 17:36:52

您无法在整个 viewModel 上调用某些内容,但在单个可观察对象上,您可以调用 myObservable.valueHasMutated() 来通知订阅者他们应该重新评估。正如您提到的,这在 KO 中通常是不必要的。

You can't call something on the entire viewModel, but on an individual observable you can call myObservable.valueHasMutated() to notify subscribers that they should re-evaluate. This is generally not necessary in KO, as you mentioned.

不一样的天空 2024-12-28 17:36:52

在某些情况下,简单地删除绑定然后重新应用可能会很有用:

ko.cleanNode(document.getElementById(element_id))
ko.applyBindings(viewModel, document.getElementById(element_id))

In some circumstances it might be useful to simply remove the bindings and then re-apply:

ko.cleanNode(document.getElementById(element_id))
ko.applyBindings(viewModel, document.getElementById(element_id))
初见 2024-12-28 17:36:52

我在这里用我的bindHTML淘汰绑定处理程序创建了一个JSFiddle:
https://jsfiddle.net/glaivier/9859uq8t/

首先,将绑定处理程序保存到其自己的(或通用)文件并包含在淘汰赛之后。

如果您使用此功能,请将您的绑定切换到此:

<div data-bind="bindHTML: htmlValue"></div>

OR

<!-- ko bindHTML: htmlValue --><!-- /ko -->

I have created a JSFiddle with my bindHTML knockout binding handler here:
https://jsfiddle.net/glaivier/9859uq8t/

First, save the binding handler into its own (or a common) file and include after Knockout.

If you use this switch your bindings to this:

<div data-bind="bindHTML: htmlValue"></div>

OR

<!-- ko bindHTML: htmlValue --><!-- /ko -->
洛阳烟雨空心柳 2024-12-28 17:36:52

一个简单的替代方法是清除 observable 数组:

let tmp = myObservableArray();
myObservableArray([]);
myObservableArray(tmp);

注意:这种替代方法可能会影响性能。

An easy alternative is to clear the observable array:

let tmp = myObservableArray();
myObservableArray([]);
myObservableArray(tmp);

Note: This alternative could perhaps suffer in performance.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文