MVC中使用AngularJS-01,基本

Angularjs是一个前端的Javascript MVC 库和框架,使前端得到更好的设计、维护和测试。它的核心特性有:MVC、双向数据绑定、指令和语义化标签、模块化工具、依赖注入、HTML模板,以及对常用工具的封装,例如$http、$cookies、$location等。本篇体验Angularjs在MVC中的基本使用。

通过NuGet,输入关键字Angularjs,安装"Angular JS Core"。

把angular.js引入页面:

<script src="~/Scripts/angular.js"></script>

ng-app指令

当Angular找到DOM中含有ng-app指令的元素时,才会进行初始化,并可以调用Angular的其它指令。

<html ng-app>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index</title>
     <script src="~/Scripts/angular.js"></script>
    <script src="~/Scripts/controller.js"></script>
    <link href="~/Content/bootstrap.css" rel="stylesheet" />
</head>
    <body>
    <div>
        <h3>Angular Hello world</h3>
        10+2={{10 + 2}}
    </div>
    </body>
</html>

使用"ng-model"指令进行数据双向绑定

<div>
        <input type="text" placeholder="输入Name" ng-model="name"/>
        {{name}}
    </div>

通过ng-model=”name”,把input和页面显示实现了双向绑定。

使用"ng-controller"指令,引入controller

在NuGet中输入关键字bootstrap,安装在MVC4下的bootstrap。

把bootstrap.cs引入视图页。

创建controller.js如下:

var MainController = function($scope) {
    var model = {
        Name: "My Books",
        Books: [
            { Title: ‘阳光踩烂的日子‘, isComplete: false },
            { Title: ‘那些年‘, isComplete: false },
            { Title: ‘时间是用来浪费的‘, isComplete: true }
        ]
    };

    $scope.readingList = model;
};

把controller.js引入视图页。Home/Index.cshtml如下:

<html ng-app>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index</title>
     <script src="~/Scripts/angular.js"></script>
    <script src="~/Scripts/controller.js"></script>
    <link href="~/Content/bootstrap.css" rel="stylesheet" />
</head>
<body>
    <div ng-controller="MainController">
        <div>
            <h2>{{readingList.Name}}的阅读清单</h2>
        </div>
        <br/>
        <div>
            <table class="table table-bordered table-condensed">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>是否完成阅读</th>
                        <th></th>
                    </tr>
                </thead>
                <tbody>
                    <tr ng-repeat="book in readingList.Books">
                        <td>{{book.Title}}</td>
                        <td>{{book.isComplete}}</td>
                        <td><input type="checkbox" ng-model="book.isComplete"/></td>
                    </tr>
                </tbody>
            </table>
        </div>
    </div>
</body>
</html>

运行:

当改变checkbox的勾选状态,isComplete值也在true和false之间切换,这点体现了Angularjs的双向绑定。

filter实现过滤功能

添加一个Input:

<div>
            <input type="text" ng-model="titleFilter" placeholder="输入关键字搜索"/>
        </div>

以"|"的形式,给每行添加过滤器:

<tr ng-repeat="book in readingList.Books | filter:titleFilter">

运行,输入关键字:

使用"ng-click"指令为DOM元素绑定事件

在controller.js中添加如下:

$scope.addBook = function() {
        model.Books.push({ Title: $scope.newTitle, isComplete: false });
        $scope.newTitle = ‘‘;
    };

在<div ng-controller="MainController">中添加如下:

<div>
                <input type="text" ng-model="newTitle" placeholder="输入新书名" required>
                <input type="button" ng-click="addBook()" value="添加" class="btn" />
            </div>

运行,添加数据:

选择使用Angularjs还是Knockout?

Angular比Knockout承担了更多的服务端工作,如果使用的框架是轻量级的,比如NodeJS,偏向使用Angular。
如果选择的框架是ASP.NET,偏向使用Knockout。

MVC中使用AngularJS-01,基本,布布扣,bubuko.com

时间: 2024-10-23 04:13:49

MVC中使用AngularJS-01,基本的相关文章

如何在 ASP.NET MVC 中集成 AngularJS(2)

在如何在 ASP.NET MVC 中集成 AngularJS(1)中,我们介绍了 ASP.NET MVC 捆绑和压缩.应用程序版本自动刷新和工程构建等内容. 下面介绍如何在 ASP.NET MVC 中集成 AngularJS 的第二部分. ASP.NET 捆绑和压缩 CSS 和 JavaScript 的捆绑与压缩功能是 ASP.NET MVC 最流行和有效的特性之一.捆绑和压缩降低了 HTTP 请求和有效载荷的大小,结果是可以更快和更好的执行 ASP.NET MVC 的网站.有许多可以减少 CS

如何在 ASP.NET MVC 中集成 AngularJS(3)

