Nov
1
Written by:
Michael Washington
11/1/2016 3:58 PM
Note: This tutorial is part of a series of articles that create a complete Angular 2 application using OData 4 and ASP.NET 4:
- Hello World! in Angular 2 using Visual Studio 2015 and ASP.NET 4 (this article)
- Implement ASP.NET 4 MVC Application Security in Angular 2 Using OData 4
- Tutorial: Creating An Angular 2 CRUD Application Using MVC 5 and OData 4
- Tutorial: An End-To-End Angular 2 Application Using MVC 5 and OData 4
You can create applications in Angular 2 using Visual Studio 2015 running ASP.NET 4.
(Note: the following directions mostly follow the directions on the Angular site)
Step 1 – Visual Studio 2015 Update 3 (or higher)
data:image/s3,"s3://crabby-images/427f0/427f007ac5ffce89a3dea263bba225f71576fd78" alt="image image"
Ensure you have Visual Studio 2015 Update 3 (or higher).
You can download the free Visual Studio 2015 Community Edition from:
https://www.visualstudio.com/downloads/download-visual-studio-vs
Step 2 – Install TypeScript 2.0 (or higher)
data:image/s3,"s3://crabby-images/b962a/b962a9c2b4d513cfbe74961db52ba4007773ee72" alt="image image"
Install TypeScript 2.0 (or higher) for Visual Studio 2015 from here: https://www.typescriptlang.org/#download-links.
Step 3 – Install Node.Js and NPM
data:image/s3,"s3://crabby-images/18320/18320f82f84f32d1b9f225ea9cf8e9505a1cf2fd" alt="image image"
Install Node.js and the Node Package Manager (NPM) from here:
https://nodejs.org/en/download/
Step 4 – Configure Visual Studio
To avoid problems, we need to configure Visual Studio to use the global external web tools (such as the Node Package Manager).
data:image/s3,"s3://crabby-images/9ca2a/9ca2a2aeba3ccf5d7777b209e4186ac59acb13a8" alt="image image"
Open Visual Studio.
data:image/s3,"s3://crabby-images/f2d1f/f2d1f093ad141ccea7483691cda410d78f7945ef" alt="image image"
Open Options.
data:image/s3,"s3://crabby-images/42e28/42e286acd782dc1ca4bbc35e3285cbd90ada06d0" alt="image image"
In the Options dialog, select External Web Tools.
Move the $(PATH) entry above any $(DevEnvDir) or $(VSINSTALLDIR) entries.
Click OK.
Restart Visual Studio (for this change to take effect).
Step 5 – Create The Project
data:image/s3,"s3://crabby-images/f525a/f525afd801d0807577550d273d378d80ffe2cb85" alt="image image"
In Visual Studio, select File, then New, then Project.
data:image/s3,"s3://crabby-images/62940/629408da52dfc770b4c2ee2d538d7641f1355613" alt="image image"
Create a ASP.NET Web Application (.NET Framework) project.
data:image/s3,"s3://crabby-images/84401/8440100d13160fd29876069be167294a4605a70e" alt="image image"
Create a MVC project.
data:image/s3,"s3://crabby-images/c6a28/c6a28d5a199149d24dcf3847ba34124415ce7f89" alt="image image"
After the project is created and opens, in the Solution Explorer, right-click on the Solution node and select Rebuild Solution.
Step 6 – Download the Angular QuickStart files
data:image/s3,"s3://crabby-images/b7eb5/b7eb580d3a4d807de327c45149a7663587d00abd" alt="image image"
Download the Angular Quickstart files from:
https://github.com/angular/quickstart/archive/2.4.0.zip (note they are constantly updating this project so get the 2.4.0 release that is known to work with this tutorial)
Step 7 – Add the Angular QuickStart Files
data:image/s3,"s3://crabby-images/333d4/333d4b9604d7471d803f7a761e866e55f8260937" alt="image image"
Unzip the Angular Quickstart files into a directory.
Select all the files, and copy all the files…
data:image/s3,"s3://crabby-images/e5337/e5337d4c5a6dba2ece5cb3cde7b01b3dcd28595b" alt="image image"
… and paste them into the directory that the Visual Studio project is in.
Do this using the Windows file manager not inside Visual Studio.
Step 8 – Add the Angular QuickStart Files to the Project
data:image/s3,"s3://crabby-images/652f5/652f53cf143e91a6f1db138ba555fc7d48f4044c" alt="image image"
In Visual Studio, in the Solution Explorer, click on the Project node (not the Solution node).
Click the Show All Files button.
data:image/s3,"s3://crabby-images/17fe7/17fe7b65c38b4ab058dfb5c5be3b3f52ef23dab5" alt="image image"
Right-click on the following folders and files and select Include In Project:
- app folder (answer No if asked to search for TypeScript Typings)
- styles.css
- package.json
- tsconfig.json
data:image/s3,"s3://crabby-images/6375d/6375dee7d007c39c1bc7ba6565c4e4843d662986" alt="image image"
Click the Show All Files button again to hide the remaining files.
data:image/s3,"s3://crabby-images/24889/24889fae17a5a246e663e2023f91bda27e3eadfc" alt="image image"
We now need to bring in the other Angular files using the Node Package Manager (NPM).
Right-click on the package.json file and select Restore Packages.
(If you do not see this option, try closing and re-opening Visual Studio, or if you have the Visual Studio Node.js tools installed, uninstall them. You can also use the node command line)
data:image/s3,"s3://crabby-images/0b840/0b8404b1bc6ef49e2de1f18e2a6744802718bf9a" alt="image image"
Wait until the packages have been installed (it may take a few minutes).
data:image/s3,"s3://crabby-images/1523b/1523bba51ab372b4ead7b51d4fc6dfcd427b36b3" alt="image image"
Rebuild the Solution.
Step 9 – Create the Hello World! Application
data:image/s3,"s3://crabby-images/9ab93/9ab939a3cba1dc683d3ab6e21130b6f448a6eada" alt="image image"
Open the file at: Views/Shared/_Layout.cshtml and add the following code to the Head section:
<!-- Angular2 Code -->
<base href="~/">
<link rel="stylesheet" href="~/styles.css">
<!-- Polyfill(s) for older browsers -->
<script src="https://cdn.polyfill.io/v2/polyfill.min.js?features=Intl.~locale.en"></script>
<script src="~/node_modules/core-js/client/shim.min.js"></script>
<script src="~/node_modules/zone.js/dist/zone.js"></script>
<script src="~/node_modules/reflect-metadata/Reflect.js"></script>
<script src="~/node_modules/systemjs/dist/system.src.js"></script>
<script src="~/systemjs.config.js"></script>
<script>
System.import('app').catch(function(err){ console.error(err); });
</script>
<!-- Angular2 Code -->
data:image/s3,"s3://crabby-images/f6a5b/f6a5b26a9a628d48dc003adb24752ddde0dc3032" alt="image image"
Open the file at: Views/Home/Index.cshtml and replace all the code with the following code:
@{
ViewBag.Title = "Home Page";
}
<div class="jumbotron">
<h1>Angular 2 QuickStart</h1>
</div>
<div class="row">
<div class="col-md-4">
<!-- Angular2 Code -->
<my-app>Loading...</my-app>
<!-- Angular2 Code -->
</div>
</div>
data:image/s3,"s3://crabby-images/a2706/a270690d263f2fd6895be3bb93517e1d3d5704f5" alt="image image"
Open the file at: app/app.component.ts and replace all the code with the following code:
import { Component } from '@angular/core';
@Component({
selector: 'my-app',
template: `
<h1>Hello World!</h1>
<h2>{{DynamicValue}}</h2>
`
})
export class AppComponent {
DynamicValue: string =
"Running on IIS with ASP.NET 4.5 in Visual Studio 2015";
}
data:image/s3,"s3://crabby-images/2cc45/2cc45ae2d31837d53d0cbe863dfc90f17403eee8" alt="image image"
Run the project.
data:image/s3,"s3://crabby-images/f13bb/f13bb946b768c632c7d440bd21e0bfe8b5e78df4" alt="image image"
The application will display.
Links (LightSwitch Help Website)
Implement ASP.NET 4 MVC Application Security in Angular 2 Using OData 4
Links
Angular 2 Visual Studio 2015 QuickStart
Download Visual Studio 2015 Community Edition (Free)
Resources to Learn Angular 2
Angular 2: Getting Started (Pluralsight – Paid)
Introduction to Angular 2.0 (Microsoft Virtual Academy – Free)
Download
The project is available at http://lightswitchhelpwebsite.com/Downloads.aspx
You must have Visual Studio 2015 Update 3 (or higher) and TypeScript 2.0 (or higher) installed to run the code.
3 comment(s) so far...
(econnreset) If when using NodeJs and you get a "econnreset" error, you can do this:
npm config set registry http://registry.npmjs.org/
See: http://stackoverflow.com/questions/18419144/npm-not-working-read-econnreset
By Michael Washington on
11/29/2016 1:01 PM
|
Very nice tutorial,
possible to do one for setting up ASP.NET 4 and Angular 4? please also include publishing the project to IIS.
thanks!
By mrekoj on
6/9/2017 11:11 AM
|
@mrekoj - See this link for Angular 4: http://lightswitchhelpwebsite.com/Blog/tabid/61/EntryId/4306/Upgrading-JavaScriptServices-and-PrimeNG-From-Angular-2-to-Angular-4.aspx - See this link for publishing: https://github.com/aspnet/JavaScriptServices/issues/337
By Michael Washington on
6/9/2017 11:13 AM
|