javascript 的一些特性--函数
来源:互联网 发布:行业分析知乎 编辑:程序博客网 时间:2024/04/29 13:00
本文转载自:http://software.intel.com/zh-cn/articles/javascript-first-class-citizen-function/?cid=sw:prccsdn229032.用于读书笔记.
简介
一、JavaScript函数入门级
// 直接声明函数myfunc
function myfunc(/* arguments */) {
}
// 把匿名函数赋值给本地变量myfunc
var myfunc = function(/* arguments */) {
}
注意,上面两种函数声明方式存在细微的差别:第一种方式在声明时就是一个命名的函数,无论是声明在调用之前、调用之后,甚至是不会执行到的位置(例如return语句之后或是永远不会为真的分支里),都在整个作用域可访问;第二种方式是通过把匿名函数赋值给变量的方式,严格意义上说这不是一个函数的声明(function declaration)而是一个函数表达式(function expression),在赋值之前这个函数不能被任何代码访问到,也就是说这个赋值必须在调用之前完成,否则调用时会出现错误:"TypeError: undefined is not a function"。例如:
myfunc1(); // 能够正常调用,因为myfunc1采用直接声明的方式
function myfunc1() {
}
myfunc2(); // 出错 TypeError: undefined is not a function
var myfunc2 = function() {
};
函数的基本调用方式与传统语言相同用一对括号调用: myfunc()。JavaScript的函数也支持直接或间接的递归(recursive)调用,例如经典的斐波那契函数用JavaScript可以这样实现:
function fib(n) {
if (n == 1 || n == 2) {
return 1;
} else {
return fib(n - 2) + fib(n - 1);
}
}
function negative(n) {
return -n; // 取n的相反值
}
function square(n) {
return n*n; // n的平方
}
function process(nums, callback) {
var result = [];
for(var i = 0, length = nums.length; i < length; i++) {
result[i] = callback(nums[i]); // 对数组nums中的所有元素传递给callback进行处理,将返回值作为结果保存
}
return result;
}
var nums = [-3, -2, -1, 0, 1, 2, 3, 4];
var n_neg = process(nums, negative);
// n_neg = [3, 2, 1, 0, -1, -2, -3, -4];
var n_square = process(nums, square);
// n_square = [9, 4, 1, 0, 1, 4, 9, 16];
以上代码展示了把函数作为参数传入另一个函数process调用的示例,在process函数的实现中,把callback作为一个黑盒子看待,负责把参数传给它,然后获取返回值,在调用之前并不清楚callback的具体实现。只有当执行到20行和22行时,callback才被分别代表negative或square,分别对每个元素进行取相反值或平方值的操作。
function generator() {
var i = 0;
return function() {
return i++;
};
}
var gen1 = generator(); // 得到一个自然数生成器
var gen2 = generator(); // 得到另一个自然数生成器
var r1 = gen1(); // r1 = 0
var r2 = gen1(); // r2 = 1
var r3 = gen2(); // r3 = 0
var r4 = gen2(); // r4 = 1
上面的代码展示了把函数作为返回值的示例,generator是一个自然数生成器函数,返回值是一个自然数生成函数。每次调用generator时都会把一个匿名函数作为结果返回,这个匿名函数在被实际调用时依次返回每个自然数。在generator里的变量i在每次调用这个匿名函数时都会自增1,这其实就是一个闭包。下面我们来介绍一下闭包.
var elem = document.getElementById('test');
elem.addEventListener('click', function() {
alert('You clicked ' + elem.tagName);
});
这段代码的作用是点击一个结点时显示它的标签名称,它把一个匿名函数注册为一个DOM结点的click事件处理函数,函数内引用了一个DOM对象elem,就形成了闭包。这就会产生一个循环引用,即:DOM->闭包->DOM->闭包...DOM对象在闭包释放之前不会被释放;而闭包作为DOM对象的事件处理函数存在,所以在DOM对象释放前闭包不会释放,即使DOM对象在DOM tree中删除,由于这个循环引用的存在,DOM对象和闭包都不会被释放。可以用下面的方法可以避免这种内存泄露:
var elem = document.getElementById('test');
elem.addEventListener('click', function() {
alert('You clicked ' + this.tagName); // 不再直接引用elem变量
});
闭包还会带来很多类似的内存泄露问题,只有在写代码的时候着重注意一下闭包,尽量避免此类的问题产生。
- function Person(name) {
- this.name = name;
- this.toString = function() {
- return 'Hello, ' +this.name + '!';
- };
- }
- var p = new Person('Ghostheaven');
- alert(p); // Hello, Ghostheaven!
- function MyClass(name) {
- this.name = name;
- return name; // 构造函数的返回值?
- }
- var obj1 = new MyClass('foo');
- var obj2 = MyClass('foo');
- var obj3 = new MyClass({});
- var obj4 = MyClass({});
- obj1 = MyClass对象
- obj2 = 'foo'
- obj3 = {}
- obj4 = {}
三、JavaScript函数妖怪级
- new Function ([arg1[, arg2[, ... argN]],] functionBody)
- var func1 = new Function('name','return "Hello, " + name + "!";');
- func1('Ghostheaven'); // Hello, Ghostheaven!
- function selfUpdate() {
- window.selfUpdate = function() {
- alert('second run!');
- };
- alert('first run!');
- }
- selfUpdate(); // first run!
- selfUpdate(); // second run!
- javascript 的一些特性--函数
- javascript的一些特性
- 虚函数的一些特性
- 虚函数的一些特性
- python的一些函数特性
- JavaScript的函数式特性
- 一些蛋疼的JavaScript语法特性
- Python3的一些特性、函数分析
- 关于fork()函数特性的一些探究
- javascript的一些小函数
- javascript的一些倒计时函数
- JavaScript的一些基本知识 -- 函数
- JavaScript笔记;函数的基本特性
- javascript 中的函数,特性
- Nodejs学习中一些javascript特性的总结
- javascript数据类型(以及它们的一些特性与判断)
- javascript的替换一些符号的函数
- 一些常用的javascript函数(方法)
- 如何给JavaScript添加一个自定义对象
- cocos2d的常用动作及效果总结之三:Ease actions
- zen cart 关于页面 title
- 杭电ACM 2032 杨辉三角
- cocos2d的常用动作及效果总结之四:Special Actions
- javascript 的一些特性--函数
- style="visibility: hidden"和 style=“display:none”区别
- MVC与三层架构区别
- hdu 2458 Kindergarten (最大独立集)
- Android定制出厂默认输入法
- LNMP架设 (备忘录)
- Ubuntu 配置 Apache
- Qt中拖拽窗口以改变位置的实现
- Android中Intent的setData,setType和setDataAndType的用法