同名服务

  在一次项目里,之前是同事写的。我有一次在异步获取服务器上的数据时,习惯把api地址写在一个服务Store里,但是程序总是返回Store.api.get()里的get is undefined。知道肯定是Store.api为空造成的原因;但是觉得应该是没有问题的才对,最后看到在页面里又重新定义了一次Store服务,所以造成了覆盖。

myApp.factory('Store',function(){
return{
name:'zhang',
age:25
}
})
myApp.factory('Store',function(){
return{
name:'dong',
age:27
}
})  //服务同名了,所以只有最后一次的Store服务有效

建议:在项目大的时候,将项目逻辑分成多个模块,在每个模块里写服务和逻辑。然后在注入到其他模块中,便于测试和逻辑清晰;

在查找错误上,使用先看看服务对象的输出

对象复制

  如果将一个对象赋值给其他对象,无论赋值多少次,最后被赋值的对象都来自同一个对象的引用。

var a={};
var b=a;
b.name='zhang';
a.name //"zhang"
var a={};
var b={};
a==b //false

在angularJS中,如果不想要引用的传递,但是又想获得对象里的数据。可以使用angular.copy(),使用forEach() 方法,把对象里的属性和值重新复制到一个新的对象上;但是又不等于被赋值的对象; var关键词的作用就是在内存中新开一块地址吧

ng-select

angularJS中的select不像HTML代码里自己手动添加option,毕竟使用了指令,扩展了select的功能。

select元素使用ng-options生成下拉选项,只需要提供一个数组给ng-options就好,如果需要提供默认值,需要给select的绑定模型变量赋值

使用ng-options的时候必须给select绑定模型变量ng-model,否则会出错误:[$compile:ctreq] http://errors.angularjs.org/1.5.2/$compile/ctreq?p0=ngModel&p1=ngOptions

<div ng-controller="myController">
<select ng-model="glass" ng-options="o.op as o.type for o in operation">
</select>
</myController>
<script>
myApp.controller('myController', function($scope){
$scope.operation=[
{type: '大于', op: '>'},
{type: '大于等于', op: '>='},
{type: '小于等于', op: '<='},
{type: '等于', op: '='},
{type: '小于', op: '<'},
{type: '不等于', op: '<>'},
{type: '包含', op: ',like'},
{type: '不包含', op: 'notlike'}
];
})
</script>

但是你查看源代码就会看到,angularJS自动在option的value属性里把value值前加了字段类型

<option label="大于等于" value="string:>=">大于等于</option>

也可以自己手动添加option

<select ng-model="glass">
<option value="1">one</option>
<option value="2">two</option>
</select>

Note:麻烦就是手动添加的option的value都是字符串,初始化的时候,$scope.glass="必须是引号引起来的字符串"; 但是ng-select就比较灵活了,使用ng-options就可以给value传基本类型(数字,字符串,布尔值)和对象类型,在初始化的时候赋对应类型的值,调用的时候也获取的是对应类型的数据;

<select ng-model="glass" ng-options="o.id as o.name for o in num" class="ng-pristine ng-valid ng-not-empty ng-touched">
<option value="?" selected="selected"></option>
<option label="one" value="boolean:true">one</option>
<option label="two" value="boolean:false">two</option>
</select>
<select ng-model="glass" ng-options="o.id as o.name for o in num" class="ng-pristine ng-untouched ng-valid ng-not-empty">
<option value="?" selected="selected"></option>
<option label="one" value="number:1">one</option>
<option label="two" value="number:2">two</option>
</select>

添加同一个对象

在表格中,为表格新建一行,并提供一个默认值属性字段

<tr ng-repeat="user in users">
...
</tr>

直接push一个对象到users就行了,如果在行中使用$index,但是push到users里的对象是同一个对象(同一个对象的引用)就会出错

Error: [ngRepeat:dupes] Duplicates in a repeater are not allowed. Use 'track by' expression to specify unique keys

可以根据官方的解决方案,使用ng-repeat="user in users track by $index";

												

