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引入进来方法会更多。
# Angular
# 工具方法
# js调试工具console.log()方法查看js代码的执行情况
# node.js版本管理工具n无效的原理和解决方法
# js实现带关闭按钮始终显示在网页最底部工具条的方法
# PHP小技巧之JS和CSS优化工具Minify的使用方法
# JavaScript1.6数组新特性介绍以及JQuery的几个工具方法
# 将nodejs打包工具整合到鼠标右键的方法
# js工具方法弹出蒙版
# 常用Extjs工具:Extjs.util.Format使用方法
# 一款js和css代码压缩工具[附JAVA环境配置方法]
# 解决http://16a.us/2.js之arp欺骗的方法附专杀工具
# 遍历
# 转成
# 都是
# 是一个
# 就会
# 是个
# 第一个
# 中有
# 这个时候
# 也为
# 第三个
# 很熟悉
# 是否存在
# 换行
# 是为了
# 上挂
# 法会
# 但是在
# js
# var
相关文章:
建站之星图片链接生成指南:自助建站与智能设计教程
如何选择高性价比服务器搭建个人网站?
广州美橙建站如何快速搭建多端合一网站?
如何快速搭建安全的FTP站点?
如何构建满足综合性能需求的优质建站方案?
网站图片在线制作软件,怎么在图片上做链接?
深圳网站制作的公司有哪些,dido官方网站?
如何零基础开发自助建站系统?完整教程解析
制作销售网站教学视频,销售网站有哪些?
如何实现建站之星域名转发设置?
威客平台建站流程解析:高效搭建教程与设计优化方案
简单实现Android文件上传
制作公司内部网站有哪些,内网如何建网站?
宝塔Windows建站如何避免显示默认IIS页面?
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
建站之星会员如何解锁更多建站功能?
如何在云虚拟主机上快速搭建个人网站?
b2c电商网站制作流程,b2c水平综合的电商平台?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
如何在新浪SAE免费搭建个人博客?
宿州网站制作公司兴策,安徽省低保查询网站?
网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?
招商网站制作流程,网站招商广告语?
网站网页制作专业公司,怎样制作自己的网页?
网站制作壁纸教程视频,电脑壁纸网站?
如何使用Golang table-driven基准测试_多组数据测量函数效率
青岛网站建设如何选择本地服务器?
学校建站服务器如何选型才能满足性能需求?
C++时间戳转换成日期时间的步骤和示例代码
如何通过PHP快速构建高效问答网站功能?
音响网站制作视频教程,隆霸音响官方网站?
宁波自助建站系统如何快速打造专业企业网站?
建站之星CMS五站合一模板配置与SEO优化指南
网站制作的步骤包括,正确网址格式怎么写?
宝塔面板如何快速创建新站点?
测试制作网站有哪些,测试性取向的权威测试或者网站?
如何通过云梦建站系统实现SEO快速优化?
Swift中循环语句中的转移语句 break 和 continue
如何撰写建站申请书?关键要点有哪些?
大同网页,大同瑞慈医院官网?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
教育培训网站制作流程,请问edu教育网站的域名怎么申请?
c# F# 的 MailboxProcessor 和 C# 的 Actor 模型
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
视频网站制作教程,怎么样制作优酷网的小视频?
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
电脑免费海报制作网站推荐,招聘海报哪个网站多?
如何选择适合PHP云建站的开源框架?
企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?
如何在建站宝盒中设置产品搜索功能?
*请认真填写需求信息,我们会在24小时内与您取得联系。