{"id":302,"date":"2009-09-24T22:18:03","date_gmt":"2009-09-24T13:18:03","guid":{"rendered":"http:\/\/www.moonmile.net\/blog\/?p=302"},"modified":"2009-09-26T18:36:41","modified_gmt":"2009-09-26T09:36:41","slug":"silverlight-mvvm-%e3%81%ae%e8%90%bd%e3%81%a8%e3%81%97%e7%a9%b4","status":"publish","type":"post","link":"http:\/\/www.moonmile.net\/blog\/archives\/302","title":{"rendered":"Silverlight MVVM \u306e\u843d\u3068\u3057\u7a74"},"content":{"rendered":"<p>\u5c11\u3057\u4ed5\u4e8b\u306e\u30da\u30fc\u30b9\u304c\u843d\u3061\u7740\u3044\u3066\u304d\u305f\u306e\u3067\u60c5\u5831\u3092\u6d41\u3057\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n<p>\u73fe\u5728\u4f7f\u3063\u3066\u3044\u308b\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u304c SLExtensions \u306e DLL \u3092\u4f7f\u3063\u3066\u3044\u308b\u306e\u3067\u3001\u306a\u3093\u3058\u3083\u308d\uff1f\u3068\u3044\u3046\u5f62\u3067 MVVM \u30e2\u30c7\u30eb\u3063\u3066\u306e\u304c\u3042\u308b\u306e\u3053\u3068\u3092\u77e5\u308a\u307e\u3057\u305f\u3002\u4ee5\u524d\u304b\u3089 MVC \u30e2\u30c7\u30eb\u3092\u5229\u7528\u3057\u3066\u3044\u308b\u3057\u3001.NET \u30e9\u30dc\u306e9\u6708\u306e\u52c9\u5f37\u4f1a\uff08\u5f8c\u307b\u3069\u8cc7\u6599\u3092\u30a2\u30c3\u30d7\u3059\u308b\u4e88\u5b9a\u3067\u3059\uff09\u3067\u3082\u8a71\u3057\u307e\u3057\u305f\u304c\u3001MVVM \u3067\u3042\u308d\u3046\u3068\u3001MVC \u3067\u3042\u308d\u3046\u3068\u3001\u300c\uff2d\uff36\u25cb\u300d\u3063\u3066\u30e2\u30c7\u30eb\u306b\u306f\u9055\u3044\u306a\u3044\u306e\u3067\u3001\u6700\u65b0\u3063\u3066\u8a33\u3067\u3082\u3042\u308a\u307e\u305b\u3093\u3002<br \/>\n\u5b9f\u88c5\u4e0a\u306f\u3042\u308c\u3053\u308c\u3042\u308b\u3093\u3067\u3059\u304c\u3001\u307e\u3041\u3001\u30bf\u30a4\u30c8\u30eb\u901a\u308a\u300c\u843d\u3068\u3057\u7a74\u300d\u304c\u3042\u308b\u3093\u3067\u3059\u3002<\/p>\n<p>SLExtensions\u3092\u4f7f\u3063\u305fM-V-VM\u30d1\u30bf\u30fc\u30f3\u5b9f\u88c5<br \/>\n<a href=\"http:\/\/d.hatena.ne.jp\/coma2n\/20090217\/1234881006\">http:\/\/d.hatena.ne.jp\/coma2n\/20090217\/1234881006<\/a><\/p>\n<p>\u3092\u898b\u3066\u3044\u304f\u3064\u304b\u30da\u30fc\u30b8\u3092\u63a2\u3063\u3066\u3044\u304d\u307e\u3057\u305f\u3002\u3053\u306e\u65b9\u3001\u696d\u52d9\u7528\u306e\u30a2\u30d7\u30ea\u4f5c\u6210\u306b\u7cbe\u901a\u3057\u3066\u3044\u308b\u3089\u3057\u304f MVC \u30e2\u30c7\u30eb\u306e\u6839\u672c\u7684\u306a\u3068\u3053\u308d\u3092\u7406\u89e3\u3057\u3066\u3044\u3089\u3063\u3057\u3083\u3044\u307e\u3059\u3002VB 6.0 \u306a\u3093\u304b\u304c\u51fa\u3066\u304f\u308b\u3068\u3053\u308d\u304c\u597d\u611f\u304c\u6301\u3066\u307e\u3059\uff01<br \/>\n\u8981\u306f\u3001<br \/>\n\u30fb\u30bd\u30d5\u30c8\u30a6\u30a7\u30a2\u5de5\u5b66\u306a\u3068\u3053\u308d\uff08\u7406\u5b66\u90e8\u7684\u306a\u3068\u3053\u308d\uff09<br \/>\n\u30fb\u73fe\u5834\u3067\u306e\u5b9f\u88c5\/\u4f5c\u696d\u5834\u306e\u554f\u984c\uff08\u5de5\u5b66\u90e8\u7684\u306a\u3068\u3053\u308d\uff09<br \/>\n\u306e\u554f\u984c\u304c\u3042\u308a\u307e\u3059\u3002\u6587\u7cfb\u306e\u65b9\u306b\u306f\u3001\u7406\u5b66\u90e8\u3068\u5de5\u5b66\u90e8\u306e\u9055\u3044\u304c\u3088\u304f\u308f\u304b\u3089\u306a\u3044\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u304c\u3001<\/p>\n<p>\u300c\u7406\u8ad6\u300d\u3068\u300c\u5b9f\u8df5\u300d\u3068\u3044\u3046\u6bd4\u8f03\u3067\u3001\u7406\u8ad6\u304c\u300c\u7406\u5b66\u90e8\u300d\u3001\u5b9f\u8df5\u304c\u300c\u5de5\u5b66\u90e8\u300d\u3063\u3066\u3053\u3068\u3067\u3059\u3002<br \/>\n\u30bd\u30d5\u30c8\u30a6\u30a7\u30a2\u5de5\u5b66\u306e\u5834\u5408\u300c\u5de5\u5b66\u300d\u3092\u540d\u4e57\u3063\u3066\u3044\u308b\u3068\u3053\u308d\u3082\u3042\u308b\u306e\u3067\u3059\u304c\u3001\u7d14\u7c8b\u306b\u6570\u5b66\u7684\u306a\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u306e\u554f\u984c\u3082\u3042\u3063\u3066\u3001\u3053\u306e\u7406\u5b66\/\u5de5\u5b66\u304c\u6df7\u5728\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u753b\u50cf\u8a8d\u8b58\u306e\u8ad6\u6587\u96c6\u3092\u8cb7\u3063\u305f\u306e\u3067\u3059\u304c\u3001\u7406\u8ad6\u7684\u306a\u3068\u3053\u308d\u3060\u3051\u3067\u306a\u304f\u3001\u5b9f\u88c5\u4e0a\u306e\u554f\u984c\u3084\u30b9\u30d4\u30fc\u30c9\u306e\u554f\u984c\u3082\u6271\u3063\u3066\u3044\u308b\u3068\u3053\u308d\u304c\u5de5\u5b66\u7684\u3067\u3059\u306d\u3002\u53ce\u675f\u30b9\u30d4\u30fc\u30c9\u3068\u304b\u3002<\/p>\n<p>\u3055\u3066\u3001MVVM \u30d1\u30bf\u30fc\u30f3\u3092\u5b9f\u88c5\u3057\u305f SLExtensions \u306e DLL \u3067\u3059\u304c\u3001\u3053\u308c\u304c\u7121\u304f\u3066\u3082 MVVM \u30d1\u30bf\u30fc\u30f3\u306f\u5b9f\u88c5\u53ef\u80fd\u3067\u3059\u3002\u3068\u3044\u3046\u304b\u500b\u4eba\u7684\u306b\u306f SLExtensions \u3092\u4f7f\u308f\u306a\u3044\u65b9\u304c\u30b3\u30fc\u30c9\u304c\u3059\u3063\u304d\u308a\u3057\u307e\u3059\u3002\u306a\u3093\u3068\u306a\u304f\u3067\u3059\u304c\u3001\u3053\u306e\u3042\u305f\u308a\u300c\u7406\u8ad6\u3068\u3057\u3066\u306e\u30d1\u30bf\u30fc\u30f3\u300d\u2192\u300c\u30d1\u30bf\u30fc\u30f3\u3092\u305d\u306e\u307e\u307e\u5b9f\u88c5\u300d\u3057\u3066\u3044\u308b\u300c\u7406\u8ad6\u300d\u9818\u57df\u306b\u7559\u307e\u3063\u3066\u304a\u308a\u3001\u5b9f\u969b\u306b\u4f5c\u696d\u91cf\u306a\u3069\uff08\u4eba\u7684\u30b9\u30ad\u30eb\u3082\u8fbc\u307f\uff09\u3092\u8003\u616e\u3057\u305f\u672c\u6765\u306e\u300c\u5de5\u5b66\u300d\u306b\u81f3\u3063\u3066\u3044\u306a\u3044\u6c17\u304c\u3057\u307e\u3059\u3002<\/p>\n<p># \u4f59\u8ac7\u3067\u3059\u304c\u3001Microsoft \u306e\u5b9f\u88c5\u9762\u306f\u3001\u591a\u5c11\uff08\uff1f\uff09\u3054\u3061\u3083\u3054\u3061\u3083\u306a\u9762\u3082\u542b\u3081\u3066\u79c1\u306f\u597d\u304d\u3067\u3059\u3002<br \/>\n# Java \u306e\u6574\u7406\u3055\u308c\u3061\u3083\u3063\u305f\u30b3\u30fc\u30c9\u30d1\u30bf\u30fc\u30f3\u3088\u308a\u3082\u3001C# \u306e\u3054\u3061\u3083\u3054\u3061\u3083\u3055\u306f\u3053\u306e\u624b\u306e\u30d1\u30bf\u30fc\u30f3\u3092\u5b9f\u88c5\u3059\u308b\u3068\u304d\u306b\u3001\u300c\u30d1\u30bf\u30fc\u30f3\u300d\u2260\u300c\u5b9f\u88c5\u30d1\u30bf\u30fc\u30f3\u300d\u3068\u3059\u308b\u3053\u3068\u304c\u53ef\u80fd\u306a\u306e\u3067\u3059\u3002\u3053\u306e\u3042\u305f\u308a\u3001C++ \u306e template \u3084 #define \u30de\u30af\u30ed\u306b\u901a\u3058\u308b\u3082\u306e\u304c\u3042\u308b\u3093\u3067\u3059\u304c\u3002\u6b8b\u5ff5\u306a\u304c\u3089 C# \u306f\u30d7\u30ea\u30d7\u30ed\u30bb\u30c3\u30b5\u3092\u5b9f\u88c5\u3057\u306a\u3044\u3068\u304d\u305f\u3082\u3093\u3060\u3002<\/p>\n<p>\u3048\u3048\u3068\u3001\u6700\u521d\u306b\u8a00\u3063\u3066\u304a\u304d\u307e\u3059\u304c\u3001\u79c1\u3068\u3057\u3066\u306f MVVM \u30e2\u30c7\u30eb\u3092\u3053\u306e\u3088\u3046\u306a\u5b9f\u88c5\u306e\u4ed5\u65b9\u306b\u3059\u308b\u306e\u306f\u53cd\u5bfe\u3067\u3059\u3002<br \/>\n\u3068\u3044\u3046\u306e\u3082\u3001ASP.NET \u3084 Silverlight \u306e\u5834\u5408\u3001\u65e2\u306bVisual Studio\u306e\u81ea\u52d5\u751f\u6210\u6a5f\u80fd\u306b\u3088\u3063\u3066\u3001\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u81ea\u8eab\u304c\u30d0\u30a4\u30f3\u30c9\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u3001Text\u30d7\u30ed\u30d1\u30c6\u30a3\u7b49\u306b\u72ec\u81ea\u306b\u30d0\u30a4\u30f3\u30c7\u30a3\u30f3\u30b0\u3059\u308b\u610f\u5473\u304c\u3042\u308a\u307e\u305b\u3093\u3002View\u3068Model\u3092\u5206\u3051\u305f\u3044\u306e\u3067\u3042\u308c\u3070\u3001Silverlight \u306b\u65e2\u306b\u5b9f\u88c5\u3057\u3066\u3042\u308b\u3082\u306e\u3092\u5229\u7528\u3059\u308b\u304c\u5206\u308a\u3084\u3059\u3044\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u305f\u3060\u3057\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3068\u306e\u81ea\u52d5\u30d0\u30a4\u30f3\u30c7\u30a3\u30f3\u30b0\u3092\u63a8\u3057\u9032\u3081\u305f\u5834\u5408\uff08\u3044\u308f\u3086\u308b\u30ce\u30f3\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u306e\u5834\u5408\uff09\u306b\u306f\u3001\u3053\u306e\u5b9f\u88c5\u304c\u6709\u52b9\u3067\u3059\u3002\u3053\u306e\u8a71\u306f\u5225\u306a\u6a5f\u4f1a\u306b\u3002\u3068\u3044\u3046\u304b\u3001\u672c\u5f53\u306f.NET\u30e9\u30dc\u306e\u52c9\u5f37\u4f1a\u3067\u8a71\u3057\u305f\u304b\u3063\u305f\u30cd\u30bf\u3067\u3059\u3002<\/p>\n<p>\u3068\u3001\u3084\u3063\u3068\u3053\u3053\u304b\u3089\u672c\u984c\u3067\u3059\u3002<\/p>\n<p>\u25a0Text\u30d7\u30ed\u30d1\u30c6\u30a3\u3078\u306e\u30d0\u30a4\u30f3\u30c9<\/p>\n<p>TextBox\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306b\u8868\u793a\u3059\u308bText\u30d7\u30ed\u30d1\u30c6\u30a3\u306e\u30d0\u30a4\u30f3\u30c9\u3092\u884c\u3044\u307e\u3059\u3002<br \/>\n\u307e\u305a\u3001xaml \u306b\u30d0\u30a4\u30f3\u30c9\u3059\u308b\u30dd\u30a4\u30f3\u30c8\u3092\u8a18\u8ff0\u3057\u307e\u3059\u3002<\/p>\n<p>Page.xaml<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\n&lt;Grid x:Name=&amp;quot;LayoutRoot&amp;quot; Background=&amp;quot;White&amp;quot;&gt;\r\n    &lt;StackPanel&gt;\r\n        &lt;TextBox Name=&amp;quot;TextName&amp;quot; Width=&amp;quot;100&amp;quot; Text=&amp;quot;{Binding LastName, Mode=TwoWay}&amp;quot; \/&gt;\r\n        &lt;Button Name=&amp;quot;BtnSave&amp;quot; Width=&amp;quot;100&amp;quot; Content=&amp;quot;\u4fdd\u5b58&amp;quot; Click=&amp;quot;BtnSave_Click&amp;quot; \/&gt;\r\n        &lt;TextBox Name=&amp;quot;TextOut&amp;quot; Width=&amp;quot;100&amp;quot; Text=&amp;quot;{Binding OutName, Mode=TwoWay}&amp;quot; \/&gt;\r\n    &lt;\/StackPanel&gt;\r\n&lt;\/Grid&gt;\r\n<\/pre>\n<p>Text=&#8221;{Binding LastName, Mode=TwoWay}&#8221;<\/p>\n<p>\u306e\u3068\u3053\u308d\u304c\u305d\u308c\u3067\u3059\u306d\u3002\u300cLastName\u300d\u3068\u3044\u3046\u540d\u524d\u3067\u30d0\u30a4\u30f3\u30c9\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u3055\u3066\u3001\u3053\u308c\u304c\u4f55\u51e6\u306b\u30d0\u30a4\u30f3\u30c9\u3055\u308c\u308b\u304b\u3068\u3044\u3046\u3068\u3001\u30e2\u30c7\u30eb\u30af\u30e9\u30b9\u306e\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u306a\u308a\u307e\u3059\u3002<br \/>\n\u30d0\u30a4\u30f3\u30c9\u304c\u53cc\u65b9\u5411\u300cTwoWay\u300d\u306a\u306e\u3067\u3001INotifyPropertyChanged\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u5b9f\u88c5\u3057\u307e\u3059\u3002INotifyPropertyChanged\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306f\u3001\u304a\u7d04\u675f\u306e\u30b3\u30fc\u30c9\u304c\u3042\u308b\u306e\u3067\u3001\u305d\u306e\u307e\u307e\u8cbc\u308a\u4ed8\u3051\u307e\u3059\u3002<br \/>\nSLExtensions \u3092\u4f7f\u3046\u5834\u5408\u306f\u3001\u3053\u3053\u306e\u30b3\u30fc\u30c9\u304c\u65e2\u306b\u5b9f\u88c5\u6e08\u307f\u3067\u3059\u3002<\/p>\n<p>\u4fbf\u5b9c\u4e0a Page.xaml.cs \u306b\u5165\u308c\u3066\u3044\u307e\u3059\u304c\u3001\u3069\u3053\u306b\u304a\u3044\u3066\u3082\u69cb\u3044\u307e\u305b\u3093\u3002<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\n\/\/\/ &lt;summary&gt;\r\n\/\/\/ \u30e2\u30c7\u30eb\u30af\u30e9\u30b9\r\n\/\/\/ &lt;\/summary&gt;\r\npublic class Model : INotifyPropertyChanged\r\n{\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u5165\u529b\u5024\r\n    \/\/\/ &lt;\/summary&gt;\r\n    private string _LastName = &amp;quot;&amp;quot;;\r\n    public string LastName\r\n    {\r\n        get { return _LastName; }\r\n        set\r\n        {\r\n            if (_LastName != value)\r\n            {\r\n                _LastName = value;\r\n                OnPropertyChanged(&amp;quot;LastName&amp;quot;);\r\n            }\r\n        }\r\n    }\r\n\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u4fdd\u5b58\u30dc\u30bf\u30f3\u62bc\u4e0b\u6642\u306e\u51fa\u529b\u5024\r\n    \/\/\/ &lt;\/summary&gt;\r\n    private string _OutName = &amp;quot;&amp;quot;;\r\n    public string OutName\r\n    {\r\n        get { return _OutName; }\r\n        set\r\n        {\r\n            if (_OutName != value)\r\n            {\r\n                _OutName = value;\r\n                OnPropertyChanged(&amp;quot;OutName&amp;quot;);\r\n            }\r\n        }\r\n    }\r\n    #region INotifyPropertyChanged \u30e1\u30f3\u30d0\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u30d7\u30ed\u30d1\u30c6\u30a3\u5909\u66f4\u6642\u306e\u30a4\u30d9\u30f3\u30c8\r\n    \/\/\/ &lt;\/summary&gt;\r\n    public event PropertyChangedEventHandler PropertyChanged;\r\n    protected virtual void OnPropertyChanged(PropertyChangedEventArgs e)\r\n    {\r\n        if (PropertyChanged != null)\r\n            PropertyChanged(this, e);\r\n    }\r\n    protected virtual void OnPropertyChanged(string name)\r\n    {\r\n        if (PropertyChanged != null)\r\n            PropertyChanged(this, new PropertyChangedEventArgs(name));\r\n    }\r\n    #endregion\r\n}\r\n<\/pre>\n<p>\u3053\u308c\u3067\u3001View\u3068Model\u306e\u6e96\u5099\u304c\u3067\u304d\u307e\u3057\u305f\u3002<br \/>\n\u305f\u3060\u3001\u3053\u306e\u307e\u307e\u3067\u306f\u30c0\u30e1\u3067\u3001\u3053\u308c\u3092\u7d50\u3073\u4ed8\u3051\u308b\u51e6\u7406\u3092\u5165\u308c\u307e\u3059\u3002<br \/>\nPage.xaml.cs<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\npublic partial class Page : UserControl\r\n{\r\n    public Page()\r\n    {\r\n        InitializeComponent();\r\n        this.DataContext = MyModel;\r\n    }\r\n    public Model MyModel = new Model();\r\n<\/pre>\n<p>\u30c7\u30fc\u30bf\u30d0\u30a4\u30f3\u30c9\u306f\u3001InitializeComponent \u306e\u524d\u306b\u5165\u308c\u308b\u306e\u304b\u3001\u5f8c\u308d\u306b\u5165\u308c\u308b\u306e\u304b\u6c7a\u307e\u3063\u3066\u306f\u3044\u307e\u305b\u3093\u304c\u3001\u4e00\u5fdc\u3001\u5f8c\u308d\u306b\u5165\u308c\u307e\u3059\u3002\u4f55\u304b\u3068 InitializeComponent \u306e\u4e2d\u3067\u8272\u3005\u3084\u3063\u3066\u304f\u308c\u308b\u306e\u3067\u3002<br \/>\nMyModel \u30d5\u30a3\u30fc\u30eb\u30c9\u304c public \u306b\u306a\u3063\u3066\u3044\u308b\u306e\u306f\u3001UnitTest \u306e\u305f\u3081\u3067\u3059\u3002\u672c\u6765\u3001Model \u306f View \u3084 ViewModel \u3068\u5207\u308a\u96e2\u3059\u306e\u304c\u76ee\u7684\u306a\u306e\u3067\u3001\u666e\u901a\u3053\u3053\u306b Model \u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306e\u5b9f\u4f53\u306f\u7f6e\u304d\u307e\u305b\u3093\u3002<br \/>\n\u5b9f\u884c\u3092\u78ba\u8a8d\u3057\u3066\u306f\u3044\u307e\u305b\u3093\u304c\u3001SLExtensions \u3092\u4f7f\u3046\u5834\u5408\u306f\u3001InitializeComponent \u306e\u524d\u306b\u5165\u308c\u308b\u5fc5\u8981\u304c\u3042\u308b\u3088\u3046\u3067\u3059\u3002<\/p>\n<p>\u3055\u3066\u3001\u3053\u308c\u3067 MVVM \u306e\u5b9f\u88c5\u304c\u6e08\u307f\u307e\u3057\u305f\u3002<\/p>\n<p>\u52d5\u304b\u3059\u3068\u3053\u308d\u306f\u3001\u4fdd\u5b58\u30dc\u30bf\u30f3\u3092\u62bc\u3057\u305f\u3068\u304d\u3067\u3001<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n\r\n&lt;Button Name=&amp;quot;BtnSave&amp;quot; Width=&amp;quot;100&amp;quot; Content=&amp;quot;\u4fdd\u5b58&amp;quot; Click=&amp;quot;BtnSave_Click&amp;quot; \/&gt;\r\n\r\n<\/pre>\n<p>\u306e BtnSave_Click \u30a4\u30d9\u30f3\u30c8\u304c\u767a\u751f\u3057\u305f\u3068\u304d\u3067\u3059\u3002<br \/>\n\u5b9f\u306f\u3001\u30a4\u30d9\u30f3\u30c8\u81ea\u4f53\u3082\u30d0\u30a4\u30f3\u30c9\u304c\u53ef\u80fd\uff08SLExtensions\u3067\u306f\u3001\u72ec\u81ea\u306b\u30d0\u30a4\u30f3\u30c9\u3057\u307e\u3059\uff09\u306a\u306e\u3067\u3059\u304c\u3001\u3053\u3053\u3067\u306f Page.xaml.cs \u306e\u307b\u3046\u306b\u8a18\u8ff0\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\nprivate void BtnSave_Click(object sender, RoutedEventArgs e)\r\n{\r\n    MyModel.OutName = MyModel.LastName;\r\n}\r\n<\/pre>\n<p>\u3053\u308c\u306f MyModel \u306e LastName \u306e\u5024\uff08\u6587\u5b57\u5217\uff09\u3092 OutName \u306b\u4ee3\u5165\u3057\u3066\u3044\u308b\u3068\u3053\u308d\u3067\u3059\u3002<br \/>\n\u666e\u901a\u306f\u3001<\/p>\n<p>    TextOut.Text = TextName.Text;<\/p>\n<p>\u306a\u611f\u3058\u3067\u30c6\u30ad\u30b9\u30c8\u30dc\u30c3\u30af\u30b9\u306eText\u30d7\u30ed\u30d1\u30c6\u30a3\u3092\u53c2\u7167\u3059\u308b\u3068\u3053\u308d\u3067\u3059\u304c\u3001\u3053\u3053\u3067\u306fModel\u30af\u30e9\u30b9\u306e\u30d7\u30ed\u30d1\u30c6\u30a3\u3092\u5229\u7528\u3057\u307e\u3059\u3002<br \/>\nText\u30d7\u30ed\u30d1\u30c6\u30a3\u306e\u307b\u3046\u304c\u3001\u5206\u308a\u3084\u3059\u3044\u3068\u8a00\u3048\u3070\u5206\u308a\u3084\u3059\u3044\u306e\u3067\u3059\u304c\u3001\u3053\u3053\u306fMVVM\u30e2\u30c7\u30eb\u306e\u5f0a\u5bb3\u3067\u3059\u306d\u3002Model\u30af\u30e9\u30b9\u3092\u4f7f\u3046\u3068\u76f4\u89b3\u7684\u3067\u306a\u3044\u306e\u304c\u6b8b\u5ff5\u3067\u3059\u3002\u305f\u3060\u3001\u6163\u308c\u308b\u3068\u3001<\/p>\n<p>\u30fbView\u30af\u30e9\u30b9\u306e\u6319\u52d5\u3092\u77e5\u3089\u306a\u304f\u3066\u3088\u3044\u3002<br \/>\n\u30fb\u30b7\u30ea\u30a2\u30e9\u30a4\u30ba\u7b49\u306e\u30c7\u30fc\u30bf\u306b\u95a2\u3059\u308b\u30e1\u30bd\u30c3\u30c9\u3092 Model \u30af\u30e9\u30b9\u306b\u96c6\u7d04\u3067\u304d\u308b<br \/>\n\u30fb\u5358\u4f53\u30c6\u30b9\u30c8\u304c\u3057\u3084\u3059\u3044<\/p>\n<p>\u3068\u3044\u3046\u5229\u70b9\u304c\u3042\u308a\u307e\u3059\u3002\u7279\u306b\u5358\u4f53\u30c6\u30b9\u30c8\u306f\u4fbf\u5229\u3067\u3059\u3002<br \/>\n\u666e\u901a Silverlight \u306e\u753b\u9762\u306e\u30c6\u30b9\u30c8\u306f\u3001\u3072\u3068\u304c\u624b\u3067\u30de\u30a6\u30b9\u3092\u30af\u30ea\u30c3\u30af\u3057\u306a\u304c\u3089\u3084\u308b\u3068\u601d\u3046\u306e\u3067\u3059\u304c\u3001Model \u30af\u30e9\u30b9\u306b\u5206\u96e2\u3059\u308b\u3068\u3001\u901a\u5e38\u306e NUnit \u306e\u3088\u3046\u306a\u30c6\u30b9\u30c8\u30c4\u30fc\u30eb\u304c\u4f7f\u3048\u307e\u3059\u3002<br \/>\n\u3082\u3063\u3068\u3082\u3001Silverlight \u7528\u306e\u30c6\u30b9\u30c8\u30c4\u30fc\u30eb\u3082\u3042\u308b\u306e\u3067\u3001\u305d\u308c\u3092\u5229\u7528\u3059\u308b\u306e\u3082\u30c6\u3067\u3059\u3002<\/p>\n<p>\u5148\u306eModel\u30af\u30e9\u30b9\u3092\u52d5\u304b\u3059\u3068\u3001\u753b\u9762\u306eTextBox\u3092\u89e6\u3063\u3066\u3044\u306a\u3044\u306e\u306b\u3001\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u304d\u3061\u3093\u3068\u6587\u5b57\u5217\u304c\u8868\u793a\u3055\u308c\u307e\u3059\u3002\u3053\u308c\u304c\u300c\u30d0\u30a4\u30f3\u30c9\u300d\u306e\u52b9\u679c\u3067\u3001\u5148\u306b xaml \u306b\u3057\u305f Binding \u3068 Model \u306e\u30d7\u30ed\u30d1\u30c6\u30a3\u304c\u7d50\u3073\u3064\u3044\u3066\u3044\u308b\u305f\u3081\u306b\u3001\u3053\u306e\u3088\u3046\u306b\u52d5\u304d\u307e\u3059\u3002<\/p>\n<p>\u25a0\u30d0\u30a4\u30f3\u30c9\u306e\u843d\u3068\u3057\u7a74<\/p>\n<p>\u3055\u3066\u3001\u3053\u3053\u304b\u3089\u304c\u672c\u984c\u3067\u3059\u3002<br \/>\n\u3053\u306e\u30d0\u30a4\u30f3\u30c9\u306e\u6a5f\u80fd\u3092\u4f7f\u3063\u305f MVVM \u30e2\u30c7\u30eb\u3067\u3059\u304c\u3001\u7d4c\u9a13\u304c\u6d45\u3044\uff08\uff1f\uff09\u3068 Model \u306e\u4f5c\u6210\u306b\u9589\u53e3\u3057\u307e\u3059\u3002<br \/>\n\u305f\u3076\u3093\u3001Visual Studio \u3067\u753b\u9762\u3092\u3044\u3063\u307a\u3093\u3044\u4f5c\u3063\u3066\u3044\u308b\u3068\u753b\u9762\u3068\u30a4\u30d9\u30f3\u30c8\u306e\u7d50\u3073\u3064\u3051\u3092\u610f\u8b58\u3057\u306a\u3044\u306e\u3067\uff08\u610f\u8b58\u3057\u306a\u3044\u9020\u308a\u306b\u306a\u3063\u3066\u3044\u308b\u306e\u3067\uff09\u3001\u3053\u306e\u3042\u305f\u308a\u3092\u5206\u96e2\u3059\u308b\u306e\u304c\u56f0\u96e3\u306a\u306e\u3060\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u305d\u3046\u3044\u3046\u5834\u5408\u306f\u3001\u7d20\u76f4\u306b MVVM \u30e2\u30c7\u30eb\u3092\u8ae6\u3081\u3066\u3001\u5148\u306e Page.xml.cs \u306b\u76f4\u63a5\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u7d4c\u7531\u3067\u5024\u3092\u64cd\u4f5c\u3057\u305f\u307b\u3046\u304c\u7121\u96e3\u3067\u3059\u3002\u3082\u3068\u3082\u3068 Silverlight \u3084 ASP.NET \u304c MVC \u30e2\u30c7\u30eb\u3067\u51fa\u6765\u3066\u3044\u308b\u306e\u3067\u3001\u3042\u3048\u3066\u53b3\u3057\u3044\u5236\u9650\u3055\u308c\u305f\u5f62\u3067 MVVM \u30e2\u30c7\u30eb\u3092\u5c0e\u5165\u3059\u308b\u5fc5\u8981\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\n<p>\u304c\u3001\u73fe\u5834\u306e\u72b6\u6cc1\u306b\u3088\u308a\u3051\u308a\u3067\u3057\u3066\u3001\u3069\u3046\u3057\u3066\u3082 Model \u3092\u4f5c\u3089\u306a\u3044\u3068\u99c4\u76ee\u306b\u306a\u3063\u305f\u3068\u304d\u306b\u3001\u601d\u308f\u305a\u300c\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u305d\u306e\u3082\u306e\u3092\u30d0\u30a4\u30f3\u30c9\u3057\u3066\u3057\u307e\u304a\u3046\u300d\u3068\u3044\u3046\u767a\u60f3\u306b\u306a\u308a\u307e\u3059\u3002<br \/>\n\u3053\u308c\u304c\u843d\u3068\u3057\u7a74\u3067\u3059\u3002<\/p>\n<p>\u3067\u306f\u5b9f\u969b\u306b\u3001\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u30d0\u30a4\u30f3\u30c9\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<p>Page.xaml<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n&lt;Grid x:Name=&amp;quot;LayoutRoot&amp;quot; Background=&amp;quot;White&amp;quot;&gt;\r\n    &lt;StackPanel&gt;\r\n        &lt;TextBox Name=&amp;quot;TextBoxIn&amp;quot; Width=&amp;quot;100&amp;quot; DataContext=&amp;quot;{Binding TBoxInName, Mode=TwoWay}&amp;quot; \/&gt;\r\n        &lt;TextBox Name=&amp;quot;TextBoxOut&amp;quot; Width=&amp;quot;100&amp;quot; DataContext=&amp;quot;{Binding TBoxOutName, Mode=TwoWay}&amp;quot; \/&gt;\r\n        &lt;Button Name=&amp;quot;BtnSave&amp;quot; Width=&amp;quot;100&amp;quot; Content=&amp;quot;\u4fdd\u5b58&amp;quot; Click=&amp;quot;BtnSave_Click&amp;quot; \/&gt;\r\n    &lt;\/StackPanel&gt;\r\n&lt;\/Grid&gt;\r\n<\/pre>\n<p>\u4e0a\u8a18\u306e\u3088\u3046\u306b DataContext \u306b\u30d0\u30a4\u30f3\u30c9\u3057\u3066\u3057\u307e\u3044\u307e\u3059\u3002<br \/>\nPage.xaml.cs \u306b\u8a18\u8ff0\u3059\u308b\u3068\u304d\u306f TextBoxIn \u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u76f4\u63a5\u53c2\u7167\u3067\u304d\u308b\u306e\u3067\u3059\u304c\u3001Model \u304b\u3089\u306f TextBoxIn \u304c\u898b\u308c\u307e\u305b\u3093\u3002\u3067\u3059\u306e\u3067\u3001\u30d0\u30a4\u30f3\u30c9\u3057\u3066\u3057\u307e\u3046\u308f\u3051\u3067\u3059\u3002<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\n\/\/\/ &lt;summary&gt;\r\n\/\/\/ \u30e2\u30c7\u30eb\u30af\u30e9\u30b9\r\n\/\/\/ &lt;\/summary&gt;\r\npublic class Model : INotifyPropertyChanged\r\n{\r\n\r\n    private TextBox _TBoxOutName = new TextBox();\r\n    public TextBox TBoxOutName\r\n    {\r\n        get { return _TBoxOutName; }\r\n        set\r\n        {\r\n            if (_TBoxOutName != value)\r\n            {\r\n                _TBoxOutName = value;\r\n                OnPropertyChanged(&amp;quot;TBoxOutName&amp;quot;);\r\n            }\r\n        }\r\n    }\r\n    private TextBox _TBoxInName = new TextBox();\r\n    public TextBox TBoxInName\r\n    {\r\n        get { return _TBoxInName; }\r\n        set\r\n        {\r\n            if (_TBoxInName != value)\r\n            {\r\n                _TBoxInName = value;\r\n                OnPropertyChanged(&amp;quot;TBoxInName&amp;quot;);\r\n            }\r\n        }\r\n    }\r\n   \r\n}\r\n<\/pre>\n<p>Model \u30af\u30e9\u30b9\u3067\u306f\u3001TBoxOutName \u30d7\u30ed\u30d1\u30c6\u30a3\u3067\u53d7\u3051\u307e\u3059\u3002<br \/>\nTextBox \u30af\u30e9\u30b9\u306b\u306a\u308b\u306e\u3067\u3001\u300c\u5b09\u3057\u3044\u300d\u3053\u3068\u306b<\/p>\n<p>TBoxOutName.Text<\/p>\n<p>\u306a\u3063\u3066\u5f62\u3067Text\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u30a2\u30af\u30bb\u30b9\u3067\u304d\u307e\u3059\u3002<br \/>\n\u306a\u306e\u3067\u3001\u4fdd\u5b58\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3057\u305f\u3068\u304d\u306f\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\nprivate void BtnSave_Click(object sender, RoutedEventArgs e)\r\n{\r\n MyModel.TBoxOutName.Text = MyModel.TBoxInName.Text;\r\n}\r\n<\/pre>\n<p>\u4e00\u898b\u3059\u308b\u3068\u3001\u4f55\u3082\u5909\u308f\u3063\u3066\u3044\u306a\u3044\u3088\u3046\u306b\u898b\u3048\u307e\u3059\u304c\u3001\u30c6\u30ad\u30b9\u30c8\u30dc\u30c3\u30af\u30b9\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u76f4\u63a5\u53c2\u7167\u3057\u3066\u3044\u307e\u3059\u3002\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306a\u306e\u3067\u3001Text\u30d7\u30ed\u30d1\u30c6\u30a3\u3092\u76f4\u63a5\u6271\u3048\u308b\u3001\u3068\u3044\u3046\u5229\u70b9\u304c\u3042\u308b\u306e\u3067\u3059\u304c\u3002<br \/>\n\u5229\u70b9\u3068\u3044\u3046\u304b\u96e3\u70b9\u3068\u3044\u3046\u304b\u3001MVVM \u30e2\u30c7\u30eb\u4e0a\u306e\u30eb\u30fc\u30eb\u9055\u53cd\u3067\u3059\u3088\u306d\u3002\u3053\u308c\u306f\u3002\u30c7\u30b6\u30a4\u30f3\u306b\u95a2\u308f\u308b\u3068\u3053\u308d\u3092\u3054\u3063\u305d\u308a\u6301\u3063\u3066\u304d\u3066 Model \u30af\u30e9\u30b9\u3067\u64cd\u4f5c\u3057\u3066\u3057\u307e\u3046\u3001\u3063\u3066\u306e\u304c\u9593\u9055\u3044\u3067\u3059\u3002<\/p>\n<p>\u3067\u3001\u3053\u308c\u3067\u52d5\u4f5c\u3055\u305b\u308b\u3068\u3001\u666e\u901a\u306b\u52d5\u304d\u307e\u3059\u3002\u5148\u306eText\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u30d0\u30a4\u30f3\u30c9\u3057\u305f\u3068\u304d\u3068\u540c\u3058\u3088\u3046\u306b\u4fdd\u5b58\u30dc\u30bf\u30f3\u3092\u30af\u30ea\u30c3\u30af\u3059\u308b\u3068\u3001\u753b\u9762\u306e\u30c6\u30ad\u30b9\u30c8\u30dc\u30c3\u30af\u30b9\u306b\u30d0\u30a4\u30f3\u30c9\u3055\u308c\u307e\u3059\u3002<br \/>\n\u306a\u306e\u3067\u3001\u3069\u3063\u3061\u3067\u3082\u3044\u3044\u3058\u3083\u3093\u3001\u3081\u3067\u305f\u3057\u3081\u3067\u305f\u3057\uff08\u30eb\u30fc\u30eb\u9055\u53cd\u306f\u5225\u3068\u3057\u3066\uff09\u306b\u601d\u3048\u308b\u306e\u3067\u3059\u304c\u3001\u5b9f\u306f\u9055\u3044\u307e\u3059\u3002<br \/>\n\u3053\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306e\u30d0\u30a4\u30f3\u30c9\u3002\u4e00\u898b\u3001TBoxOutName.Text\u30d7\u30ed\u30d1\u30c6\u30a3\u304c\u30c6\u30ad\u30b9\u30c8\u30dc\u30c3\u30af\u30b9\u306eText\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u76f4\u63a5\u30d0\u30a4\u30f3\u30c9\u3067\u304d\u3066\u3044\u308b\u3088\u3046\u306b\u601d\u3048\u307e\u3059\u304c\u300c\u9055\u3044\u307e\u3059\u300d\u3002\u753b\u9762\u3092\u8868\u793a\u3057\u3066\u3044\u308b\u3068\u304d\u306b\u3001\u30c6\u30ad\u30b9\u30c8\u30dc\u30c3\u30af\u30b9\u304cText\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u8a2d\u5b9a\u3057\u3066\u3044\u308b\u3060\u3051\u306a\u306e\u3067\u3059\u3002<br \/>\n\u3053\u308c\u306f\u3001Silverlight \u306e UnitTest \u3092\u3057\u305f\u6642\u306b\u5224\u660e\u3057\u307e\u3059\u3002<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\n    model.TBoxInName.Text = &quot;masuda&quot;;\r\n    Assert.AreEqual(&quot;masuda&quot;, model.TBoxInName.Text);\r\n    _page.TestBtnSaveClick();\r\n    Assert.AreEqual(&quot;masuda&quot;, model.TBoxOutName.Text);\r\n    \/\/ \u5373\u6642\u30d0\u30a4\u30f3\u30c9\u3055\u308c\u306a\u3044\r\n    Assert.AreEqual(&quot;masuda&quot;, _page.TextBoxOut.Text); \u2605\r\n<\/pre>\n<p>\u5b9f\u306f\u2605\u306e\u3068\u3053\u308d\u3067\u30a8\u30e9\u30fc\u306b\u306a\u308a\u307e\u3059\u3002<br \/>\n\u30e2\u30c7\u30eb\u306e\u30d7\u30ed\u30d1\u30c6\u30a3\uff08model.TBoxOutName.Text\uff09\u306f\u300cmasuda\u300d\u304c\u8a2d\u5b9a\u3055\u308c\u3066\u3044\u307e\u3059\u304c\u3001\u76f4\u63a5\u30c6\u30ad\u30b9\u30c8\u30dc\u30c3\u30af\u30b9\u306e\u30d7\u30ed\u30d1\u30c6\u30a3\uff08TextBoxOut.Text\uff09\u3092\u53c2\u7167\u3057\u305f\u3068\u304d\u306b\u306f\u7a7a\u767d\u304c\u8fd4\u308a\u307e\u3059\u3002<br \/>\n\u3057\u304b\u3057\u3001\u753b\u9762\u3067\u52d5\u304b\u3059\u3068\u554f\u984c\u306f\u3042\u308a\u307e\u305b\u3093\u3002\u304d\u3061\u3093\u3068\u3001TextBoxOut\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306b\u300cmasuda\u300d\u304c\u8868\u793a\u3055\u308c\u307e\u3059\u3002<br \/>\n\u306a\u305c\u3067\u3057\u3087\u3046\u304b\uff1f <\/p>\n<p>\u25a0\u30d0\u30a4\u30f3\u30c9\u306f\u5373\u6642\u884c\u308f\u308c\u308b<\/p>\n<p>MVVM \u30e2\u30c7\u30eb\u306e\u5b9f\u88c5\u3067\u4f7f\u308f\u308c\u308b OnPropertyChanged \u30e1\u30bd\u30c3\u30c9\u3067\u3059\u304c\u3001\u5185\u90e8\u3067\u30ad\u30e5\u30fc\u306a\u3069\u3092\u5229\u7528\u3057\u3066\u3044\u308b\u308f\u3051\u3067\u306f\u306a\u304f\uff08\u5b9f\u88c5\u4e0a\u3001\u305d\u3046\u3044\u3046\u30d0\u30a4\u30f3\u30c9\u3082\u3042\u308a\u3067\u3057\u3087\u3046\u304c\uff09\u3001Silverlight \u306e\u5834\u5408\u306f\u5373\u6642\u5b9f\u884c\uff08\u95a2\u6570\u30b3\u30fc\u30eb\u578b\uff09\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\u306a\u306e\u3067\u3001\u30b7\u30fc\u30b1\u30f3\u30b9\u3068\u3057\u3066\u306f\u3001<\/p>\n<p>1.Model\u306b\u5024\u3092\u8a2d\u5b9a\u3059\u308b<br \/>\n2.Model\u30d7\u30ed\u30d1\u30c6\u30a3\u304cOnPropertyChagned\u3092\u547c\u3073\u51fa\u3059\u3002<br \/>\n3.View\u306eProeprtyChanged\u30a4\u30d9\u30f3\u30c8\u304c\u5b9f\u884c\u3055\u308c\u308b\u3002<br \/>\n4.View\u306e\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u5024\u304c\u8a2d\u5b9a\u3055\u308c\u308b\u3002<\/p>\n<p>\u306e\u3088\u3046\u306b\u30b7\u30fc\u30b1\u30f3\u30b7\u30e3\u30eb\u306b\u52d5\u304d\u307e\u3059\u3002<\/p>\n<p>\u304c\u3001\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u30d0\u30a4\u30f3\u30c9\u3057\u305f\u5834\u5408\u306b\u306f\u3001<\/p>\n<p>\u30fb\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u81ea\u8eab\u306e\u5909\u66f4\u3067\u306f\u30a4\u30d9\u30f3\u30c8\u304c\u767a\u751f\u3059\u308b\u306e\u3067\u3059\u304c\u3001<br \/>\n\u30fb\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306e\u30d7\u30ed\u30d1\u30c6\u30a3\uff08Text\u30d7\u30ed\u30d1\u30c6\u30a3\u306a\u3069\uff09\u3067\u306f\u30a4\u30d9\u30f3\u30c8\u306f\u767a\u751f\u3057\u307e\u305b\u3093\u3002<\/p>\n<p>\u5f53\u305f\u308a\u524d\u3068\u3044\u3048\u3070\u5f53\u305f\u308a\u524d\u3067\u3059\u304c\u3001\u30d0\u30a4\u30f3\u30c9\u3057\u305f\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306b\u5bfe\u3057\u3066\u306e\u307f\u30d0\u30a4\u30f3\u30c9\u304c\u767a\u751f\u3057\u307e\u3059\u3002\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u304c\u6301\u3063\u3066\u3044\u308b\u30d5\u30a3\u30fc\u30eb\u30c9\u3084\u5b50\u306e\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u5909\u66f4\u3057\u3066\u3082\u3001\u30a4\u30d9\u30f3\u30c8\u306f\u767a\u751f\u3057\u307e\u305b\u3093\u3002<\/p>\n<p>\u3053\u3053\u304c\u300c\u843d\u3068\u3057\u7a74\u300d\u3067\u3059\u3002<\/p>\n<p>\u306a\u306e\u3067\u3001\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306b\u5bfe\u3057\u3066\u30d0\u30a4\u30f3\u30c9\u3092\u884c\u3063\u305f\u5834\u5408\u3001\u4e00\u898b\u3001\u30d0\u30a4\u30f3\u30c9\u304c\u3046\u307e\u304f\u52d5\u3044\u3066\u3044\u308b\u3088\u3046\u306b\u898b\u3048\u307e\u3059\u304c\u3001\u5b9f\u306f\u5168\u7136\u5f79\u306b\u7acb\u3063\u3066\u3044\u307e\u305b\u3093\u3002<\/p>\n<p>\u30b7\u30fc\u30b1\u30f3\u30b9\u3068\u3057\u3066\u306f\u3001<\/p>\n<p>1.Model\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306eText\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u5024\u3092\u8a2d\u5b9a\u3059\u308b\u3002<br \/>\n2.\u3053\u306e\u6642\u70b9\u3067\u306f\u3001\u30d0\u30a4\u30f3\u30c9\u304c\u8d70\u3089\u305a\u3001View\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306b\u306f\u53e4\u3044\u5024\u304c\u6b8b\u3063\u305f\u307e\u307e\u3002<br \/>\n3.\u753b\u9762\u3092\u518d\u63cf\u753b\u3059\u308b\u30a4\u30d9\u30f3\u30c8\u304c\u8d70\u308b\uff08\u30dc\u30bf\u30f3\u30a4\u30d9\u30f3\u30c8\u306a\u3069\uff09\u3002<br \/>\n4.\u8868\u793a\u6642\u306bView\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u304cText\u30d7\u30ed\u30d1\u30c6\u30a3\u3092\u53c2\u7167\u3059\u308b\u3002<br \/>\n5.Model\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306eText\u30d7\u30ed\u30d1\u30c6\u30a3\u306e\u5024\u3092\u53d6\u5f97\u3059\u308b\u3002<br \/>\n6.View\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306eText\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u5024\u304c\u8a2d\u5b9a\u3055\u308c\u308b\u3002<br \/>\n7.View\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306eText\u30d7\u30ed\u30d1\u30c6\u30a3\u304c\u753b\u9762\u306b\u8868\u793a\u3055\u308c\u308b\u3002<\/p>\n<p>\u3068\u3044\u3046\u9806\u5e8f\u306b\u306a\u3063\u3066\u304a\u308a\u3001UnitTest \u3092\u52d5\u304b\u3057\u305f\u3068\u304d\u306b\u306f\u30012\u3067\u5024\u3092\u53d6\u5f97\u3057\u3066NG\u3002\u3060\u304c\u3001\u753b\u9762\u306f7\u306e\u6642\u70b9\u3067\u8868\u793a\u3055\u308c\u308b\u304b\u3089OK\u3063\u3066\u3044\u3046\u5177\u5408\u306a\u306e\u304b\u306a\u3001\u3068\u3002<\/p>\n<p>\u307e\u3041\u3001\u3069\u3063\u3061\u306b\u305b\u3088\u3001\u2193\u306a\u5f62\u3067\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u76f4\u63a5\u30d0\u30a4\u30f3\u30c9\u3059\u308b\u306e\u306f\u30eb\u30fc\u30eb\u9055\u53cd\u3067\u3059\u306d\u3002\u526f\u4f5c\u7528\u3082\u5927\u304d\u3044\u3057\u3001\u907f\u3051\u3066\u304a\u304d\u305f\u3044\u843d\u3068\u3057\u7a74\u3067\u3059\u3002<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\"> \r\n\r\n        &lt;TextBox Name=&amp;quot;TextBoxIn&amp;quot; Width=&amp;quot;100&amp;quot; DataContext=&amp;quot;{Binding TBoxInName, Mode=TwoWay}&amp;quot; \/&gt;\r\n<\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u5c11\u3057\u4ed5\u4e8b\u306e\u30da\u30fc\u30b9\u304c\u843d\u3061\u7740\u3044\u3066\u304d\u305f\u306e\u3067\u60c5\u5831\u3092\u6d41\u3057\u3066\u304a\u304d\u307e\u3059\u3002 \u73fe\u5728\u4f7f\u3063\u3066\u3044\u308b\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u304c SLExtensions \u306e DLL \u3092\u4f7f\u3063\u3066\u3044\u308b\u306e\u3067\u3001\u306a\u3093\u3058\u3083\u308d\uff1f\u3068\u3044\u3046\u5f62\u3067 MVVM \u30e2\u30c7\u30eb\u3063\u3066\u306e\u304c\u3042\u308b\u306e\u3053\u3068\u3092\u77e5\u308a\u307e\u3057\u305f\u3002 &hellip; <a href=\"http:\/\/www.moonmile.net\/blog\/archives\/302\">\u7d9a\u304d\u3092\u8aad\u3080 <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[3],"tags":[],"class_list":["post-302","post","type-post","status-publish","format-standard","hentry","category-dev"],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/302","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/comments?post=302"}],"version-history":[{"count":9,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/302\/revisions"}],"predecessor-version":[{"id":305,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/302\/revisions\/305"}],"wp:attachment":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/media?parent=302"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/categories?post=302"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/tags?post=302"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}