javascript学习笔记五:javascript中的回调函数
2014-03-01 14:49
330 查看
18.javascript中的回调模式:
形如:
我们不能直接在findNodes中对查询到的节点进行隐藏(这样检索就可修改逻辑耦合了),那么他就不再是一个通用函数了。
解决方法是用回调模式,可以将节点隐藏逻辑以回调函数方式传递给findNodes()并委托其执行
findNodes(hide);//先执行findNodes然后执行hide,当然回调函数也可以在调用主函数时创建:findNodes(function(node){node.style.display = 'none';});
形如:
function writeCode(callback){ //执行一些事物, callback(); //... } function intrduceBugs(){ //....引入漏洞 } writeCode(intrduceBugs); 我们传递函数的应用给writeCode(),让writeCode在适当的时候来执行它(返回以后调用)先看一个不怎么好的例子(后续要对其重构):
//模拟查找页面中的dom节点,将查找到的节点存在数组里面统一返回 //此函数只用于查找不对dom节点做任何的逻辑处理 var findNodes = function(){ var i = 100000;//大量的循环, var nodes = [];//用于存储找到的dom节点 var found; while(i){ i -=1; nodes.push(found); } return nodes; } //将查找找到的dom节点全部隐藏 var hide = function(nodes){ var i = 0, max = nodes.lenght; for(;i<max;i++){ nodes[i].style.display = 'none'; } } //执行函数 hide(findNodes());//findNodes后面有括号代表立即执行,先执行findNodes()然后执行hide()上面的方法是低效的,以为hide()必须再次遍历有findNodes()返回的数组节点,如何避免这种多余的循环呢。
我们不能直接在findNodes中对查询到的节点进行隐藏(这样检索就可修改逻辑耦合了),那么他就不再是一个通用函数了。
解决方法是用回调模式,可以将节点隐藏逻辑以回调函数方式传递给findNodes()并委托其执行
//重构findNodes以接受一个回调函数 var findNodes = fucntion(callback){ var i = 100000, nodes = [], found; //检查回调函数是否可用调用的 if(typeof callback !== 'function'){ callback = false; } while(i){ i -= 1; if(callback){ callback(found); } nodes.push(found); } return nodes; } //回调函数 var hide = function(node){ node.style.display = 'none '; } //找到后续节点并在后续执行中对其进行隐藏
findNodes(hide);//先执行findNodes然后执行hide,当然回调函数也可以在调用主函数时创建:findNodes(function(node){node.style.display = 'none';});
相关文章推荐
- javascript学习笔记四:javascript中的函数(对象)
- javascript学习笔记三:javascript基本数据类型+正则表达式+异常处理
- javascript学习笔记二:javascript中的数组对象和json对象
- javascript学习笔记一:javascript原型+对象字面量等
- 《JavaScript DOM编程艺术》学习笔记<一>
- JavaScript跨域总结与解决办法
- C#代码与javaScript函数的相互调用
- JSON资料整理
- (9)javascript 引用类型 Array类型
- Servlet的生命周期,并说出Servlet和CGI的区别,Servlet与JSP的区别
- extjs官网+extjs官网案例
- JSON资料整理
- ExtJS 案例
- 『ExtJS』表单(一)常用表单控件及内置验证
- Extjs中三种不同的数据提交方式
- ExtJs 备忘录(4)—— Form表单(四) [ 数据提交 ]
- ExtJs 备忘录(3)—— Form表单(三) [ 数据验证 ]
- ExtJs 备忘录(2)—— Form表单(二) [ 控件封装 ]
- ExtJs 备忘录(1)—— Form表单(一) [ 控件使用 ]
- 初学js正则表达式之密码强度验证