-
-
Notifications
You must be signed in to change notification settings - Fork 71
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Best way to implement "Statically-typed view model" approach? #589
Comments
Ahh, I see what the problem is. Yes, your View Model cannot be inside a module, as XAML doesn't support nested types (F# modules are implemented as types in .NET). This slightly complicates your simple example, as you'll have to split things up into several modules. Take your view model and put it outside and after the I'll work on making the documentation clearer with an explicit section in the docs around this feature. The example of this is in Let me know if you have any more questions or suggestions! |
It works, thanks a lot!
I must mention, as a newcomer transitioning directly from C#+MVVM, such a sample would have saved me a great deal of time and effort. (I guess from the documentation any F# programmer would have figured it out rapidly, but for anyone in a learning process I think it might no be as evident)
I'm asking since in the samples, clearly the bindings approach is preferred, so does it have any advantages versus the other one other than readability and a more "functionnal" style? Thank you again |
If you have a sample to suggest already made, by all means share it. Even if we don't use it directly, it could inspire ideas. The "view model class" approach is relatively new, which is why the "binding list" approach has many more samples. If you use view model classes, you will be able to navigate from XAML binding usages to their definitions in Rider and Visual Studio. Rider will also check XAML when you search for usages. I don't think that the "binding list" approach has any particular advantages, but we will keep it around to avoid breaking existing code. |
(We having been calling them dynamic bindings and static bindings.) I prefer dynamic bindings, but I stopped using Elmish.WPF (due to job change) before static bindings were created. |
I'm having trouble understanding how to implement the statically-typed view model approach. (everything is working fine with the bindings approach)
I attempted to use the guidance from Elmish.WPF on GitHub, but despite spending a lot of time on it, I find the documentation either unclear or possibly outdated. Is there a complete and current sample that demonstrates the best way to do this?
I've been working on this implementation, but regardless of my efforts, the 'HelloViewModel' does not appear in Intellisense. Here's my attempt: https://github.com/YkTru/ElmishWPF_StaticallyTypedViewModel.
Any assistance would be greatly appreciated. Thank you.
The text was updated successfully, but these errors were encountered: