Angular工具方法学习
程序员文章站
2022-04-25 21:01:36
angular为我们提供了很多的工具方法。
angular.bind 更改this指向
var obj1 = {
name : 'obj1',
show...
angular为我们提供了很多的工具方法。
angular.bind 更改this指向
var obj1 = { name : 'obj1', show : function(str){ return this.name + str; } }; var obj2 = { name : 'obj2' }; var a = angular.bind(obj2,obj1.show,' is a object'); var b = angular.bind(obj2,obj1.show,[' is a object']); console.log(a());
angular.bind会根据你的参数类型来决定调用call或apply,注意a和b後面传递的参数,a是传递一个字符串,b是传递一个数组。
angular.copy 拷贝
var a = { name : 'hello' }; var c = angular.copy(a); console.log(c);
angular.extend 继承
var a = { name : 'hello' }; var b = { age : 20 }; var c = angular.extend(a,b); console.log(c);
angular.extend 比较
console.log(angular.equals(1,1)); //true console.log(angular.equals({name:'xxx'},{name:'xxx'})); //true console.log(angular.equals({name:'xxx'},{name:'yyy'})); //false console.log(angular.equals(nan,nan)); //true console.log(nan == nan); //false console.log(nan === nan); //false
注意最後nan和nan的比较,在原生js中都是为false的,但是在angular中尉true。
angular.foreach 遍历
var array = ['a','b','c']; angular.foreach(array,function(value,i){ console.log(value,i); console.log(this); });
遍历数组,对象也可以。value表示值,i表示索引,而this表示window对象。(在angular.foreach中我们传递了两个参数,1是遍历的数组,2是匿名函数)
var array = ['a','b','c']; var result = []; angular.foreach(array,function(value,i){ //遍历查找数组时,我们可能是为了获取某些值 if(value === 'a'){ //如果数组中有'a'的话,就存入到result中,这里的this就代表result this.push(value); }; },result); console.log(result);
这个时候我们三个参数,1是遍历的数组,2是匿名函数,3是结果集(当传递了第三个参数的时候angular.foreach里面的this就会是一个空数组,否侧为window对象)。
angular也为我们提供了原生的json.parse()以及json.stringify()方法。
var str = '{"name" : "xiecg","age" : "18"}'; var json = angular.fromjson(str); console.log(json);
将一个字符串的json解析成对象。
var str = {"name" : "xiecg","age" : "18"}; var json = angular.tojson(str,true); console.log(json);
将一个json解析成字符串(後面传入一个true可换行,便于阅读)
辅助方法
console.log( angular.identity(1,2,3) ); //返回第一个参数 var flag = false; flag ? console.log('xxx') : angular.noop(); //空函数,防止出错
大小写转换
console.log(angular.uppercase('hello')); //转成大写 console.log(angular.lowercase('hello')); //转成小写
判断类型
var a = []; console.log(angular.isarray(a)); //true angular.isarray //判断一个元素是否是数组 angular.isdate //判断一个元素是否是时间对象 angular.isdefined //判断一个元素是否存在 angular.isundefined //判断一个元素是否是undefined angular.isfunction //判断一个元素是否是个函数 angular.isnumber //判断一个元素是否是数字 angular.isobject //判断一个元素是否是对象 angular.isstring //判断一个元素是否是字符串 angular.iselement //判断一个元素是否是html节点元素(jq获取的元素也是可以判断到的)
文件信息
console.log( angular.version )
angular也提供了部分jq中的方法
<!doctype html> <html ng-app> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <title>demo</title> <script type="text/javascript" src="https://code.angularjs.org/1.3.8/angular.min.js"></script> </head> <body> <div id="box">1</div> <script type="text/javascript"> document.onclick = function(){ var odiv = document.getelementbyid('box'); angular.element(odiv).css('background','red'); console.log(angular.element(odiv)); //查看原型上挂载的方法 }; </script> </body> </html>
console.log(angular.element(odiv));
是不是很熟悉呢 ? 如果将jq引入进来方法会更多。
推荐阅读
-
《深入理解java虚拟机》学习笔记--第四章:虚拟机性能监控与故障处理工具 虚拟机java
-
《深入理解java虚拟机》学习笔记--第四章:虚拟机性能监控与故障处理工具 虚拟机java
-
MySQL学习笔记之数据的增、删、改实现方法_MySQL
-
photoshop学习网站 php学习笔记 面向对象的构造与析构方法
-
深入学习php数据类型转换方法 php数据类型转换不求人
-
java实现字符串四则运算公式解析工具类的方法
-
nodejs学习四:sequelize model的常用方法
-
Java JDBC入门之八 : DAO设计模式重构查询方法 AND 使用BeanUtils工具类操作JavaBean
-
ES6字符串新增扩展方法以及模板字符串的学习
-
PHP学习方法和经验