Aug
17
Written by:
Michael Washington
8/17/2013 10:08 PM
data:image/s3,"s3://crabby-images/f8011/f801186951c0be69875b1c715298db81254feec9" alt="image image"
Jesus Rodriguez wrote a great article titled Why Does Angular.js Rock?. It is an excellent work and really demonstrates the power of Angular. As I read through the article I realized that the functionality he demonstrates can of course be done in LightSwitch because LightSwitch contains a full featured JavaScript data binding framework to allow you to build SPA (Single Page Applications).
The thing that sets LightSwitch apart from other JavaScript data binding frameworks such as Angular, is that LightSwitch has advanced tooling in Visual Studio. For example, it has a data designer and a screen designer. It provides tight coupling for maximum efficiency when interacting with data (you can connect to any data source using WCF RIA Services).
What this means is that it is very easy to perform functionality in LightSwitch that can be challenging using other frameworks. Make no mistake, the end result is the same whether you use LightSwitch or another SPA framework (see: How Does A LightSwitch HTML Client Application Work?).
data:image/s3,"s3://crabby-images/d930d/d930d39ae2e8c51e04e6cd87cc0454a1c3bc8fe2" alt="image image"
I created a sample application that you can download that demonstrates the examples in this article.
Data Binding
data:image/s3,"s3://crabby-images/8979e/8979e494e0e1df523cc3e4fcc6e9c14c88be4ddb" alt="image image"
The first example covers data binding. The Angular example does not require very much coding. However, the LightSwitch example does not require any coding at all.
data:image/s3,"s3://crabby-images/bcb29/bcb290a4d6e6ddf6e5061cbf921a7213123083aa" alt="image image"
With LightSwitch we simply add a Property to the the View Model (the left hand side of the screen) and drag the Property to the screen twice, to create two controls bound to the same property. In one control we set as a text box, in the other we set as a label.
data:image/s3,"s3://crabby-images/5515f/5515ff2cb1e56486f0e8cb8f23a39c6bf5f7c9ad" alt="image image"
When we run the application, enter text in the text box, and click or tab away, the value is shown in the label.
Note: In Jesus’s example he raises the data binding on each keystroke. While this is possible with LightSwitch it would require code. The vast majority of the time you would not want the data binding raised on each keystroke. You would want it raised after the user has completed entering the value they desire. This is why I chose to show the most common situation.
Scope
data:image/s3,"s3://crabby-images/88db3/88db37a7605ce7212a94496d2cd7dba00dec8902" alt="image image"
A Scope in Angular is like a screen in LightSwitch.
In LightSwitch you can simply bind a label control to a Property in the View Model…
data:image/s3,"s3://crabby-images/7efe4/7efe4435139359dffe8bbdd1673c418cdca40c74" alt="image image"
… and select Write Code and use the following code to set the value:
myapp.bShowMessage.created = function (screen) {
screen.Message = "Hello, World";
};
data:image/s3,"s3://crabby-images/ac41c/ac41c80714106ae8ff6b41e607b6417a1a2c8045" alt="image image"
When we run the application the value shows.
Functions
data:image/s3,"s3://crabby-images/f715f/f715f377835e788239d14764c2c7dc27584471a9" alt="image image"
In Angular you can define and call Functions. In LightSwitch, Functions are called Methods.
data:image/s3,"s3://crabby-images/3a53e/3a53eefe465dcd61d6392debf6a0a0053e58ea58" alt="image image"
You use Add Data Item to create a Method.
data:image/s3,"s3://crabby-images/ce72e/ce72e64196658014df10e9572c173eb8c294bfbe" alt="image image"
It will show in the View Model (shown in blue), and you can drag and drop it on the Screen designer to bind it to controls if needed.
data:image/s3,"s3://crabby-images/c9dbc/c9dbc30ed9b5ec142b5ba45e98692c366c6000d6" alt="image image"
To write code to define the Method, we right-click on it in the View Model and select Edit Execute Code.
We use the following code:
myapp.cWhatIsYourName.greet_execute = function (screen) {
screen.Greeting = "Hello, " + screen.Name;
};
data:image/s3,"s3://crabby-images/2b6fe/2b6fe7dbda773b72e261ae2025565528078d91e1" alt="image image"
When we run the application and enter a value, and click the button, the Method is executed and the result shows.
Directives
data:image/s3,"s3://crabby-images/ae63e/ae63e063ce97c62e7b8c0a0f1fa9159f19c163e6" alt="image image"
Angular has Directives. LightSwitch uses Properties, Methods (Commands) and Collections (including Queries).
However, any functionality you can do in Angular, you can do in LightSwitch.
In Jesus’s example, he displays a DIV when the button is clicked.
data:image/s3,"s3://crabby-images/884c7/884c77c61212eb51587df1584845bc16c14d8fd6" alt="image image"
In LightSwitch when we lay out the screen, notice the boolShow property is not bound to any control on the screen. It will only be used programmatically.
data:image/s3,"s3://crabby-images/9d804/9d804a1ef7bb5f5c6f9e90903d32ca0dcbaebec3" alt="image image"
To make a DIV we use the Custom Control control. We set it by selecting Edit Render Code in its Properties.
We use the following code:
myapp.dShowMessage.ctrlShow_render = function (element, contentItem) {
// Sets the content of the Div
element.innerText = "I am only visible when show is true. ";
};
data:image/s3,"s3://crabby-images/2ce30/2ce30ad856416587051b837e38e511366aca45eb" alt="image image"
We set the code for the Method raised by the button using the following:
myapp.dShowMessage.btnShow_execute = function (screen) {
// Change the value of boolShow to the opposite
screen.boolShow = !screen.boolShow;
};
Finally we create a data binding on the boolShow property that will be raised when anything changes its value:
myapp.dShowMessage.created = function (screen) {
// Create a Listener for changes in boolShow
screen.addChangeListener("boolShow", function (e) {
// Show or hide the Div
screen.findContentItem("ctrlShow").isVisible = screen.boolShow;
});
};
data:image/s3,"s3://crabby-images/f376a/f376a15ed490371d7dc6a9bc79d104e94a147a66" alt="image image"
When we run the application, we can click the button to display the DIV.
Note: You can read more about data binding in LightSwitch at the following link: Writing JavaScript / The Binding Pattern.
Data
data:image/s3,"s3://crabby-images/c3bc2/c3bc252290d60602ba106bfc9ad4453211fcb0df" alt="image image"
Now we get to the examples where LightSwitch really shines, working with data.
In Jesus’s example, he creates an array of data and displays it.
data:image/s3,"s3://crabby-images/02a2e/02a2e7a99197b0203a1f0ca7849d6fa78deeb315" alt="image image"
In LightSwitch we can add a table.
data:image/s3,"s3://crabby-images/09518/095186453b9866ec54999189400788a182ec1d53" alt="image image"
The table is our Model. It can be a database table or, if using WCF RIA Services, a web service, the server hard drive, or even an Excel file.
data:image/s3,"s3://crabby-images/d25c6/d25c67739c1006d82941f6b62f970f6b544100cf" alt="image image"
We add the entity (table) to the screen and use a Custom Control in its layout.
We then select the Custom Control and select Edit Render Code and use the following code:
myapp.eShowPeople.RowTemplate_render = function (element, contentItem) {
var Person = contentItem.value;
var itemTemplate = $("<div></div>");
var FinalName = $("<h2>").text(Person.Name + ' from ' + Person.Country);
FinalName.appendTo($(itemTemplate));
itemTemplate.appendTo($(element));
};
We can create records using the following code:
myapp.eShowPeople.created = function (screen) {
var PersonOne = new myapp.Person();
PersonOne.Name = "Jesus";
PersonOne.Country = "Spain";
var PersonTwo = new myapp.Person();
PersonTwo.Name = "Dave";
PersonTwo.Country = "Canada";
var PersonThree = new myapp.Person();
PersonThree.Name = "Wesley";
PersonThree.Country = "USA";
var PersonFour = new myapp.Person();
PersonFour.Name = "Krzysztof";
PersonFour.Country = "Poland";
};
data:image/s3,"s3://crabby-images/4b2c5/4b2c57f545a46eb1ae56d515b7b7930242a7212f" alt="image image"
When we run the application the records show.
data:image/s3,"s3://crabby-images/f46d8/f46d83ffe15410a499953ce07e7191660b7b6998" alt="image image"
When we try to leave the page, we are prompted to save the records because LightSwitch automatically implements a data workspace and change tracking.
Clicking save, will save the records to the database, no extra code is needed.
Filters
data:image/s3,"s3://crabby-images/ec89b/ec89b777f2f2558c4e8ede90782122b54ed22703" alt="image image"
Jesus demonstrates using filters with Angular.
In the LightSwitch example we will perform a server side search that can even handle a database with millions of records.
data:image/s3,"s3://crabby-images/1c91a/1c91a0700f42496dacd6d64bd0d9052c1b548001" alt="image image"
In LightSwitch, we simply click the Edit Query link next to the collection we want to filter.
data:image/s3,"s3://crabby-images/ef89a/ef89ac7652ce0d925286570b93b93f2258b9e73c" alt="image image"
We design a query that takes a search Parameter.
data:image/s3,"s3://crabby-images/a5ea4/a5ea43d1617dbf9bd6506717d22ecd1a7a9720da" alt="image image"
We create a property connected to the Parameter and connect that property to a textbox that the user will be able to fill to perform the search.
data:image/s3,"s3://crabby-images/b6fcc/b6fcc410d7ffe7db1dd025fcc5f56123c854fdc7" alt="image image"
Without the need to write a single line of code we have a server side search.
Download Code
The LightSwitch project is available at http://lightswitchhelpwebsite.com/Downloads.aspx
(you must have Visual Studio 2013 (or higher) installed to run the code)
3 comment(s) so far...
This is excellent. What a great way to draw in people who otherwise would not become familiar with what LightSwitch can do.
By Richard Waddell on
8/18/2013 6:22 AM
|
@Richard Waddell - I think it also shows LightSwitch developers what LightSwitch can do :)
In creating the code for the article I found myself doing things I never did before in LightSwitch such as "screen.findContentItem("ctrlShow").isVisible = screen.boolShow;"
By Michael Washington on
8/18/2013 6:30 AM
|
Excellent Michael, thanks
By Benoit Sarton on
11/22/2014 7:19 AM
|