knockout
An introduction for WPFists
MVVM for Javascript
- Dependency tracking
- Automatic UI refresh
- Declarative bindings
Basic Property binding
Knockout
<div>You've clicked <span data-bind='text: numberOfClicks'> </span> times</div>
WPF
<TextBlock>
<TextBlock.Inlines>
<Run>You've clicked </Run>
<Run Text="{Binding NumberOfClicks.Value}"/>
<Run> times</Run>
</TextBlock.Inlines>
</TextBlock>
Command binding
Knockout
<button
data-bind='click: registerClick, disable: hasClickedTooManyTimes'>
Click me
</button>
WPF
<Button Command="{Binding RegisterClickCommand}"> Click me</Button>
ICommand
public ICommand RegisterClickCommand
{
get { return new RelayCommand(
RegisterClick, () => !HasClickedTooManyTimes.Value); }
}
Visible binding
Knockout
<div data-bind='visible: hasClickedTooManyTimes'>
That's too many clicks! Please stop before you wear out your fingers.
<button data-bind='click: resetClicks'>Reset clicks</button>
</div>
WPF
<StackPanel Orientation="Horizontal">
<StackPanel.Visibility>
<Binding Path="HasClickedTooManyTimes.Value">
<Binding.Converter>
<BooleanToVisibilityConverter />
</Binding.Converter>
</Binding>
</StackPanel.Visibility>
<TextBlock>That's too many clicks! Please stop before you wear out your fingers.</TextBlock>
<Button Command="{Binding ResetClicks}">Reset clicks</Button>
</StackPanel>
Viewmodel
Knockout
var ClickCounterViewModel = function() {
this.numberOfClicks = ko.observable(0);
this.registerClick = function() {
this.numberOfClicks(this.numberOfClicks() + 1);
};
this.resetClicks = function() {
this.numberOfClicks(0);
};
this.hasClickedTooManyTimes = ko.computed(function() {
return this.numberOfClicks() >= 3;
}, this);
};
WPF
Apply Bindings
Knockout
ko.applyBindings(new ClickCounterViewModel());
WPF
public partial class MainWindow : Window
{
public MainWindow()
{
DataContext = new MainWindowViewModel();
InitializeComponent();
}
}
knockout In Web Apps
WPF MVVM
CEF MVVM
Demo
Next Steps
- Code is proof of concept - not production ready
- Doesn't work for deeply nested types
- Open source it!
knockout
By David
knockout
- 759