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 对象的属性和方法4种不同的类型
Mar 19 Javascript
javascript XMLHttpRequest对象全面剖析
Apr 24 Javascript
JQuery将文本转化成JSON对象需要注意的问题
May 09 Javascript
js控制再次点击按钮之间的间隔时间可防止重复提交
Aug 01 Javascript
AngularJS学习笔记之ng-options指令
Jun 16 Javascript
基于jquery实现一个滚动的分步注册向导-附源码
Aug 26 Javascript
详解JavaScript中的属性和特性
Dec 08 Javascript
使用微信内嵌H5网页解决JS倒计时失效问题
Jan 13 Javascript
微信小程序实现验证码获取倒计时效果
Feb 08 Javascript
详解使用create-react-app快速构建React开发环境
May 16 Javascript
mpvue中使用flyjs全局拦截的实现代码
Sep 13 Javascript
在vue项目实现一个ctrl+f的搜索功能
Feb 28 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
Linux下将excel数据导入到mssql数据库中的方法
2010/02/08 PHP
php强制下载类型的实现代码
2011/04/21 PHP
php中通过curl模拟登陆discuz论坛的实现代码
2012/02/16 PHP
php在window iis的莫名问题的测试方法
2013/05/14 PHP
PHP在线生成二维码代码(google api)
2013/06/03 PHP
linux系统下php安装mbstring扩展的二种方法
2014/01/20 PHP
推荐几款用 Sublime Text 开发 Laravel 所用到的插件
2014/10/30 PHP
php实现遍历文件夹的方法汇总
2017/03/02 PHP
laravel使用数据库测试注意事项
2020/04/10 PHP
jQuery源码分析-04 选择器-Sizzle-工作原理分析
2011/11/14 Javascript
jQuery 淡出一个图像到另一个图像的实现代码
2013/06/12 Javascript
javascript实现百度地图鼠标滑动事件显示、隐藏
2015/04/02 Javascript
在JavaScript中处理数组之reverse()方法的使用
2015/06/09 Javascript
javascript中使用new与不使用实例化对象的区别
2015/06/22 Javascript
Angular.js之作用域scope'@','=','&amp;'实例详解
2017/02/28 Javascript
Vue v2.4中新增的$attrs及$listeners属性使用教程
2018/01/08 Javascript
详解React项目的服务端渲染改造(koa2+webpack3.11)
2018/03/19 Javascript
如何在vue里添加好看的lottie动画
2018/08/02 Javascript
vue组件中的样式属性scoped实例详解
2018/10/30 Javascript
jQuery实现异步上传一个或多个文件
2020/08/17 jQuery
Jquery+javascript实现支付网页数字键盘
2020/12/21 jQuery
使用Python下载歌词并嵌入歌曲文件中的实现代码
2015/11/13 Python
python3批量删除豆瓣分组下的好友的实现代码
2016/06/07 Python
python安装oracle扩展及数据库连接方法
2017/02/21 Python
Request的中断和ErrorHandler实例解析
2018/02/12 Python
django表单实现下拉框的示例讲解
2018/05/29 Python
python用户评论标签匹配的解决方法
2018/05/31 Python
很酷的python表白工具 你喜欢我吗
2019/04/11 Python
python如何实现不用装饰器实现登陆器小程序
2019/12/14 Python
CK美国官网:Calvin Klein
2016/08/26 全球购物
某/etc/fstab文件中的某行如下: /dev/had5 /mnt/dosdata msdos defaults,usrquota 1 2 请解释其含义
2013/09/18 面试题
J2EE模式面试题
2016/10/11 面试题
中学优秀班主任事迹材料
2014/05/01 职场文书
有限公司股东合作协议书
2014/10/29 职场文书
redis击穿 雪崩 穿透超详细解决方案梳理
2022/03/17 Redis
SpringCloud Feign请求头删除修改的操作代码
2022/03/20 Java/Android