学习YUI.Ext 第二天


Posted in Javascript onMarch 10, 2007

遇到一些JS的语法上的问题,没有理解透,恶补基本功!

 

匿名函数 An anonymous function

没有名字的就叫作“匿名函数”,像这个

function(x,y){return x+y}

没有名字当然不能直接调用,也无法调用;最多能只能把它赋值或闭包处理(闭包是什么下面再讲),如:

var sum =function(x,y){return x+y};

alert(sum(1,2));

这时候,与传统写法是等价的 function sum(x,y){return x+y}.这样的写法让人感觉更OOP,因为sum变量就包含了function...这个函数体;

还可以闭包的方式调用该函数:

(functioin(x,y){return x+y})(1,2) //返回值3

代码很简洁。注意括号的使用,形式为(exp)()。这种用法可以称作 闭包closure。
后面括号的是参数,把这些参数放进fn里面立即计算,得出一个值 3。这实际上是一个表达式的运算。没想到fn函数体也可以放进去参与运算^_^(Using function as an expression)!(基本功:表达式Expression,其含义是通过计算后,始终会返回一个值,无论这个表达式有多长)

fn还可以以参数形式传递(passing function as argument to other functions)

var main_fn = function(fn,x,y){return fn(x,y)}

var sum = function (x,y){
   return x+y;
}

alert(main_fn(sum,1,2)) // result:3

总结一下(by an IBM Engineer's article, refer to IBM website,最好用心记一记)

Functions need not have names all the time.

Functions can be assigned to variables like other values.

A function expression can be written and enclosed in parenetheses for application later.

Functions can be passed as arguments to oher funcitons.

再谈闭包,闭包的作用是形成一个定义域,举一个很白痴的例子 1+(2+3),括号部分优先运算,或者换个说法,括号里面的归为一个范围,这个范围我不理你做什么事情都是你里面做的事情,与括号外界无关(好像是废话,--我是这样想的,就是这样写的@#@),程序上的理解也是这样。js有函数定义域function scope,因此,当使用this指向一个对象出现问题的时候,可考虑使用闭包。具体例子在:http://www.svendtofte.com/code/practical_functional_js/

Javascript 相关文章推荐
客户端js性能优化小技巧整理
Nov 05 Javascript
js禁止页面刷新与后退的方法
Jun 08 Javascript
javascript实现下班倒计时效果的方法(可桌面通知)
Jul 10 Javascript
纯js实现瀑布流布局及ajax动态新增数据
Apr 07 Javascript
设计模式中的组合模式在JavaScript程序构建中的使用
May 18 Javascript
JS提示:Uncaught SyntaxError: Unexpected token ILLEGAL错误的解决方法
Aug 19 Javascript
js控制div层的叠加简单方法
Oct 15 Javascript
jQuery Chosen通用初始化
Mar 07 Javascript
Vue高版本中一些新特性的使用详解
Sep 25 Javascript
浅谈js中的bind
Mar 18 Javascript
vue实现todolist功能、todolist组件拆分及todolist的删除功能
Apr 11 Javascript
基于node+websocket+html实现腾讯课堂聊天室聊天功能
Mar 04 Javascript
学习YUI.Ext基础第一天
Mar 10 #Javascript
JavaScript触发器详解
Mar 10 #Javascript
又一个图片自动缩小的JS代码
Mar 10 #Javascript
基础的prototype.js常用函数及其用法
Mar 10 #Javascript
优秀js开源框架-jQuery使用手册(1)
Mar 10 #Javascript
用JavaScript实现仿Windows关机效果
Mar 10 #Javascript
Javascript中的Split使用方法与技巧
Mar 09 #Javascript
You might like
PHP出错界面
2006/10/09 PHP
PHP 将图片按创建时间进行分类存储的实现代码
2010/01/05 PHP
php实现文件下载代码分享
2014/08/19 PHP
WordPress主题制作中自定义头部的相关PHP函数解析
2016/01/08 PHP
PHP实现微信网页授权开发教程
2016/01/19 PHP
Yii2框架实现注册和登录教程
2016/09/30 PHP
PHP 实现人民币小写转换成大写的方法及大小写转换函数
2017/11/17 PHP
PHP全局使用Laravel辅助函数dd
2019/12/26 PHP
location.href 在IE6中不跳转的解决方法与推荐使用代码
2010/07/08 Javascript
js 替换功能函数,用正则表达式解决,js的全部替换
2010/12/08 Javascript
JavaScript prototype属性深入介绍
2012/11/27 Javascript
关于jQuery $.isNumeric vs. $.isNaN vs. isNaN
2013/04/15 Javascript
js数组操作常用方法
2014/05/08 Javascript
完美兼容IE,chrome,ff的设为首页、加入收藏及保存到桌面js代码
2014/12/17 Javascript
使用jQuery的load方法设计动态加载及解决被加载页面js失效问题
2017/03/01 Javascript
微信小程序实现滚动消息通知
2018/02/02 Javascript
vue刷新页面时去闪烁提升用户体验效果的实现方法
2018/12/10 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
2019/02/18 Javascript
JavaScript如何获取一个元素的样式信息
2019/07/29 Javascript
ElementUI radio组件选中小改造
2019/08/12 Javascript
vue递归组件实战之简单树形控件实例代码
2019/08/27 Javascript
Vuejs中的watch实例详解(监听者)
2020/01/05 Javascript
python装饰器使用方法实例
2013/11/21 Python
解析Python中的生成器及其与迭代器的差异
2016/06/20 Python
pycharm 解除默认unittest模式的方法
2018/11/30 Python
python 解决flask uwsgi 获取不到全局变量的问题
2019/12/22 Python
Python 实现平台类游戏添加跳跃功能
2020/03/27 Python
Pygame框架实现飞机大战
2020/08/07 Python
T3官网:头发造型工具
2019/12/26 全球购物
自我鉴定模板
2013/10/29 职场文书
暑期社会实践学生的自我评价
2014/01/09 职场文书
党的生日演讲稿
2014/09/10 职场文书
合伙购房协议样本
2014/10/06 职场文书
2015年社区党建工作汇报材料
2015/06/25 职场文书
OpenCV绘制圆端矩形的示例代码
2021/08/30 Python
Matplotlib绘制条形图的方法你知道吗
2022/03/21 Python