如何将值从一个视图模型传递到knockout js中的另一个视图模型? [英] How to pass value from one view model to another viewmodel in knockout js?
问题描述
我有两个视图模型,我想将值从一个视图模型传递到另一个视图模型。我有两个viewmodels和两个div我想在div 1中点击按钮显示另一个div。
i have two view models and i want to pass value from one view model to another viewmodel. i have two viewmodels and two div i want to display another div on click of button which is present in div 1.
这里是html代码
<div id="container1">
<ul >
<li >Container1 item</li>
<!-- ko foreach: myItems -->
<li>Item <span data-bind="text: $data"></span></li>
<!-- /ko -->
</ul>
<button data-bind="click:showDiv">show another div</button>
</div>
<div id="container2" data-bind="visible:show">
<ul>
<li >Container2 item</li>
<!-- ko foreach: myItems -->
<li>Item <span data-bind="text: $data"></span></li>
<!-- /ko -->
</ul>
</div>
这里是剧本
function Container1ViewModel()
{
var self = this;
self.myItems = ko.observableArray();
self.myItems.push("ABC");
self.myItems.push("CDE");
}
function Container2ViewModel() {
var self = this;
self.myItems = ko.observableArray();
self.myItems.push("XYZ");
self.myItems.push("PQR");
}
var container1VM;
var container2VM;
$(document).ready(function() {
if ($.isEmptyObject(container1VM)) {
container1VM = new Container1ViewModel();
ko.applyBindings(container1VM, document.getElementById("container1"));
}
if ($.isEmptyObject(container2VM)) {
container2VM = new Container2ViewModel();
ko.applyBindings(container2VM, document.getElementById("container2"));
}
});
我该怎么办?
推荐答案
你可以使用伟大的@RyanNiemeyer的KO.postbox
You can make use of KO.postbox by the great @RyanNiemeyer
我在两个视图模型中都引入了一个变量
I introduced one variable in both the viewmodels each
在viewmodel 1中,它将发布(shout)所做的更改:
In viewmodel 1 which will publish (shout) the changes once made :
self.isVisible = ko.observable(false).publishOn("showDiv");
在viewmodel 2中,它将列出来自viewmodel 1的更改
in viewmodel 2 which will be listning to changes from viewmodel 1
self.isVisible = ko.observable(false).subscribeTo("showDiv");
然后我在第一个viewModel中创建了一个click方法来切换Show Div action(visible:true / false)
Then I created one click method in first viewModel to toggle Show Div action (visible : true / false)
self.showDiv = function(){
if(self.isVisible())
self.isVisible(false);
else
self.isVisible(true);
}
将现有标记的可见绑定更改为:
Changed visible binding from your existing markup to this :
<div id="container2" data-bind="visible:isVisible">
它现在将第一个viewmodel中所做的更改发布到第二个viewmodel。这称为pub-sub机制。阅读更多信息: https://github.com/rniemeyer/knockout-postbox
It now publish changes made in first viewmodel to second viewmodel. This is called pub-sub mechanism. Read more on : https://github.com/rniemeyer/knockout-postbox
这里摆弄: http://jsfiddle.net / rahulrulez / 0454h205 / 1 /
Fiddle here : http://jsfiddle.net/rahulrulez/0454h205/1/
这篇关于如何将值从一个视图模型传递到knockout js中的另一个视图模型?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!