今天来为大家介绍如何在 ASP.NET MVC 中集成 AngularJS 的最后一部分内容. 调试路由表 - HTML 缓存清除 就在我以为示例应用程序完成之后,我意识到,我必须提供两个版本的路由表:一个运行在调试模式的应用程序下和一个运行在发布模式的应用程序下.在调试模式下,JavaScript 文件在未使用压缩功能的情况下会被下载.如果想要调试并在 JavaScript 控制器中设置断点,这是必须的.事实上,路由表的产生版本也出现了一些挑战,由于产生路由代码使用的是 JavaScript

如何在ASP.NET MVC和EF中使用AngularJS

(此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) AngularJS作为一个越来越流行的前端框架,在使用ASP.NET MVC和实体框架开发Web应用的时候,恰当的使用它可以让你的前端界面更易开发.今天推荐的文章就是介绍如何把AngularJS结合到ASP.NET MVC开发当中. 虽然之前开发的一套SaaS系统也是以ASP.NET MVC.实体框架为基础,前端辅以AngularJS.不过一直无暇很好总结一下这方面的经验分享给大家,刚好今天推荐的文

ASP.NET MVC中jQuery与angularjs混合应用传参并绑定数据

要求是这样子的,在一个列表页中,用户点击详细铵钮,带记录的主键值至另一页.在另一外页中,获取记录数据,然后显示此记录数据在网页上. 先用动图演示: 昨天有分享为ng-click传递参数 <angularjs为ng-click事件传递参数>http://www.cnblogs.com/insus/p/7017737.html 上面仅仅是在ng-click传入一个值,但是在ASP.NET MVC中,还需要把这个值传至另外一个视图中<ASP.NET MVC传递参数(model)>http

ASP.NET MVC中实现属性和属性值的组合,即笛卡尔乘积01, 在控制台实现

在电商产品模块中必经的一个环节是:当选择某一个产品类别,动态生成该类别下的所有属性和属性项,这些属性项有些是以DropDownList的形式存在,有些是以CheckBoxList的形式存在.接着,把CheckBoxList的选中项组合生成产品SKU项. 本系列将在ASP.NET MVC中实现以上功能.但本篇,先在控制台实现属性值的笛卡尔乘积. 关于属性的类: public class Prop { public int Id { get; set; } public string Name {

前端MVC学习总结——AngularJS验证、过滤器

前端MVC学习总结--AngularJS验证.过滤器 目录 一.验证 二.过滤器 2.1.内置过滤器 2.1.1.在模板中使用过滤器 2.1.2.在脚本中调用过滤函数 2.2.自定义过滤器 三.指令(directive) 3.1.支持AngularJS功能的指令 3.1.1.应用与模块(ng-app) 3.1.2.控制器(ng-Controller) 3.1.3.包含(ng-Include) 3.1.4.不绑定(ngNonBindable) 3.2.扩展表单元素的指令 3.2.1.ng-opti

使用Json.Net解决MVC中各种json操作

最近收集了几篇文章,用于替换MVC中各种json操作,微软mvc当然用自家的序列化,速度慢不说,还容易出问题,自定义性也太差,比如得特意解决循环引用的问题,比如datetime的序列化格式,比如性能.NewtonSoft.json也就是Json.Net性能虽然不是最好的,但是是比较靠前的,其功能是最强大的,包含各种json操作模式.现在来看看mvc中的替换1, Controller.Json方法这个方法最容易出现循环引用,比如EF查出一个一对多集合想序列化,结果a引用了子表b,b中还引用了a,导

Http请求中Content-Type讲解以及在Spring MVC中的应用

引言: 在Http请求中,我们每天都在使用Content-type来指定不同格式的请求信息,但是却很少有人去全面了解content-type中允许的值有多少,这里将讲解Content-Type的可用值,以及在Spring MVC中如何使用它们来映射请求信息. 1.  Content-Type MediaType,即是Internet Media Type,互联网媒体类型:也叫做MIME类型,在Http协议消息头中,使用Content-Type来表示具体请求中的媒体类型信息. [html] vie

MVC中使用SignalR打造酷炫实用的即时通讯功能

資料來源:http://www.fangsi.net/1144.html 前言,现在这世道写篇帖子没个前言真不好意思发出来.本贴的主要内容来自于本人在之前项目中所开发的一个小功能,用于OA中的即时通讯.由于当时走的太急,忘记把代码拿出来.想想这已经是大半年前的事情了,时间过了这么久,在当时最新的SignalR2.0.1到现在已经变成了2.2.昨天晚上特地熬了个夜,重新又把它写出来做了一个小小的Demo.当然我只是大自然的搬运工,这个SignalR即时通讯功能里面有一些前端的类库不是我自己写的.我