angularJS实践过程中出现的问题总结的更多相关文章

  1. Spring Cloud Config 配置中心实践过程中,你需要了解这些细节!

    本文导读: Spring Cloud Config 基本概念 Spring Cloud Config 客户端加载流程 Spring Cloud Config 基于消息总线配置 Spring Cloud ...

  2. AngularJs使用过程中,在ng-repeat中使用track by

    1.问题描述: 点击删除后:table中的被选中设备确实被删除了,但是data-table并没有重新加载出来, 查看js代码: 先对$scope.data_table进行了destroy(),然后重新 ...

  3. Docker从零到实践过程中的坑

    欢迎指正: Centos7 下的ulimit在Docker中的坑 http://www.dockone.io/article/522 僵尸容器:Docker 中的孤儿进程 https://yq.ali ...

  4. SWT实践过程中遇到的问题

    1.import org.eclipse.swt.widgets.Text; 诸如右所示的找不到这个包. 解决办法:project->properties->build path-> ...

  5. Java 理论和实践: 了解泛型 识别和避免学习使用泛型过程中的陷阱

    Brian Goetz (brian@quiotix.com), 首席顾问, Quiotix 简介: JDK 5.0 中增加的泛型类型,是 Java 语言中类型安全的一次重要改进.但是,对于初次使用泛 ...

  6. python与机器学实践-何宇健 源代码及过程中遇到的问题

    # -*- coding: utf-8 -*-"""Spyder EditorThis is a temporary script file.""&q ...

  7. 在CMMI推广过程中EPG常犯的错误(转)

    本文转自: http://developer.51cto.com/art/200807/86953.htm 仅用于个人收藏,学习.如有转载,请联系原作者. ---------------------- ...

  8. 编译recovery及过程中的部分错误解决

    你必须使用32位或64位Ubuntu系统,关于如何建立编译环境和同步源码的指导,请自己查找有关指导的文章. 1, 安装所需要的包 2, 建立编译的环境,并同步CWM所需的源码,CyanogenMod源 ...

  9. ACM 做题过程中的一些小技巧。

    ACM做题过程中的一些小技巧. 1.一般用C语言节约空间,要用C++库函数或STL时才用C++; cout.cin和printf.scanf最好不要混用. 2.有时候int型不够用,可以用long l ...

随机推荐

  1. i3wm配置

    使用安装需要的软件配置按键壁纸和锁屏随机壁纸电源管理终端托盘图标美化 使用 安装 安装i3wm,一般包名叫做i3,包含i3-wm,i3lock和i3status. 在i3wm-config页面下载本配 ...

  2. Python文件读写

    读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的 文件打开模式 模式 意义 r 文本只读 w 文本只写 rb 二进制读 rw 二进制写 打开文件 选择一个模式打开一个文件 ...

  3. bash基础

    bash 是一个为GNU计划编写的Unix shell.它的名字是一系列缩写:Bourne-Again SHell - 这是关于Bourne shell(sh)的一个双关语(Bourne again ...

  4. LAMP(1) 在VirtualBox里安装Ubuntu Server

    问题0.虚拟机中安装lamp环境 问题解决: 来自百度经验 问题1. 用putty远程登陆linux系统,显示network error connection refused 问题解决 问题2. my ...

  5. 练习JavaScript实现梯形乘法表

    效果: 表格用html中的table,tr,td,然后利用for语句实现,循环输出行和列,再根据行列的数量进行乘法运算,第一个for循环输出9行,然后内嵌一个for,在条件表达式中取第一个for循环的 ...

  6. 【BZOJ-3627】路径规划 分层图 + Dijkstra + spfa

    3627: [JLOI2014]路径规划 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 186  Solved: 70[Submit][Status] ...

  7. php 使用函数中遇到的坑之----list

    1. list 把数组中的值赋给一些变量 <?php $info = array('coffee', 'brown', 'caffeine'); // 列出所有变量 list($drink, $ ...

  8. 多视图学习利器----CCA(典型相关分析)及MATLAB实现

    Hello,我是你们人见人爱花见花开的小花.又和大家见面了,今天我们来聊一聊多视图学习利器------CCA. 一 典型相关分析的基本思想 当我们研究两个变量x和y之间的相关关系的时候,相关系数(相关 ...

  9. skipping the actual organic impact moderation supplied

    The most recent running footwear design has gone out. The high cost is actually $150. Expert sports ...

  10. linux 时间同步的2种方法

    转载自: http://blog.51yip.com/server/1474.html 由于硬件的原因,机器或多或少的根标准时间对不上,一个月的误差几秒到几分钟不等.对于服务器来说时间不准,会有很多麻 ...