AngularJs + Web API 页面开发(一)
AngularJS这个JS框架是个神马东东我也不太清楚,我也是初学者~~
AngularJS适用于single page App,单页面程序都是局部刷新的,这一点和Ajax有第一的区别,因为使用Ajax的一个致命点是 会使浏览器的后退
按钮失效。
在AngularJs中有几个核心的知识点:scope(块),controller(控制器),service(服务),directive(指令)、Module(模块)。
请看下面我画的草图。

接下来我将结合一个简单的例子给大家讲讲如何使用AngularJS+Web API+简单Linq to sql 技术实现 增删改分页。
数据库: SQL 2005 开发工具 VS2012
浏览器用谷歌浏览器查看效果
首先是,这里三张表,人员联系User,地址表AddressInfo,城市表City(数据自己添加)。
第一步,或取得所有人员联系信息。
JS代码如下:
<script type="text/javascript">
var app = angular.module('myApp', []); app.run(function ($rootScope, $http) { var getInfo = function () {
var config = { params: { Flag: "Pre", pageIndex: } };
$rootScope.pageIndex = "";
$http.get('/api/values', config).
success(function (teamList) {
$rootScope.teamList = teamList;
}).
error(function (teamList) {
$rootScope.teamList = teamList || "Request failed";
});
/*得到所有城市信息*/
$http.get('/api/city').
success(function (cityList) {
$rootScope.cityList = cityList;;
}).
error(function (cityList) {
$rootScope.cityList = cityList || "Request failed";
});
}; getInfo(); });
</script>
html代码如下
<div ng-controller="OperateController">
<div>
<table border="" cellpadding="" cellspacing="" width="80%" style="background-color: black;">
<thead>
<tr style="background-color: white;">
<th style="width: 10%; background-color: white;">UserID</th>
<th style="width: 15%; background-color: white;">Name</th>
<th style="width: 15%; background-color: white;">Age</th>
<th style="width: 20%; background-color: white;">Address_FK</th>
<th style="width: 15%; background-color: white;">Operate</th> </tr>
</thead>
<tbody>
<tr ng-repeat='team in teamList ' ng-click="GetOne(team.UserID)">
<td style="background-color: white; height:20px;">
<input style="width: 98%" ng-model="team.UserID" /></td>
<td style="background-color: white;">
<input style="width: 98%" ng-model="team.Name" /> </td>
<td style="background-color: white;">
<input style="width: 98%" ng-model="team.Age" /></td>
<td style="background-color: white; text-align:center;"> </td> <td style="text-align: center; background-color: white;"><a ng-click="Del(team.UserID)" style="cursor: pointer;"> Delete</a></td>
</tr>
</tbody>
</table>
</div>
</div>
Html代码
因为是Web API,所以API的代码如下
我这里默认使用Values的Controller,得到数据代码如下
public class ValuesController : ApiController
{
TrainDataContext dbContext = new TrainDataContext(); // GET api/values
public IEnumerable<User> Get()
{
var UserInfo = dbContext.User.Skip().Take().ToList();
//JavaScriptSerializer josn = new JavaScriptSerializer();
//var infoStr = josn.Serialize(UserInfo);
return UserInfo;
} // GET api/values/5
public IEnumerable<User> Get(string Flag, double pageIndex)
{
int PageSize = ; double PageCount = Math.Ceiling(dbContext.User.Count() / Convert.ToDouble(PageSize));
if (Flag == "Pre")
{
if (pageIndex <= )
{
pageIndex = ;
}
else
{ pageIndex = pageIndex - ;
}
}
else if (Flag == "Next")
{ if (pageIndex >= PageCount)
{
pageIndex = PageCount;
}
else
{
pageIndex = pageIndex + ;
}
} int SkipValue =Convert.ToInt32( PageSize * (pageIndex - ));
var UserInfo = dbContext.User.Skip(SkipValue).Take(PageSize).ToList();
return UserInfo; }
C#
这里使用的Linq to sql,如果对linq to sql 一点都不了解的人可以查看我的http://www.cnblogs.com/xianrongbin/p/3266149.html这篇博文。
以上代码看不懂没关系,我慢慢讲来。
在Angular的scope是,类似与C#代码中的model,里面包含了该对象的属性及方法。
当然,我们不要忘记,每一个angular应用有且只有一个rootscope,但可以拥有多个child scope,所有的scope都是继承 了rootscope。
这里有一个概念,叫做原型继承:如果没有找到对应的属性,它将会一直向上搜索parent scope,直到到达root scope。例子如下:
<script type="text/javascript">
var app = angular.module('myApp', []);
app.controller("TestController", function ($scope) {
$scope.leader='xrb',
$scope.employee = {
dept: '项目部',
reprts: [{ name: 'name1' }, { name: 'name2' }]
};
});
</script> <div ng-controller="TestController">
{{employee.dept}}
<ul>
<li ng-repeat="employee in employee.reprts">
name:{{employee.name}}<br />
leader:{{leader}}
</li>
</ul>
</div>
原型继承
这里,leader属性在employee里是没有的,因此,JS会在同级没有时,顺着往上一级一级探索,直到达到rootscope。 因此,leader返回的值是 xrb.
其实,知道了这个概率, 我也不知道有什么用~~
Angular有一个特别的机制,叫做双向绑定机制。其实就是数据源一变,展现形式立刻改变。最简单的代码如下
<input type="text" ng-model="testname" /><br />
showtestname:{{testname}}
showtestname后面的值会根据Input里的值的变化而变化。
这里引入$apply,$digest,$watch三个关键词
AngularJs + Web API 页面开发(一)的更多相关文章
- [Angularjs]asp.net mvc+angularjs+web api单页应用
写在前面 最近的工作一直在弄一些h5的单页应用,然后嵌入到app的webview中.之前一直在用angularjs+html+ashx的一套东西.实在是玩腻了.然后就尝试通过asp.net mvc的方 ...
- 用ASP.NET Web API技术开发HTTP接口
开发工具 Visual Studio 2013 SQL Server 2008 R2 准备工作 启动Visual Studio 2013,新建一个ASP.NET Web应用程序,命名为SimpleAP ...
- 用ASP.NET Web API技术开发HTTP接口(一)
开发工具 Visual Studio 2013 SQL Server 2008 R2 准备工作 启动Visual Studio 2013,新建一个ASP.NET Web应用程序,命名为SimpleAP ...
- 用ASP.NET Web API技术开发HTTP接口(二)
在第一部分,我们创建了一个基本的ASP.NET Web API项目,新建成功了数据表,然后添加了一些测试数据,最后创建了API控制器,用json格式把数据表里面的内容成功输出到浏览器上.接下来我们将继 ...
- [Angularjs]asp.net mvc+angularjs+web api单页应用之CRUD操作
写在前面 前篇文章整理了angularjs学习目录,有园子里的朋友问我要这方面的demo,周末也没什么事,就在之前的单页应用的demo上面添加了增删改查的操作.代码比较简单,这里只列举比较重要的代码片 ...
- 基于SpringBoot的Web API快速开发基础框架
其实还是很因为懒,才会有这个案例项目的产生,每次开启一个终端的小服务都要整理一次框架,造成重复的.不必要的.缺乏创造性的劳动,SO,本着可以用.用着简单的原则上传代码到Github,希望有需要的朋友直 ...
- 淘金客II项目问题日志(AngularJs+BootStrap+Api接口开发)
问题二: 组件,如果是modal框,那么show的时候,是不会load它的(因为load有时候是需要传送数据的),需要别的组件去主动load它.那么问题来了:哪些框直接show,哪些框不仅需要show ...
- [译]ABP框架使用AngularJs,ASP.NET MVC,Web API和EntityFramework构建N层架构的SPA应用程序
本文转自:http://www.skcode.cn/archives/281 本文演示ABP框架如何使用AngularJs,ASP.NET MVC,Web API 和EntityFramework构建 ...
- asp.net web api 测试帮助页面建立并测试
asp.net web api 测试帮助页面建立并测试 现在使用WEB API来开发,越来越流行. 在开发过程中的测试调试,可以使用Fiddler等工具来帮助测试外,还有: 在asp.net 中有种方 ...
随机推荐
- 在<s:iterator>标签里给动态表格添加序号
在<s:iterator>标签里给动态表格添加序号,需要用到<s:iterator>标签里的Status属性里的count eg:<s:iterator value=&q ...
- 《疯狂Java讲义》(三) ---- JDK&JRE&JVM&CLASSPATH
JDK: Java SE Development Kit, Java标准版开发包.包括Java编译器,JRE,以及常用的Java类库等. JRE: Java Runtime Environment,运 ...
- 《Unix/Linux网络日志分析与流量监控》获2015年度最受读者喜爱的IT图书奖
<Unix/Linux网络日志分析与流量监控>获2015年度最受读者喜爱的IT图书奖.刊登在<中华读书报>( 2015年01月28日 19 版) 我的2015年新作刊登在< ...
- Spark Streaming源码解读之No Receivers彻底思考
本期内容 : Direct Acess Kafka Spark Streaming接收数据现在支持的两种方式: 01. Receiver的方式来接收数据,及输入数据的控制 02. No Receive ...
- JAVASCRIPT 中 FOR (VAR I IN DATA) 循环数组项
今天在改代码的时候发现有很多代码的循环是用 for(var i in data)写的,我通常都是用for(var i=0;i<data.length;i++) 就查看了一下,原来这两个是有区别的 ...
- IT界里的生日
MS-DOS 1981年7月27日 windows 3.0 1990年5月22日 windows 3.11 1992年3月18日 Windows 95 1995年8月24日 Windows ...
- Verilog $random用法
“$random函数调用时返回一个32位的随机数,它是一个带符号的整形数...”,并给出了一个例子: _________________________________________________ ...
- C语言隐形密码输入
今天费了老大的劲,终于做出来了!虽然简单,但也是自己的心血,分享一下! #include<stdio.h> #include<conio.h> int main(){ char ...
- Processing与Java混编初探
Processing其实是由Java开发出的轻量级JAVA开发语言,主要用于做原型,有setup.draw两个主接口和几个消息相应接口 Processing和Java混编很简单...在Java中引入外 ...
- JS的封装
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAl8AAADiCAYAAABwdKKfAAAYLGlDQ1BJQ0MgUHJvZmlsZQAAWIWVeQ