欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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));

  Angular工具方法学习

是不是很熟悉呢 ?  如果将jq引入进来方法会更多。