javascript学习笔记(七) js函数介绍
更新时间:2012年06月19日 23:06:23 作者:
javascript学习笔记之js函数介绍,需要的朋友可以参考下
1.函数内部属性 arguments
arguments用来保存函数的参数,arguments.callee指向拥有arguments对象的函数
//阶乘
function factorial(num) {
if (num <= 1) {
return 1;
} else {
return num*arguments.callee(num-1); //用agreements.callee代替
}
}
var trueFactorial = factorial;
factorial = function {
return 0;
}
alert(trueFactorial(5)); //20
alert(factorial(5)); //0
2.函数的属性和方法
length属性,表示函数参数的个数
3. apply()和call()方法
apply()和call()方法的作用是传递参数或扩充函数的作用域
//传递参数
function sum(num1,num2) {
return num1+num2;
}
function callSum(num1,num2) {
return sum.call(this,num1,num2); //第一个参数this,后面列举所有参数
}
alert(callSum(10,10)); //20
function calSum1(num1,num2) {
return sum.apply(this,arguments); //第一个参数this,第二个参数arguments
}
function calSum2(num1,num2) {
return sum.apply(this,[num1,num2]); //第一个参数this,第二个参数是参数数组
}
alert(callSum1(10,10)); //20
alert(callSum2(10,10)); //20
//改变函数作用域
window.color = "red";
var o = { color:"blue"};
function sayColor() {
alert(this.color);
}
sayColor(); //red
sayColor.call(this); //red
sayColor.call(window);//red
sayColor.call(o); //blue
arguments用来保存函数的参数,arguments.callee指向拥有arguments对象的函数
复制代码 代码如下:
//阶乘
function factorial(num) {
if (num <= 1) {
return 1;
} else {
return num*arguments.callee(num-1); //用agreements.callee代替
}
}
var trueFactorial = factorial;
factorial = function {
return 0;
}
alert(trueFactorial(5)); //20
alert(factorial(5)); //0
2.函数的属性和方法
length属性,表示函数参数的个数
3. apply()和call()方法
apply()和call()方法的作用是传递参数或扩充函数的作用域
复制代码 代码如下:
//传递参数
function sum(num1,num2) {
return num1+num2;
}
function callSum(num1,num2) {
return sum.call(this,num1,num2); //第一个参数this,后面列举所有参数
}
alert(callSum(10,10)); //20
function calSum1(num1,num2) {
return sum.apply(this,arguments); //第一个参数this,第二个参数arguments
}
function calSum2(num1,num2) {
return sum.apply(this,[num1,num2]); //第一个参数this,第二个参数是参数数组
}
alert(callSum1(10,10)); //20
alert(callSum2(10,10)); //20
复制代码 代码如下:
//改变函数作用域
window.color = "red";
var o = { color:"blue"};
function sayColor() {
alert(this.color);
}
sayColor(); //red
sayColor.call(this); //red
sayColor.call(window);//red
sayColor.call(o); //blue
您可能感兴趣的文章:
- javascript学习笔记(十九) 节点的操作实现代码
- javascript学习笔记(十八) 获得页面中的元素代码
- javascript学习笔记(十七) 检测浏览器插件代码
- javascript学习笔记(十六) 系统对话框(alert、confirm、prompt)
- javascript学习笔记(十五) js间歇调用和超时调用
- javascript学习笔记(十四) window对象使用介绍
- javascript学习笔记(十三) js闭包介绍(转)
- javascript学习笔记(十二) RegExp类型介绍
- javascript学习笔记(十一) 正则表达式介绍
- javascript学习笔记(十) js对象 继承
- javascript学习笔记(九) js对象 设计模式
- javascript学习笔记(八) js内置对象
- javascript学习笔记(六) Date 日期类型
- javascript学习笔记(五) Array 数组类型介绍
- javascript学习笔记(四) Number 数字类型
- javascript学习笔记(三) String 字符串类型介绍
- javascript学习笔记(二) js一些基本概念
- javascript学习笔记(一) 在html中使用javascript
- javascript学习笔记(二十) 获得和设置元素的特性(属性)
相关文章
JavaScript高级程序设计(第3版)学习笔记2 js基础语法
这一篇复习一下ECMAScript规范中的基础语法,英文好的朋友可以直接阅读官方文档。JavaScript本质上也是一种类C语言,熟悉C语言的朋友,可以非常轻松的阅读这篇文章,甚至都可以跳过,不过建议你最好还是看一看,在介绍的同时,我可能会引用一些自认为不易理解且比较流行的用法。2012-10-10
JavaScript高级程序设计(第3版)学习笔记4 js运算符和操作符
如果说数据类型是编程语言的砖瓦,那么运算符和操作符则是编程语言的石灰和水泥了,它是将各种数据类型的值有机组合的糅合剂,使得数据值不再只是一个孤立的值,而有了一种动态的灵性2012-10-10
JavaScript italics方法入门实例(把字符串显示为斜体)
这篇文章主要介绍了JavaScript italics方法入门实例,italics方法用于把字符串显示为斜体,需要的朋友可以参考下2014-10-10
javascript学习笔记(九)javascript中的原型(prototype)及原型链的继承方式
在javascript学习笔记(八)中,我们主要学习了在使用javascript面向对象编程时,如何创建对象及添加对象的属性和方法。2011-04-04


最新评论