表达式不会在vb.net应用程序中生成值

Lam*_*fif 2 .net c# vb.net mvvm winforms

我有一个Winforms应用程序,我想在其中使用MVVM设计模式:

我按照本教程

这是非常有趣的文章,但我遇到了这个问题:我的应用程序是vb.net,我将代码(C#)转换为vb.net,除了这个之外它工作正常:

C#代码

 protected void ViewModel_Validated(object sender, EventArgs e)
    {
        this.ViewModel.AttachedControls.ToList().ForEach(c => this.errorProvider.SetError(c.Value as Control, ""));
        if (!string.IsNullOrEmpty(this.ViewModel.Error)) {
            this.ViewModel.Messages.ToList().ForEach(message => {
                this.errorProvider.SetError(this.ViewModel.AttachedControls[message.Key] as Control, message.Value);
            });
        }
    } 
Run Code Online (Sandbox Code Playgroud)

Vb.net代码

 Protected Sub ViewModel_Validated(ByVal sender As Object, ByVal e As EventArgs)
        Me.ViewModel.AttachedControls.ToList().ForEach(Function(c) Me.errorProvider.SetError(TryCast(c.Value, Control), ""))
        If Not String.IsNullOrEmpty(Me.ViewModel.[Error]) Then
            Me.ViewModel.Messages.ToList().ForEach(Function(message)
                                                       Me.errorProvider.SetError(TryCast(Me.ViewModel.AttachedControls(message.Key), Control), message.Value)

                                                   End Function)
        End If
    End Sub
Run Code Online (Sandbox Code Playgroud)

问题出在这一行:

Me.ViewModel.AttachedControls.ToList().ForEach(Function(c) Me.errorProvider.SetError(TryCast(c.Value, Control), ""))
Run Code Online (Sandbox Code Playgroud)

错误:

Expression does not produce a value.

我需要知道

  • 这个错误的原因是什么?
  • 我该如何解决?

Fab*_*bio 9

更改FunctionSub.
Function返回值的mean方法,但是你的代码:Me.errorProvider.SetError(TryCast(c.Value, Control), "")没有.

来自MSDN:

要将值返回给调用代码,请使用Function过程; 否则,使用Sub程序.

所以尝试:

Me.ViewModel.AttachedControls.ToList().ForEach(Sub(c) Me.errorProvider.SetError(TryCast(c.Value, Control), ""))
Run Code Online (Sandbox Code Playgroud)

还有下一行你需要改变:

Me.ViewModel.Messages.ToList().ForEach(Sub(message)
                                           Me.errorProvider.SetError(TryCast(Me.ViewModel.AttachedControls(message.Key), Control), message.Value)
                                       End Sub)
Run Code Online (Sandbox Code Playgroud)