Saturday, April 16, 2016
Monday, May 19, 2014
Starting a Typescript Single Page Application using Angular.js
The first step is to create the project.

Select a typescript project.

We need to install four packages.
- Angular.js
- JQuery.js
- Typescript definition for Angular.js
- Typescript definition for JQuery.js
- Install-Package angularjs
- Install-Package jQuery
- Install-Package angularjs.TypeScript.DefinitelyTyped
It is possible to specify a specific version of the package on the command line. Without the version specification, Nuget will install the most recent version. Installing the TypeScript definition for angularjs will also install the typescript definition for jQuery.
The next step requires changing the index.html file. Below is the default file.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <title>TypeScript HTML App</title> <link rel="stylesheet" href="app.css" type="text/css" /> <script src="app.js"></script> </head> <body> <h1>TypeScript HTML App</h1> <div id="content"></div> </body> </html>
I am not sure why the default file has a blank line between the DOCTYPE declaration and the HTML declaration. Modify the html element to add the ng-app attribute. Intellisence helps add the definition. Add a value of "DemoApp" for the attribute name. This is the name of the single page application. Angular.js allows multiple applications.
<html lang="en" ng-app="DemoApp">
In the Solution Explorer, open the Scripts folder.
We need to include either the angular.js file or the angular.min.js file as a script. Debugging with the minified version of the JavaScript file is difficult. Grab the angular.js file; drag it under the link element in the index.html file; then drop the file. Visual Studio will insert the link.
<!DOCTYPE html> <html lang="en" ng-app="DemoApp"> <head> <meta charset="utf-8" /> <title>TypeScript HTML App</title> <link rel="stylesheet" href="app.css" type="text/css" /> <script src="Scripts/angular.js"></script> <script src="app.js"></script> </head> <body> <h1>TypeScript HTML App</h1> <div id="content"></div> </body> </html>
Next, modify the app.ts file to initialize Angular.js. We named the application "DemoApp" above when we modified the html element. We need to add a line to the app.ts file to initialize that module. Add the following line to the app.ts file.
var demoAppModule = angular.module('DemoApp');
That declares a variable, demoAppModule, to hold the Angular.js module. The module method takes the name of the application.
Now we have a minimal TypeScript application using Angular.js.
Wednesday, December 18, 2013
Dependency Injection Automatic Factories
Abc
, then Unity also knows how to resolve Func<Abc>
.This allows using lazy evaluation of injected properties. The code below shows how to use an automatic factory.
private Abc abc = null;
public Func FuncAbc { get; set; }
protected Abc Abc
{
get
{
if (abc == null && FuncAbc != null) abc = FuncAbc();
return abc;
}
}
When the code accesses
Abc
the getter checks the underlying private field abc to see if it is null. If it is null, then the code checks to make sure the factory FuncAbc
is not null. If the factory is not null then it creates a new instance by calling the factory FuncAbc
.
Wednesday, May 8, 2013
Sunday, February 24, 2013
I submitted three talks to Philly.Net Code Camp http://phillydotnet.org/
- Improving the Quality of Code
- Refactoring To Allow Unit Testing
- Calling an Unsigned Assembly from a Signed Assembly
Sunday, January 27, 2013
Wednesday, September 8, 2010
Joys of Removable Version of MediaWiki and SVN
I have a variety of flash memory devices. I picked a two-Gigabyte device to put a copy of MediaWiki and SVN. I now can access my personal wiki everywhere I go.
Wiki on a Stick
CH Software created MoWeS, an entire WAMP (Windows, Apache, MySQL, and PHP) stack that run without the need to install anything. MoWeS allow selecting which version of Apache, PHP, and MySQL. MediaWiki is an additional option along with other great options like ImageMagick, TYPO3, and SugarCRM. MediaWiki provides an installation page. The instructions are not quite right. Download the packages from CH Software then run moves.exe. That unpacks the files.
SVN on a Stick
I use TortoiseSVN. This integrates SVN with Windows Explorer. TortoiseSVN has the option to create a repository by just right clicking on a directory. This makes it simple to create an SVN repository on a memory stick.
Performance
Performance of SVN is a slow on my two-Gigabyte flash drive. The advantage of taking both my personal wiki and an SVN repository with me anywhere outweighs the performance issues.