gpt4 book ai didi

javascript - 在对可观察数组中的项目进行更改后,如何立即看到更新?

转载 作者:行者123 更新时间:2023-12-02 15:17:52 25 4
gpt4 key购买 nike

我正在尝试编辑表格单元格的内容,我不想直接在表格中编辑值,而是需要使用文本区域,输入一些文本并点击按钮来更新表格单元格。

我尝试使用 JQuery 执行此操作并直接更新 Observable Array,但是,直到我在“选择选项”项之间切换后才看到更改。

这是一个JSFiddle showing the complete example上面提到过。

我该如何编写此代码,以便在对 Observable Array 项进行更改后可以立即看到更改?

最佳答案

您的 Bio 属性不可观察,因此它不会更新。我做了一些小更改,使您的 Bio 可观察,因此在您单击按钮时更新,而不是在重新加载艺术家时更新 https://jsfiddle.net/jpntrx41/ 。变化主要体现在以下几个方面:

self.artistDetail = ko.observableArray([{
"ArtistId": "1",
"Bio": ko.observable("Jon Secada is a Cuban American singer and songwriter. " +
"Secada was born in Havana, Cuba, and raised in Hialeah, Florida. " +
"He has won two Grammy Awards and sold 20 million albums since his " +
"English-language debut album in 1992")
},

{
"ArtistId": "2",
"Bio": ko.observable("Céline Marie Claudette Dion, CC OQ ChLD is a Canadian " +
"singer, songwriter, businesswoman and occasional actress.")
}
]);


$(function() {
$('#update').click(function(event) {
var updateText = $('#update-bio').val();

if (viewModelA.SelectedArtist()) {

var currText = viewModelB.artistDetail()[viewModelA.SelectedArtist().value - 1].Bio();

viewModelB.artistDetail()[viewModelA.SelectedArtist().value - 1].Bio().replace(currText,
viewModelB.artistDetail()[viewModelA.SelectedArtist().value - 1].Bio(updateText));
}
});
});

虽然上面的内容满足了点击按钮时自动更新 Bio 的要求,但我对你的代码结构以及 Knockout 和 jQuery 的混合有点困惑。显然,我不知道您正在尝试做什么的大局,但值得检查您的结构,看看是否可以稍微简化它。

这是一个非常快速的工作示例,使用 Knockout http://plnkr.co/edit/3UYAQjJmbdyn1rYxZj9m?p=preview 从 1 View 模型运行所有内容。

关于javascript - 在对可观察数组中的项目进行更改后,如何立即看到更新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34313993/

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