What is Knockout ?
Knockout is a JavaScript Library Which helps the creation of rich, desktop-like web UIs.It simplifies user interactions and makes interfaces fully responsive to any data source
changes.Knockout
provides a simple two-way binding mechanism to link a data model to an UI,Thus making synchronization between them a breeze.You can read Original Article about this on
My Blog Here.
What are the Key Concepts of Knockout ?
1. Declarative Bindings
- These allow you to connect parts of your UI to your data model in a simple and convenient way
- With declarative bindings even if you change the DOM all bound pieces stay connected
- You can bind data to a DOM by simply including a data-bind attribute to any DOM element
2. Automatic UI Refresh
data:image/s3,"s3://crabby-images/1d5e8/1d5e854c8642b4fd80e3105cd26668cebe756e48" alt="Automatic UI Refresh Automatic UI Refresh"
3. Dependency Tracking
- Every time when your model data has changed all parts associated with it automatically being updated
- No need to worry about adding event handlers and listeners
- All that extra work is performed internally by Knockout and observables,
- Which notify listeners when underlying values have changed
4. Templating
- when your application becomes more complex and you need a way to display a rich structure of view model data,thus keeping your code simple
- Knockout has a native, built-in template engine which you can use right away
- But if you want, a third-party template engine, like jquery.tmpl or Underscore, also can be used
data:image/s3,"s3://crabby-images/8278e/8278edb582d229ecfd080a9bf3f61dfdca5ea0c3" alt="Templating Templating"
More Features of Knockout
How to Download Knockout ?
Step 1
data:image/s3,"s3://crabby-images/c2bc6/c2bc653154442d22e07c61163dffd073f9762db8" alt="Download Knockout Download Knockout"
Step 2
data:image/s3,"s3://crabby-images/a153e/a153ec3bfc72ff207f510dd4c5e1d578255746e4" alt="Download Knockout Download Knockout"
Step 3
How to work with Knockout ?
- You have to add a reference to the "knockout-2.2.0.js" File which you downloaded
- Then You have to add Reference to above file inside your master file
i.e. Inside \Views\Shared\_Layout.cshtml
<script src="@Url.Content("~/Scripts/knockout-2.2.0.js")" type="text/javascript"></script>
That's it.Your done.
Let's try with some basic capabilities of Knockout
ASP.Net MVC 3 and Visual Studio 2010 has been used.
CASE 1 : How to use bindings in the View (Static Data) ?
- For that you can use data-bind attributes
View's Code
?<!-- This is a View - HTML markup that defines the appearance of your UI -->
<p>First name: <strong data-bind="text: firstName"></strong></p>
<p>Last name: <strong data-bind="text: lastName"></strong></p>
Javascript Code
<script type="text/javascript">
functionAppViewModel() {
this.firstName = "Sampath";
this.lastName = "Lokuge";
}
ko.applyBindings(newAppViewModel());
</script>
Output
data:image/s3,"s3://crabby-images/f4ea0/f4ea0a4fe3e4234805608007156e583a70714a08" alt="How to use bindings in the View How to use bindings in the View"
CASE 2 : How to Make the data Editable (Dynamic Data) ?
- That's why Knockout has a concept of observables
- These are properties that automatically will issue notifications whenever their value changes
i.e.
- Not only that the underlying ViewModel data is being updated when you edit ,
- But that all associated UI is updating in Sync with it too
View's Code
<!-- This is a View - HTML markup that defines the appearance of your UI -->
<p>First name: <strong data-bind="text: firstName"></strong></p>
<p>Last name: <strong data-bind="text: lastName"></strong></p>
<p>First name:<input data-bind="value: firstName" /></p>
<p>Last name:<input data-bind="value: lastName" /></p>
Javascript Code
<script type="text/javascript">
functionAppViewModel() {
this.firstName = ko.observable();
this.lastName = ko.observable();
}
ko.applyBindings(newAppViewModel());
</script>
Output
CASE 3 : How to Define Computed Values ?
- To handle this, Knockout has a concept of Computed Properties
- These are observable (i.e., they notify on change)
- And they are computed based on the values of other observables
View's Code
<!-- This is a View - HTML markup that defines the appearance of your UI -->
<p>First name: <strong data-bind="text: firstName"></strong></p>
<p>Last name: <strong data-bind="text: lastName"></strong></p>
<p>First name:<input data-bind="value: firstName" /></p>
<p>Last name:<input data-bind="value: lastName" /></p>
<p>Full name: <strong data-bind="text: fullName"></strong></p>
Javascript Code
Note: In order to simplify things you can create a variable self (i.e. var self = this;
)
<script type="text/javascript">
functionAppViewModel() {
varself = this;
self.firstName = ko.observable();
self.lastName = ko.observable();
self.fullName = ko.computed(function () {
returnself.firstName() + " " + self.lastName();
});
}
ko.applyBindings(newAppViewModel());
</script>
Output
data:image/s3,"s3://crabby-images/4ebc6/4ebc64484ba98c35185d37b95d8119c76c490a35" alt="How to Define Computed Values How to Define Computed Values"
CASE 4 : How to add UPPER-CASE behavior ?
- Need to add a
capitalizeLastName
function to the viewmodel - To Read or Write an observable's value, you have to call it as a function
View's Code
<!-- This is a View - HTML markup that defines the appearance of your UI -->
<p>First name: <strong data-bind="text: firstName"></strong></p>
<p>Last name: <strong data-bind="text: lastName"></strong></p>
<p>First name:<input data-bind="value: firstName" /></p>
<p>Last name:<input data-bind="value: lastName" /></p>
<p>Full name: <strong data-bind="text: fullName"></strong></p>
<button data-bind="click: capitalizeLastName"> Go CAPS </button>
Javascript Code
<script type="text/javascript">
functionAppViewModel() {
varself = this;
self.firstName = ko.observable();
self.lastName = ko.observable();
self.fullName = ko.computed(function () {
returnself.firstName() + " " + self.lastName();
});
self.capitalizeLastName = function () {
varcurrentVal = self.lastName();
self.lastName(currentVal.toUpperCase());
};
}
ko.applyBindings(newAppViewModel());
</script>
Output
Small discussion about Knockout on stackoverflow, Which I have involved
Conclusion
- This is a very basic example, but it illustrates some of the key points of Knockout
- You've got a clean, object-oriented representation of your UI's data and behaviors (your
viewmodel
) - Separately, you've got a declarative representation of how it should be displayed visibly (your view)
- You can implement arbitrarily sophisticated behaviors just by updating the
viewmodel
object - You don't have to worry about which DOM elements need to be changed, added or removed,
- The framework can take care of synchronizing things for you
I hope this helps you. Comments and feedback greatly appreciated.
You Might Also Like