【问题标题】:How do I Insert Record MVVM through WCF如何通过 WCF 插入记录 MVVM
【发布时间】:2010-12-29 10:10:36
【问题描述】:

我是 MVVM 模式的新手(使用 Galasoft MVVM Light 工具包)。我创建了一个测试项目,我想通过 WCF 从数据库中获取一些记录。这工作正常,但我未能从视图中插入新记录;这是我的代码:

数据库

表名:TestUser(名字,姓氏)

WCF (NWCustomer)

两种方法

Public List<TestUser> GetAllUsers() [“LINQ2SQL Operation”] 
Public bool AddUser(TestUser testuser) 

Public bool AddUser(TestUser testuser)
{

        try

        {
                    using (DBDataContext db = new DBDataContext())
                    {
                                TestUser test = new TestUser()
                                {
                                            FirstName = testuser.FirstName,
                                            LastName = testuser.LastName
                                };
                                db.TestUser.InsertOnSubmit(test);
                                db.SubmitChanges();
                    }
        }
        catch (Exception ex)
        {
                    return false;
        }
        return true;
}

银光计划

模型包括

ITestUserService.cs

TestUserService.cs

   public void AddTestTable(TestTableViewModel testuser, Action<bool> callback)
   {
       NWCustomerClient client = new NWCustomerClient("BasicHttpBinding_NWCustomer");
       client.AddTestUserCompleted += (s, e) =>
       {
           var userCallback = e.UserState as Action<bool>;
           if (userCallback == null)
           {
               return;
          }
           if (e.Error == null)
           {
               userCallback(e.Result);
               return;
           }
           userCallback(false);
       };      

       client.AddTestUserAsync(testuser.Model);
   }

视图模型

TestUserViewModel

   public TestUser User
   {
       get;

       private set;
   } 

  public const string DirtyVisibilityPropertyName = "DirtyVisibility";
  private Visibility _dirty = Visibility.Collapsed;
  public Visibility DirtyVisibility
   {
       get
       {
           return _dirty;
       }

       set
       {
           if (_dirty == value)
           {
               return;
           }

           _dirty = value;
           RaisePropertyChanged(DirtyVisibilityPropertyName);
       }

   }

   public TestUserViewModel (TestUser user)
   {
       User = user;
       user.PropertyChanged += (s, e) =>
           {
               DirtyVisibility = Visibility.Visible;
           };
   }

MainViewModel

   public ObservableCollection<TestUserViewModel> TestTables
   {
       get;
      private set;
   }

   public const string ErrorMessagePropertyName = "ErrorMessage";
   private string _errorMessage = string.Empty;
   public string ErrorMessage
   {
       get
       {
            return _errorMessage;
       }
       set
       {
           if (_errorMessage == value)
           {
               return;
           }

           _errorMessage = value;
           RaisePropertyChanged(ErrorMessagePropertyName);
       }
   }

   private     ITestUserService _service;
   public RelayCommand< TestUserViewModel> AddTestUserRecord
   {
       get;
       private set;
   }

   public MainTestTableViewModel (ICustomerService service)
   {
       _service = service;
       TestTables = new ObservableCollection<TestTableViewModel>();
       service.GetAllTestTable(HandleResult);
   } 

   private void HandleResult(IEnumerable<TestTable> result, Exception ex)
   {
       TestTables.Clear();
       if (ex != null)
       {
           //Error
           return;
       }

       if (result == null)
       {
          return;
       }

       foreach (var test in result)
       {
           var table = new TestTableViewModel(test);
           TestTables.Add(table);
       }
   }

XAML

<Grid x:Name="LayoutRoot">
   <StackPanel>
                                <TextBox Text="FirstName" />

                                <TextBox Text="LastName" />

                                <Button Content="Add Record" Command="{Binding AddTestUserRecord}" />

           </StackPanel>

</Grid>

我想将记录添加到 TestTable(数据库表)中。如何插入记录?在 XAML 中存在两个文本框和一个按钮控件。

谢谢你。

危险

【问题讨论】:

  • MainViewModel 构造函数中:AddTestUserRecord = new RelayCommand(tuVM =&gt; _service.AddTestTable(tuVM, [callback]));
  • AddTestUserRecord 没有回调函数?

标签: wcf mvvm light


【解决方案1】:

您需要将文本框的 Text 属性绑定到 ViewModel 上的字符串属性,当调用 AddTestUserRecord 命令的“执行”方法时,只需获取属性并调用逻辑将值插入数据库。

【讨论】:

    【解决方案2】:

    首先更改您的 xml。 正如许多 Goblins 所说:= 您需要将文本框的 Text 属性绑定到 ViewModel 上的字符串属性 你应该是这样的

    <Grid x:Name="LayoutRoot">   <StackPanel    
                    <TextBox Text="{Binding FirstName,Mode=TwoWay" />
            <TextBox Text="{Binding FirstName,Mode=TwoWay" />
                    <Button Content="Add Record" Command="{Binding AddTestUserRecord}" />   </StackPanel> </Grid> 
    

    在你看来模型代码应该是这样的。

    Private _FirstName As String    Public Property FirstName() As String
        Get
            Return _FirstName 
        End Get
        Set(ByVal value As String)
            _FirstName = value RaisePropertyChanged(FirstName)
        End Set
    End Property
    
    
    
    Private _LastName As String   Public Property LastName() As String
        Get
            Return _LastName 
        End Get
        Set(ByVal value As String)
            _LastName = value RaisePropertyChanged(LastName)
        End Set
    End Property 
    
    
     Private _AddTestUserRecord As ICommand
    Public Property AddTestUserRecord() As ICommand
        Get
            If _AddTestUserRecordIs Nothing Then
                _AddTestUserRecord= New RelayCommand(Nothing, AddressOf AddUser)
            End If
            Return _rad_Map_Loaded
        End Get
        Set(ByVal value As ICommand)
            _AddTestUserRecord= value
        End Set
    End Property
    
    Public Sub AddUser()
       Try
    
    Using db As New DBDataContext()
        Dim test As New TestUser() With { _
            Key .FirstName = me.FirstName, _
            Key .LastName = me.LastName _
        }
        db.TestUser.InsertOnSubmit(test)
        db.SubmitChanges()
    End Using Catch ex As Exception     Return False  End Try    End Sub
    

    代码的格式不是很好,而且在 vb 中也是如此,但它会让你清楚地知道你必须做什么。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2020-06-20
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-09-13
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多