這幾天接觸到了AngularJs的美麗,讓饅頭有點躍躍欲試使用AngularJs來做一個SPA(單頁式網站),沒想到使用AngularJs來製作SPA網站這麼簡單!相信你看完這次的分享,你也想動手試一試!
在Visual Studio中有一個專案範本Single Page Application,不過這個專案範本預設是使用knockout.js來建立的,所以饅頭這邊是使用Web API的專案來開始製作

選擇了Web API專案後,這個專案中本身沒有AngularJs,所以我們要透過Nuget來取得AngularJs(當然,也可以從官方網站下載),在右上角打上AngularJs後就可以找到!我們可以安裝第一個nuget package,這個package預設會幫我們安裝整個AngularJs的Javascript Library

安裝AgnularJs完成後,我們要把Javascript放置到頁面中,當然我們使用MVC中提供的Bundle的功能
1 |
bundles.Add( new ScriptBundle( "~/bundles/AgnularJs" ).Include( |
2 |
"~/Scripts/angular.js" , |
3 |
"~/Scripts/angular*" )); |
接下來我們把整個(或相關檔案)AngularJs放置到頁面中吧!
這邊要注意一下,angular.js這個檔案要放在最上頭,否則您開啟瀏覽器的開發工具會看到滿江紅喔!
設定Bundle結束後,我們到View\Shared資料夾下的_Layout.cshtml在檔案的下方加入我們剛剛設定的Bundle package
1 |
@Scripts.Render("~/bundles/AgnularJs") |
以及在html的tag上加上ng-app的屬性,最後的Layout會長的樣這樣
04 |
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" /> |
05 |
< meta charset = "utf-8" /> |
06 |
< meta name = "viewport" content = "width=device-width" /> |
07 |
< title >@ViewBag.Title</ title > |
08 |
@Styles.Render("~/Content/css") |
09 |
@Scripts.Render("~/bundles/modernizr") |
11 |
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" /> |
13 |
< div class = "navbar navbar-inverse navbar-fixed-top" > |
14 |
< div class = "container" > |
15 |
< div class = "navbar-header" > |
16 |
< button type = "button" class = "navbar-toggle" data-toggle = "collapse" data-target = ".navbar-collapse" > |
17 |
< span class = "icon-bar" ></ span > |
18 |
< span class = "icon-bar" ></ span > |
19 |
< span class = "icon-bar" ></ span > |
21 |
@Html.ActionLink("應用程式名稱", "Index", "Home", new { area = "" }, new { @class = "navbar-brand" }) |
23 |
< div class = "navbar-collapse collapse" > |
24 |
< ul class = "nav navbar-nav" > |
25 |
< li >@Html.ActionLink("首頁", "Index", "Home", new { area = "" }, null)</ li > |
26 |
< li >@Html.ActionLink("API", "Index", "Help", new { area = "" }, null)</ li > |
31 |
< div class = "container body-content" > |
35 |
< p >© @DateTime.Now.Year - 我的 ASP.NET 應用程式</ p > |
39 |
@Scripts.Render("~/bundles/jquery") |
40 |
@Scripts.Render("~/bundles/AgnularJs") |
41 |
@Scripts.Render("~/bundles/bootstrap") |
43 |
@RenderSection("scripts", required: false) |
接下來,我們在Script的資料夾下新增一個Javascrpt檔案,饅頭這邊命名為angular.SPADemo.js
angular.SPADemo.js檔案中我們在這邊設定SPA的路由,饅頭這邊將第一個頁面放置在Home/SPApage1中
01 |
var SPA = angular.module( "SPA" , [ "ngRoute" ]); |
03 |
SPA.config([ '$routeProvider' , "$locationProvider" , |
04 |
function ($routeProvider, $locationProvider) { |
07 |
templateUrl: '/Home/SPApage1' , |
所以我們要在HomeController中新增一個ActionResult,名為SPApage1,並且回傳PartialView
2 |
public ActionResult SPApage1() |
4 |
return PartialView( "_SPApage1" ); |
並且將原先在Index頁面中的Html 搬移到該頁面中
01 |
@*新增一個div,並加上一個angularjs的Controller*@ |
02 |
< div ng-controller = "Main" > |
03 |
@*原先在Home/Index頁面中的Html*@ |
04 |
< div class = "jumbotron" > |
06 |
< p class = "lead" >ASP.NET is a free web framework for building great Web sites and Web applications using HTML, CSS, and JavaScript.</ p > |
07 |
< p >< a href = "http://asp.net" class = "btn btn-primary btn-lg" >Learn more »</ a ></ p > |
10 |
< div class = "col-md-4" > |
11 |
< h2 >Getting started</ h2 > |
13 |
ASP.NET Web API is a framework that makes it easy to build HTTP services that reach |
14 |
a broad range of clients, including browsers and mobile devices. ASP.NET Web API |
15 |
is an ideal platform for building RESTful applications on the .NET Framework. |
19 |
< div class = "col-md-4" > |
20 |
< h2 >Get more libraries</ h2 > |
21 |
< p >NuGet is a free Visual Studio extension that makes it easy to add, remove, and update libraries and tools in Visual Studio projects.</ p > |
24 |
< div class = "col-md-4" > |
26 |
< p >You can easily find a web hosting company that offers the right mix of features and price for your applications.</ p > |
我們將Index的頁面,改為
這樣我們就可以完成SPA了!(其他頁面依樣畫葫蘆就可以了)
其他的頁面可以繼續在路由新增,然後填上MVC中相對的位置,要記得把畫面的部分移除Layout喔!
PS. 若在Layout有設定Section的CSS或JS的Render,會無法載入喔!所以可以考慮在畫面一開始時,載入所有的JS跟CSS!但這樣的情況要請大家把JS模組化,並且盡可能的重用,否則光載入JS檔案就要等到天荒地老了...
https://code.msdn.microsoft.com/CRUD-Operations-in-MVC-5-d4ff2263/sourcecode?fileId=119238&pathId=457841343
- [译]ABP框架使用AngularJs,ASP.NET MVC,Web API和EntityFramework构建N层架构的SPA应用程序
本文转自:http://www.skcode.cn/archives/281 本文演示ABP框架如何使用AngularJs,ASP.NET MVC,Web API 和EntityFramework构建 ...
- AngularJS+ASP.NET MVC+SignalR实现消息推送
原文:AngularJS+ASP.NET MVC+SignalR实现消息推送 背景 OA管理系统中,员工提交申请单,消息实时通知到相关人员及时进行审批,审批之后将结果推送给用户. 技术选择 最开始发现 ...
- ABP 教程文档 1-1 手把手引进门之 AngularJs, ASP.NET MVC, Web API 和 EntityFramework(官方教程翻译版 版本3.2.5)含学习资料
本文是ABP官方文档翻译版,翻译基于 3.2.5 版本 转载请注明出处:http://www.cnblogs.com/yabu007/ 谢谢 官方文档分四部分 一. 教程文档 二.ABP 框架 三. ...
- [Angularjs]asp.net mvc+angularjs+web api单页应用
写在前面 最近的工作一直在弄一些h5的单页应用,然后嵌入到app的webview中.之前一直在用angularjs+html+ashx的一套东西.实在是玩腻了.然后就尝试通过asp.net mvc的方 ...
- 案例:1 Ionic Framework+AngularJS+ASP.NET MVC WebApi Jsonp 移动开发
落叶的庭院扫的一干二净之后,还要轻轻把树摇一下,抖落几片叶子,这才是Wabi Sabi的境界. 介绍:Ionic是移动框架,angularjs这就不用说了,ASP.Net MVC WebApi提供数据 ...
- [Angularjs]asp.net mvc+angularjs+web api单页应用之CRUD操作
写在前面 前篇文章整理了angularjs学习目录,有园子里的朋友问我要这方面的demo,周末也没什么事,就在之前的单页应用的demo上面添加了增删改查的操作.代码比较简单,这里只列举比较重要的代码片 ...
- ASP.NET MVC和EF集成AngularJS开发
参考资料: 如何在ASP.NET MVC和EF中使用AngularJS AngularJS+ASP.NET MVC+SignalR实现消息推送 [AngularJs + ASP.NET MVC]使用A ...
- 如何在 ASP.NET MVC 中集成 AngularJS(3)
今天来为大家介绍如何在 ASP.NET MVC 中集成 AngularJS 的最后一部分内容. 调试路由表 - HTML 缓存清除 就在我以为示例应用程序完成之后,我意识到,我必须提供两个版本的路由表 ...
- 如何在 ASP.NET MVC 中集成 AngularJS(2)
在如何在 ASP.NET MVC 中集成 AngularJS(1)中,我们介绍了 ASP.NET MVC 捆绑和压缩.应用程序版本自动刷新和工程构建等内容. 下面介绍如何在 ASP.NET MVC 中 ...
随机推荐
- cocos2d-x删除本地存储的文件UserDefault.xml方法——白费
许多其他的精彩分享:http://blog.csdn.net/u010229677 首先获取UserDefault的存储位置.然后remove就可以: remove( UserDefault::get ...
- Flynn初步:基于Docker的PaaS台
Flynn它是一个开源PaaS台,无论要部署的应用程序,你可以建立自己的主动性Docker容器集群的实现,能特性与组件设计大量參考了传统的PaaS平台Heroku.本文旨在从使用动机.基本对象.层次架 ...
- 第四章——SQLServer2008-2012资源及性能监控(1)
原文:第四章--SQLServer2008-2012资源及性能监控(1) 性能优化的第一步是发现问题,而发现问题通常又有两类:突发问题的侦测和常规问题的侦测,对于常规问题的侦测,通常需要有一个长效的性 ...
- Unity3d 导入图像尺寸失真解决方案
导入到unity3d内的图像被默认长宽变换为满足2^n关系. 例如以下图,我有张图片名称为984plus598表示我尺寸为984*598.拷贝到unity3d中后的大小为1024*512 方法一: 在 ...
- OpenCV2学习笔记(十四):基于OpenCV卡通图片处理
得知OpenCV有一段时间.除了研究的各种算法的内容.除了从备用,据导游书籍和资料,尝试结合链接的图像处理算法和日常生活,第一桌面上(随着摄像头)完成了一系列的视频流处理功能.开发平台Qt5.3.2+ ...
- 如何成功实施SDL提供的官方Android平台Demo
如何成功实施SDL提供的官方Android平台Demo 作者:雨水 日期:2014-4-30 编写说明:SDL的官方提供了一个Anroid的demo模板SDLActivity,无法直接执行,依照官方 ...
- [Visual Studio]透过Visual Studio 2012的选择性贴上将XML与JSON直接转成对应的类别
原文:[Visual Studio]透过Visual Studio 2012的选择性贴上将XML与JSON直接转成对应的类别 在开发专案时若碰到要串接服务或是他人的API,常常避免不了都要面对XML或 ...
- Linux服务器杀马(转)
开篇前言 Linux服务器一直给我们的印象是安全.稳定.可靠,性能卓越.由于一来Linux本身的安全机制,Linux上的病毒.木马较少,二则由于宣称Linux是最安全的操作系统,导致很多人对Linux ...
- 3.Chrome数据同步服务分析--server一片
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGVlcjE2OA==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...
- Kinect的学习笔记发展一Kinect引进和应用
Kinect开发学习笔记之(一)Kinect介绍和应用 zouxy09@qq.com http://blog.csdn.net/zouxy09 一.Kinect简单介绍 Kinectfor Xbox ...