angular为我们提供了很多的工具方法。
angular.bind 更改this指向
var a = angular.bind(obj2,obj1.show,' is a object');
var b = angular.bind(obj2,[' is a object']);
console.log(a());
var b = angular.bind(obj2,[' is a object']);
console.log(a());
angular.bind会根据你的参数类型来决定调用call或apply,注意a和b後面传递的参数,a是传递一个字符串,b是传递一个数组。
angular.copy 拷贝
var c = angular.copy(a);
console.log(c);
console.log(c);
angular.extend 继承
var c = angular.extend(a,b);
console.log(c);
console.log(c);
angular.extend 比较
console.log(angular.equals(NaN,NaN)); //true
console.log(NaN == NaN); //false
console.log(NaN === NaN); //false
console.log(NaN == NaN); //false
console.log(NaN === NaN); //false
注意最後NaN和NaN的比较,在原生JS中都是为false的,但是在angular中尉true。
angular.forEach 遍历
遍历数组,对象也可以。value表示值,i表示索引,而this表示window对象。(在angular.forEach中我们传递了两个参数,1是遍历的数组,2是匿名函数)
获取某些值
if(value === 'a'){
//如果数组中有'a'的话,就存入到result中,这里的this就代表result
this.push(value);
};
},result);
console.log(result);
这个时候我们三个参数,1是遍历的数组,2是匿名函数,3是结果集(
angular也为我们提供了原生的JSON.parse()以及JSON.stringify()方法。 将一个字符串的json解析成对象。 将一个json解析成字符串(後面传入一个true可换行,便于阅读)
辅助方法
var flag = false;
flag ? console.log('xxx') : angular.noop(); //空函数,防止出错
flag ? console.log('xxx') : angular.noop(); //空函数,防止出错
大小写转换
判断类型
angular.isArray //判断一个元素是否是数组
angular.isDate //判断一个元素是否是时间对象
angular.isDefined //判断一个元素是否存在
angular.isUndefined //判断一个元素是否是undefined
angular.isFunction //判断一个元素是否是个函数
angular.isNumber //判断一个元素是否是数字
angular.isObject //判断一个元素是否是对象
angular.isString //判断一个元素是否是字符串
angular.isElement //判断一个元素是否是html节点元素(JQ获取的元素也是可以判断到的)
angular.isDate //判断一个元素是否是时间对象
angular.isDefined //判断一个元素是否存在
angular.isUndefined //判断一个元素是否是undefined
angular.isFunction //判断一个元素是否是个函数
angular.isNumber //判断一个元素是否是数字
angular.isObject //判断一个元素是否是对象
angular.isString //判断一个元素是否是字符串
angular.isElement //判断一个元素是否是html节点元素(JQ获取的元素也是可以判断到的)
文件信息
angular也提供了部分JQ中的方法 console.log(angular.element(oDiv));
是不是很熟悉呢 ? 如果将JQ引入进来方法会更多。