First View是包含一些项目的列表视图。
例如。 item0,item1,item2
点击" new"按钮,将显示第二个视图。
然后点击"保存"按钮并输入名称(例如item3)。 " item3"将保存在seconde viewmodel
中保存成功后。第一个视图将刷新并显示" item3"
如何传递名称" item3"从第二个视图模型到第一个视图模型,以便在第一个视图中显示?
答案 0 :(得分:3)
在MVVMCross中使用Messenger插件。第一个VM注册一条消息。第二个VM通过发布已注册的消息类型(类)的消息来发布(通知)第一个VM。例如:
第一个虚拟机 要使用messenger插件,您需要先使用Injection注册它,如下所示:
private readonly IMvxMessenger _messenger; // VM Instance var
private MvxSubscriptionToken myToken;
public FirstViewModel(IDataService dataService, IMvxMessenger messenger)
{
// Registers the DataService(SQLite Plugin) and the Messenger Service Plugin
_dataService = dataService;
_messenger = messenger;
// Suscribe to the Meessage and pass it the name of a method to be called when the 2nd VM(the Publisher), publishes(notifies) a MyMessage to all Subscribers...
myToken = _messenger.Subscribe<MyMessage>( OnMyMessageArrived );
}
private void OnMyMessageArrived( MyMessage p_myMessage )
{
// Set the 1st VM's property from p_myMessage
MyProperty = p_myMessage.Item3
}
MyMessage 类应该如下所示:
public class MyMessage : MvxMessage
{
public MyMessage( object sender, string p_item3 ): base( sender )
{
Item3 = p_item3;
}
public string Item3 { private set; get; }
}
第二个虚拟机,当准备好重新发送值时,它应该发布MyMessage,并将值传递回第一个VM(以及任何订阅者),如下所示:
_messenger.Publish( new MyMessage( this, item3 ) );
让订阅者取消订阅他们订阅的任何邮件是一个很好的做法,所以回到第一个虚拟机,也许就在你关闭之前,你应该这样做:
_messenger.Unsubscribe<MyMessage>( myToken );
有关更完整示例,请查看Stuart的N = 9视频及相关示例。这是两者的链接:
http://slodge.blogspot.com/2013/05/n9-getting-message-n1-days-of-mvvmcross.html
R,
巴氏
答案 1 :(得分:0)
我不熟悉mvvmcross,所以我会使用一般的M / VM / V / C架构模式回答你的问题:
视图和ViewModel不应该彼此了解,这是Controller的工作。您的FirstView应警告其控制器用户单击“新建”,然后由控制器负责创建和管理您的SecondView。
这个过程就像这样(abstract,psuedocode-ish):
void ControllerAction() {
using(View listView = new MyListView() ) {
ListViewViewModel listViewVM = CreateListViewVM();
listViewVM.NewClicked = () => this.NewClicked(listViewVM); // wiring-up ViewModel events via anonymous methods
listView.SetViewModel( listViewVM );
listView.ShowModal();
}
}
void NewClicked(ListViewViewModel parentViewViewModel) {
using(View newEntryView = new NewEntryView()) {
if( newEntryView.ShowDialog() == DialogResult.OK ) {
parentViewViewModel.Refresh();
parentViewViewModel.SelectedItem = newEntryView.NewItemText; // passing the new item's name
}
}
}