• 数组循环放到新生成的li
<ul ng-init="arr=[12,5,6,394,344]">
<li ng-repeat="item in arr">{{item}}</li>
</ul>
<!--这里的item只是个变量,名字随意,只的是循环数组中的每一项数据-->
  • 也可以加入数组的下标
<ul ng-init="arr=[12,5,6,394,344]">
<li ng-repeat="(index,value) in arr">{{index}}={{value}}</li>
</ul>
<!--记得要加括号,另外第一个参数是下标,第二个参数是每个下标对应的数据-->
  • 当然,循环json也是没有问题的
<ul ng-init="json={'a':'abc','b':123,'c':'hello'}">
<li ng-repeat="(key,value) in json">{{key}}={{value}}</li>
</ul>
<!--第一个参数是键,第二个参数是值,需要注意的是,既然ng-init后面用了双引号,那json里只能都用单引号了,如果还用双引号就会出错-->
  • 稍微复杂的例子
<ul ng-init="arr=[{'name':'Victor','age':33},{'name':'Mary','age':30},{'name':'Qinyu','age':4}]">
<li ng-repeat="item in arr">{{item.name}}:{{item.age}}岁</li>
</ul>
  • 一个页面可以有很多Module,比如轮播图是个模块,导航是个模块,搜索是个模块,而一个模块下可以有很多controller
<html ng-app="test"> <!--这里是module模块的名字-->
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>Insert title here</title>
<script src="angular.1.5.8.min.js"></script>
<style type="text/css">
</style>
<script type="text/javascript">
var app = angular.module('test',[]); //定义一个名字为app的模块,在这个例子中app放在了<html>上,所以整个页面都受这一个module控制 app.controller('cont1',function($scope){ //在这个app模块上定义了一个controller,名字是cont1
$scope.a = 12; //在cont1控制器中定义了一个变量a
}); app.controller('cont2',function($scope){ //在这个app模块上定义了一个controller,名字是cont2
$scope.b = 5; ////在cont2控制器中定义了一个变量b
});
</script>
</head>
<body >
<div ng-controller="cont1"> <!--//只有在cont1控制下的元素能访问到a变量-->
<span>{{a}}</span>
</div>
<div ng-controller="cont2"> <!--//只有在cont2控制下的元素能访问到b变量-->
<span>{{b}}</span>
</div>
</body>
</html>

依赖注入:

好处是,函数的参数的名字是定死的,比如$scope, $rootScope,而且参数只要名字对了,没有顺序规定


自定义指令directive的时候,如果要用到restrict:M的时候,用的是注释<!-- directive:hello --> ,这里的hello是自定义的指令名称,而且目前的1.5.8版本里,还要在returnjson里写上 replace:true;

app.directive('hello',function(){
return {
restrict:'ECMA',
template:'<div>Hello World</div>', //也可以用templateUrl
replace:true,
link:function(scope,ele,attr){
ele.bind('mouseenter',function(){
scope.$apply('printout()'); //调用的是对应的controller里的printout方法
});
}
};
});

同一个指令可以用在不同的controller里面,实现指令在不同controller下使用的的方法,就是在自定义标签里加上自定义属性,根据属性值的不同,调用controller下不同的方法

var app = angular.module('myApp',[]);
app.controller('start_no1',['$scope',function($scope){
$scope.printout_1 = function(){
console.log('start');
};
}]);
//这里定义了2个不同的controller,都想用下面自定义的指令hello,它们有不同的函数printout_1和printout_2
app.controller('start_no2',['$scope',function($scope){
$scope.printout_2 = function(){
console.log('start222');
};
}]); app.directive('hello',function(){ //指令就一个,但是里面绑定事件用到的函数写在$apply()的参数里,而这时,attr就是指的该标签attr的自定义属性名,以为着,调用的时候执行该标签里的属性,这个例子里自定义的是hi属性
return {
restrict:'ECMA',
template:'<div>Hello World</div>',
replace:true,
link:function(scope,ele,attr){
ele.bind('mouseenter',function(){
scope.$apply(attr.howtoload); //这里的函数调用只要写函数名,因为前面的$apply已经是执行了,另外这个howtoload都要小写,即使在标签里是驼峰式的写法howToLoad,为了避免失误,可以在标签都保持小写即可
});
}
};
}); </script>
</head>
<body >
<div ng-controller="start_no1">
<hello howToLoad="printout_1()"></hello> <!--这里在指令hello标签里写上自定义属性hi,然后指定它等于不同controller里的函数-->
</div>
<div ng-controller="start_no2">
<hello howToLoad="printout_2()"></hello>
</div>

