欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular工具方法學(xué)習(xí)

 更新時(shí)間:2016年12月26日 15:01:47   作者:小謝53  
這篇文章主要為大家詳細(xì)介紹了Angular工具方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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會(huì)根據(jù)你的參數(shù)類型來(lái)決定調(diào)用call或apply,注意a和b後面?zhèn)鬟f的參數(shù),a是傳遞一個(gè)字符串,b是傳遞一個(gè)數(shù)組。 

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

遍歷數(shù)組,對(duì)象也可以。value表示值,i表示索引,而this表示window對(duì)象。(在angular.forEach中我們傳遞了兩個(gè)參數(shù),1是遍歷的數(shù)組,2是匿名函數(shù))

var array = ['a','b','c'];
var result = [];
angular.forEach(array,function(value,i){
 //遍歷查找數(shù)組時(shí),我們可能是為了獲取某些值
 if(value === 'a'){
  //如果數(shù)組中有'a'的話,就存入到result中,這里的this就代表result
  this.push(value);
 };
},result);
console.log(result);

這個(gè)時(shí)候我們?nèi)齻€(gè)參數(shù),1是遍歷的數(shù)組,2是匿名函數(shù),3是結(jié)果集(當(dāng)傳遞了第三個(gè)參數(shù)的時(shí)候angular.forEach里面的this就會(huì)是一個(gè)空數(shù)組,否側(cè)為window對(duì)象)。   

angular也為我們提供了原生的JSON.parse()以及JSON.stringify()方法。

var str = '{"name" : "xiecg","age" : "18"}';
var json = angular.fromJson(str);
console.log(json);

將一個(gè)字符串的json解析成對(duì)象。

var str = {"name" : "xiecg","age" : "18"};
var json = angular.toJson(str,true);
console.log(json);

將一個(gè)json解析成字符串(後面?zhèn)魅胍粋€(gè)true可換行,便于閱讀) 

輔助方法

console.log( angular.identity(1,2,3) ); //返回第一個(gè)參數(shù)

var flag = false; 
flag ? console.log('xxx') : angular.noop(); //空函數(shù),防止出錯(cuò)

大小寫轉(zhuǎn)換

console.log(angular.uppercase('hello')); //轉(zhuǎn)成大寫
console.log(angular.lowercase('HELLO')); //轉(zhuǎn)成小寫
 

判斷類型

var a = [];
console.log(angular.isArray(a)); //true

angular.isArray   //判斷一個(gè)元素是否是數(shù)組
angular.isDate   //判斷一個(gè)元素是否是時(shí)間對(duì)象
angular.isDefined   //判斷一個(gè)元素是否存在
angular.isUndefined  //判斷一個(gè)元素是否是undefined
angular.isFunction  //判斷一個(gè)元素是否是個(gè)函數(shù)
angular.isNumber  //判斷一個(gè)元素是否是數(shù)字
angular.isObject  //判斷一個(gè)元素是否是對(duì)象
angular.isString  //判斷一個(gè)元素是否是字符串
angular.isElement  //判斷一個(gè)元素是否是html節(jié)點(diǎn)元素(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引入進(jìn)來(lái)方法會(huì)更多。

相關(guān)文章

最新評(píng)論