Angular工具方法学习


Posted in Javascript onDecember 26, 2016

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引入进来方法会更多。

Javascript 相关文章推荐
JavaScript中的几个关键概念的理解-原型链的构建
May 12 Javascript
最精简的JavaScript实现鼠标拖动效果的方法
May 11 Javascript
JS日期加减,日期运算代码
Nov 05 Javascript
JavaScript使用DeviceOne开发实战(一) 配置和起步
Dec 01 Javascript
理解javascript中Map代替循环
Feb 26 Javascript
全面解析JavaScript里的循环方法之forEach,for-in,for-of
Apr 20 Javascript
js防阻塞加载的实现方法
Sep 09 Javascript
angular和BootStrap3实现购物车功能
Jan 25 Javascript
jQuery实现简单弹窗遮罩效果
Feb 27 Javascript
浅谈Vuejs中nextTick()异步更新队列源码解析
Dec 31 Javascript
Jquery获取radio选中值实例总结
Jan 17 jQuery
js实现贪吃蛇小游戏(加墙)
Jul 31 Javascript
angular双向绑定模拟探索
Dec 26 #Javascript
jquery Banner轮播选项卡
Dec 26 #Javascript
Javascript中常用类型的格式化方法小结
Dec 26 #Javascript
Angular的自定义指令以及实例
Dec 26 #Javascript
如何提高javascript加载速度
Dec 26 #Javascript
JS实现一次性弹窗的方法【刷新后不弹出】
Dec 26 #Javascript
javascript实现去除HTML标签的方法
Dec 26 #Javascript
You might like
Yii编程开发常见调用技巧集锦
2016/07/15 PHP
Yii框架实现的验证码、登录及退出功能示例
2017/05/20 PHP
php文件上传类的分享
2017/07/06 PHP
CI框架(CodeIgniter)实现的导入、导出数据操作示例
2018/05/24 PHP
jquery自定义函数的多种方法
2014/01/09 Javascript
3种Jquery限制文本框只能输入数字字母的方法
2014/12/03 Javascript
node.js [superAgent] 请求使用示例
2015/03/13 Javascript
jQuery插件zepto.js简单实现tab切换
2015/06/16 Javascript
浅谈js对象属性 通过点(.) 和方括号([]) 的不同之处
2016/10/29 Javascript
详解webpack-dev-server使用http-proxy解决跨域问题
2018/01/13 Javascript
JavaScript中this用法学习笔记
2019/03/17 Javascript
浅谈js闭包理解
2019/03/28 Javascript
React传值 组件传值 之间的关系详解
2019/08/26 Javascript
js图数据结构处理 迪杰斯特拉算法代码实例
2019/09/11 Javascript
javascript 构建模块化开发过程解析
2019/09/11 Javascript
python的类变量和成员变量用法实例教程
2014/08/25 Python
Python中if __name__ == &quot;__main__&quot;详细解释
2014/10/21 Python
python实现决策树C4.5算法详解(在ID3基础上改进)
2017/05/31 Python
浅谈pandas中Dataframe的查询方法([], loc, iloc, at, iat, ix)
2018/04/10 Python
解决python3 urllib 链接中有中文的问题
2018/07/16 Python
详解如何在Apache中运行Python WSGI应用
2019/01/02 Python
python write无法写入文件的解决方法
2019/01/23 Python
对Python生成汉字字库文字,以及转换为文字图片的实例详解
2019/01/29 Python
Django中使用Whoosh进行全文检索的方法
2019/03/31 Python
Python参数解析模块sys、getopt、argparse使用与对比分析
2019/04/02 Python
关于阿里云oss获取sts凭证 app直传 python的实例
2019/08/20 Python
pandas和spark dataframe互相转换实例详解
2020/02/18 Python
英国著名国际平价时尚男装品牌:Topman
2016/08/27 全球购物
Joules美国官网:出色的英国风格
2017/10/30 全球购物
次世代生活态度:Hypebeast
2018/07/05 全球购物
俄罗斯名牌服装网上商店:UNIQUE FABRIC
2019/07/25 全球购物
乐高瑞士官方商店:LEGO CH
2020/08/16 全球购物
小米官方旗舰店:Xiaomi
2020/08/07 全球购物
同步和异步有何异同,在什么情况下分别使用他们?举例说明
2014/02/27 面试题
年度考核登记表个人总结
2015/03/06 职场文书
vue @click.native 绑定原生点击事件
2022/04/22 Vue.js