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 相关文章推荐
Mootools 1.2教程 选项卡效果(Tabs)
Sep 15 Javascript
js键盘上下左右键怎么触发function(实例讲解)
Dec 14 Javascript
js点击列表文字对应该行显示背景颜色的实现代码
Aug 05 Javascript
js简单实现标签云效果实例
Aug 06 Javascript
JS+CSS实现大气清新的滑动菜单效果代码
Oct 22 Javascript
node.js回调函数之阻塞调用与非阻塞调用
Nov 13 Javascript
JavaScript数组方法总结分析
May 06 Javascript
js实现移动端微信页面禁止字体放大
Feb 16 Javascript
jQuery实现动态添加、删除按钮及input输入框的方法
Apr 27 jQuery
vue2.0设置proxyTable使用axios进行跨域请求的方法
Oct 19 Javascript
vue--点击当前增加class,其他删除class的方法
Sep 15 Javascript
vue elementUI批量上传文件
Apr 26 Vue.js
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
《Re:从零开始的异世界生活 冰结之绊》
2020/04/09 日漫
php cache类代码(php数据缓存类)
2010/04/15 PHP
微信支付的开发流程详解
2016/09/13 PHP
Nginx环境下PHP flush失效的解决方法
2016/10/19 PHP
PHP生成word文档的三种实现方式
2016/11/14 PHP
JavaScript中数组对象的那些自带方法介绍
2013/03/12 Javascript
IE 下Enter提交表单存在重复提交问题的解决方法
2014/05/04 Javascript
把文本中的URL地址转换为可点击链接的JavaScript、PHP自定义函数
2014/07/29 Javascript
js实现图片漂浮效果的方法
2015/03/02 Javascript
详解addEventListener的三个参数之useCapture
2015/03/16 Javascript
js中日期的加减法
2015/05/06 Javascript
javascript常用函数(1)
2015/11/04 Javascript
详解js中构造流程图的核心技术JsPlumb(2)
2015/12/08 Javascript
Javascript实现图片不间断滚动的代码
2016/06/22 Javascript
如何利用JSHint减少JavaScript的错误
2016/08/23 Javascript
JavaScript制作简易计算器(不用eval)
2017/02/05 Javascript
JavaScript实现父子dom同时绑定两个点击事件,一个用捕获,一个用冒泡时执行顺序的方法
2017/03/30 Javascript
Vue项目中如何引入icon图标
2018/03/28 Javascript
微信小程序实现两边小中间大的轮播效果的示例代码
2018/12/07 Javascript
js正则匹配多个全部数据问题
2019/12/20 Javascript
JavaScript实现拖动对话框效果的实现代码
2020/10/12 Javascript
python 定时器,实现每天凌晨3点执行的方法
2019/02/20 Python
PYTHON绘制雷达图代码实例
2019/10/15 Python
Python语法之精妙的十个知识点(装B语法)
2020/01/18 Python
Python selenium如何打包静态网页并下载
2020/08/12 Python
Python项目实战之使用Django框架实现支付宝付款功能
2021/02/23 Python
CSS3属性 line-clamp控制文本行数的使用
2020/03/19 HTML / CSS
详解canvas绘制网络字体几种方法
2019/08/27 HTML / CSS
医院护士求职自荐信格式
2013/09/21 职场文书
办公室主任职责范文
2013/11/08 职场文书
房地产财务管理制度
2014/02/02 职场文书
教师工作总结范文2014
2014/11/10 职场文书
新生入学欢迎词
2015/01/26 职场文书
员工辞职信怎么写
2015/02/27 职场文书
法学专业求职信范文
2015/03/19 职场文书
用Python实现Newton插值法
2021/04/17 Python