【学】AngularJS日记(2)的更多相关文章

  1. 【pwn】学pwn日记——栈学习(持续更新)

    [pwn]学pwn日记--栈学习(持续更新) 前言 从8.2开始系统性学习pwn,在此之前,学习了部分汇编指令以及32位c语言程序的堆栈图及函数调用. 学习视频链接:XMCVE 2020 CTF Pw ...

  2. 【pwn】学pwn日记(堆结构学习)

    [pwn]学pwn日记(堆结构学习) 1.什么是堆? 堆是下图中绿色的部分,而它上面的橙色部分则是堆管理器 我们都知道栈的从高内存向低内存扩展的,而堆是相反的,它是由低内存向高内存扩展的 堆管理器的作 ...

  3. 【学】AngularJS日记(4)- 过滤器的使用

    过滤器: 过滤器中的 |json,可以使原来的json数据输出时按照换行的样式 过滤器 | limitTo:2可以截取字符串或者数组的前2位 过滤器| orderBy 可以进行排序,加入json里的k ...

  4. 【学】AngularJS日记(3)- $apply(), run()方法

    $scope.$apply()方法可以强制$apply()里运行的函数所改变的model里的数据直接反应到view里,因为在angular的环境中,有时会用到原生js或者jquery的时候,这些行为有 ...

  5. 【学】AngularJS日记(1) - 常用工具

    angular.isArray(a) 判断a是否为数组 angular.isDate 是否为时间对象 angular.isDefined 判断元素是否存在 angular.isUndefined an ...

  6. 跟我学AngularJs:Service、Factory、Provider依赖注入使用与差别

    林炳文Evankaka原创作品. 转载请注明出处http://blog.csdn.net/evankaka        本教程使用AngularJs版本号:1.5.3        AngularJ ...

  7. 写在学AngularJS之前

    近来从不同途径听说AngularJS和MEAN stack,感觉很有趣的样子,于是准备抽时间来学习一下.在这里记录学习过程中的笔记. 简单整理一下先: 1. 我的学习资料: a) 官网 b) wiki ...

  8. 从0开始学angularjs-笔记03

    大家好,今天上班第一天,可能大家都不是很想上班吧,我也是一样啦---不想上班就来继续写我的angualrjs教程,造福大家吧!! 今天的主要讲解部分有以下几点:1.演示一个完整的项目结构  2.$sc ...

  9. 从0开始学angularjs-笔记02

    上一节课主要跟大家讲解了angularjs的几种特性和看了一个简单的双向绑定的例子.最近都没有时间写博客了....忙成狗呀...今天周末,在写一篇吧~~ 今天主要跟大家详细讲解一下angularjs的 ...

随机推荐

  1. SPM Homework 1 —A Project From My Personal Life

    我所完成的一个项目是上学期WEB的期末作业. 项目本质:使用Java Web编写一个网上银行系统,并实现老师所给的几项要求:分角色2015登陆.开户.存取款.转款.查看明细等. 最初目标:能够完成所有 ...

  2. 视音频技术作业一:比较CCD与CMOS摄像的区别

    作业详解: CCD与CMOS简介: CCD: CCD是Charge Coupled Device(电荷耦合器件)的缩写,它是一种半导体成像器件,因而具有灵敏度高.抗强光.畸变小.体积小.寿命长.抗震动 ...

  3. Centos6.5 gitlab安装使用

    公司从svn转到git做版本管理,我搜了一下网上git的服务器,包括gitosis,gitolite等.一开始我是用的是gitosis作为git服务器的,安装过程还算比较简单,整个服务使用python ...

  4. 在博文中嵌入Javascript代码

    今天吃饭时无聊,突然想到Markdown除了兼容HTML会不会也兼容Javascript,于是博文里除了码文插音乐还可以干点更好玩的事儿了,可以自动修改markdown文件本身,比如说自动修改从Git ...

  5. Collections.reverse 代码思考-超越昨天的自己系列(13)

    点进Collections.reverse的代码瞄了眼,然后就开始了一些基础知识的收集. 现在发现知道的越多,知道不知道的越多. 列几个记录下: reverse方法源码: /** * Reverses ...

  6. 2017 年值得一瞥的 JavaScript 相关技术趋势

    跨年前两天,Dan Abramov在Twitter上提了一个问题: JS社区毫不犹豫的抛出了它们对于新技术的预期与期待,本文内容也是总结自Twitter的回复,按照流行度降序排列.有一个尚未确定的小点 ...

  7. Oracle笔记2-数据库设计

    数据库的设计 软件开发的流程:立项->需求分析->概要设计->详细设计->实现->测试->交付->维护 [含数据库设计] 通过需求分析,就可以抽取出关键业务中 ...

  8. js中toString和valueOf方法的区别

    toString 方法 返回对象的字符串表示形式. 语法:objectname.toString([radix]) objectname 必需.要为其搜索字符串表示形式的对象. radix 可选.为将 ...

  9. socket实现手机连接网络打印机打印pos单

    打印的工具类: public class PrintLine {  String TAG = "xxl";  static String PRINT_IP = "192. ...

  10. wininet异步InternetReadFile和超时相关问题

    wininet是对socket的封装 主要流程为创建,连接,发送,接收,关闭几个过程 所以在回调函数InternetStatusCallback中可以检测到dwInternetStatus #defi ...