1、ng-repeat 数组数据中,不允许数组中有相同的两个数据,这个时候用下标去管理数据便可以解决这个问题

ng-repeat="item in list track by $index"

ng-repeat 自带的属性有 :

$index:下标; $first:第一个; $last:最后一个;

2、动态赋值 class 名

class ng-class="{'btn-info':item.isKill == 'Y'}";
第二种情况:
<li ng-repeat="item in list" class="{{$first? 'classOne': 'classTwo'}} {{$last? 'classOne': 'classTwo'}}"></li>

3、ng-click 中的 this

有时候要获取当前的这个元素,比如点击哪一个删除哪一个,要获取this。方法:

页面中:ng-click="changeKill($event.target)"
js中:$(target) 就是 $(this)
$scope.changeKill = function(target){
$(target).removeClass("btn-danger").addClass("btn-info");
$(target).text("是");
}

4、数据请求

  get 请求:

$http.get('/api/user/showname2', {
params: {
name: '张三',
age: 'abc'
}
}).then(function (result) { //正确请求成功时处理
console.info(result);
alert(result.data);
}).catch(function (result) { //捕捉错误处理
console.info(result);
alert(result.data.Message);
});

5、有时候动态改变某一个状态的时候,视图不会发生改变。需要

$scope.$apply(function(){

    }

在这个函数里面填写动态改变,$scope不需要注入。

6、复选框 和 单选框,在页面加载的时候就赋值上选中与不选中。

复选框(不判断):

<input type="checkbox" ng-model="true"> 新品
ng-model="true" 为选中
ng-model="false" 为不选中

复选框(判断):

<input type="checkbox" ng-model="chooseNew"> 新品

在 chontroller 中根据后台数据赋值 chooseNew

 $scope.chooseKill = $scope.list.isKill == 'Y' ? true : false;

单选框(不判断):

<input type="radio" name="" ng-checked="true" value="option1"> 上架
true为选中,false 为不选中

单选框(判断):

<input type="radio" name="" ng-checked="chooseLine" value="option1"> 上架

在 chontroller 中根据后台数据赋值 chooseLine

 $scope.chooseLine = $scope.list.isOnLine == 'Y' ? true : false;
or
<input type="radio" name="" ng-checked="user.sex==='1'" value="option1"> 男
<input type="radio" name="" ng-checked="user.sex==='0'" value="option1"> 女

后台传递的数据有一个 sex 是几,是1就代表男选中,0就代表女选中。

7、{{}} 和 ng-bind 实现了双向数据绑定。但是{{}} 有时候页面没加载出来的时候会出现在页面上,

非常不好看,用ng-bind变可以解决这一个问题

8、不同控制器如何调用或者公用一个数据或者函数,service  factory

angular.module('app',[]).factory('Data',function(){
return {
shopCart: ['商品1','商品2','商品3'] //可以操作,只要返回就行
}
}).service('user',function(){
this.list = [];
this.getNum = function(){ }
//用service 的话在 service 里面写什么参数例如 user 在控制器中也要把这个 穿进去
}).controller('oneCtrl',function($scoope,Data,user){ //下单页面
//$scoope.shopCart = ;
在控制器中直接 $scoope.shopCart 就可以访问数据
}).controller('oneCtrl',function($scoope,Data,user){ //购物车页面
//$scoope.data = Data;
});

  在 controller 中要访问 factory 的时候要将 Data 注入到 controller 中。

shopCart 购物车数据,购物车数据在 购物车页面姚增删改,再下单页面也要,这样购物车数据就是两个页面公用的数据

9、用$watch 来监听一个事件

例如 input 值改变了就执行什么函数,利用 ng-model 绑定一个 值在input上,然后在 控制器里面监听这个 绑定的变量。

//角色变化监控
$scope.$watch('mainSelect',function(newValue,oldValue, scope){
console.log(oldValue);
//当js执行到 controller 的时候 $watch 会被执行一次,所以说第一次是不对的,没有改变也是执行的,用下边这种方法过滤第一次
if(oldValue == newValue ){
return;
}else{
loadReload();
} });

当js执行到 controller 的时候 $watch 会被执行一次,所以说第一次是不对的,没有改变也是执行的,用上边这种方法过滤第一次

http://www.angularjs.cn/A0a6

10、常用指令

ng-bind、ng-model、ng-show/hide、ng-if、ng-submit、ng-disabled、
ng-checked、ng-src、ng-href、ng-class、ng-selected、ng-change。
ng-src="{{list.pic}}" ;在双花括号里面写图片的路径,这个路径是后台传递过来的,也就是动态的。
ng-selected="true"  代表
<select>
<opation></opation>
<opation ng-selected="true"></opation>
<opation></opation>
</select>
代表下拉选择框默认选中第二个了。

11、ng-show

<div class="two_way_canlader panel animated slideInRight" ng-show="isShowDailog">
$scope.isShowDailog = false;
$scope.chooseDate = function(){
$scope.isShowDailog = !$scope.isShowDailog ;
}



最新文章

  1. android开发------编写用户界面之相对布局
  2. LINQ to SQL Count/Sum/Min/Max/Avg Join
  3. linux内存查看
  4. macOS 自动修改mac地址脚本
  5. 查看堵塞的SQL
  6. Android Studio代码着色插件
  7. 苹果 AR 新专利马上登陆 Facetime|Facebook 要用 VR 玩直播
  8. shell脚本的if语句,判断某程序是否存在,不存在启动该程序!
  9. 【算法导论】最小生成树之Prime法
  10. 第48章 UserInfo端点(UserInfo Endpoint) - Identity Server 4 中文文档(v1.0.0)
  11. 三个猜数字游戏代码(Python)
  12. WebService 及 CXF 的进阶讲解
  13. 第28月第5天 uibutton交换方法
  14. javascript日期格式yyyyMMddHHmmss
  15. 4《想成为黑客,不知道这些命令行可不行》(Learn Enough Command Line to Be Dangerous)—目录
  16. svn 使用教程
  17. [CF521D]Shop
  18. 案例情景--在一次Oracle 数据库导出时 EXP-00008;ORA-00904:EXP-00000: oracle不同版本导入导出规则
  19. JQuery实现的 checkbox 全选;&lt;select&gt;下拉框功能
  20. linux apache下虚拟主机配置方法

热门文章

  1. [luogu4478 BJWC2018] 上学路线 (容斥原理+拓展lucas)
  2. Educational Codeforces Round 35 B/C/D
  3. (8). 使用JPA保存数据【从零开始学Spring Boot】
  4. linux 线程切换效率与进程切换效率相差究竟有多大?
  5. poj2299--归并排序求逆序数
  6. 支持中文的基于词为基本粒度的前缀树(prefix trie)python实现
  7. strcpy函数使用方法以及底层实现
  8. ZOJ 3829 Known Notation(字符串处理 数学 牡丹江现场赛)
  9. Uva1335 二分+贪心
  10. Ubuntu安装及ubuntu系统使用菜岛教程