/*
var pattern = /^[\w]+\.(zip|rar|gz)$/; //|选择符必须用分组符号包含起来
var str = '123.7z';
alert(pattern.test(str)); function box(num1, num2) { //普通函数的声明方式
return num1 + num2;
} alert(box(1, 2)); var box = function(num1, num2) { //使用变量初始化函数
return num1 + num2;
}; alert(box(1,2)); var box = new Function('num1', 'num2', 'return num1 + num2'); //使用new的构造函数来声明函数
alert(box(1, 2));
alert(typeof box); //函数可以传递函数, //下面的例子很普通,不是作为函数来传递的,而是作为函数的返回值来传递的 function box(sum, num) {
return sum + num;
} function sum(num) {
return num + 10;
} var result = box(sum(10), 10); //20,10sum(10)这里传递的是函数的返回值,和普通的变量一样,没区别
alert(result); */ //要把函数本身作为参数传递,而不是函数的结果 function box(sum, num) {
return sum(num);
} function sum(num) {
return num + 10;
} var result = box(sum, 10); //这里sum是一个函数,当作参数传递到另外一个函数里,而不是函数的返回值
alert(result);
/*
function sum(num) {
if (num <= 1) {
return 1;
} else {
return num * sum(num-1); //4 * 3 * 2 * 1 = 24 阶乘,递归
}
} alert(sum(4)); function box(num) {
if (num <= 1) {
return 1;
} else {
return num * arguments.callee(num-1); //使用arguments.callee,调用自身,实现递归
}
} alert(box(4)); //window是一个对象,而且是JS里面最大的对象,是最外围的对象 //alert(typeof window); window是对象,类型是对象,window表示全局 alert(this); //[object Window] this目前表示的是window,因为在window的范围下
alert(typeof this); //和window一模一样,所以this就是window var color = '红色的'; //这里color就是全局变量,而这个变量又是window的属性
//alert(window.color); //这里已经很好的说明color是window下的属性
alert(this.color); //同上 window.color = '红色的'; //相当于 var color = '红色的';???,是一样的 var box = {
color : '蓝色的', //这里的color是box下的属性,也就是局部变量
sayColor : function() {
alert(this.color); //这里this,我们确定了是代表的box对象。
}
}; alert(this.color);
box.sayColor(); window.color = '红色的'; function sayColor() {
alert(this.color); //所以这里执行的时候是动态的,第一次在window下,第二次在box下
} sayColor(); //这里调用sayColor,其实范围还是在window下 var box = {
color : '蓝色的'
}; box.sayColor = sayColor; //这段代码相当于47行 box.sayColor(); //这里执行的是box里面的this.color function box(name, age) {
return name + age;
} alert(box.length); function box(num1, num2) {
return num1 + num2;
} function sum(num1, num2) { //apply和call可以冒充另外一个函数
return box.apply(this, [num1, num2]); //this表示window作用域,[]表示传递的参数
} function sum2(num1, num2) {
return box.apply(this, arguments); //这个可以当数组传递,arguments
} //alert(box(10,10)); //alert(sum(10,10));
alert(sum2(10,10)); function box(num1, num2) {
return num1 + num2;
} function sum(num1, num2) {
return box.call(this, num1, num2); //call只是传递参数不同,其他和apply一样
} alert(sum(10,10));
*/ var color = '红色的'; //全局 var box = {
color : '蓝色的' //局部
}; function sayColor() {
alert(this.color);
} //sayColor(); //全局 //用call是实现对象冒充,冒充box下,冒充window下
//sayColor.call(window); //冒充window 红色的
//sayColor.call(this); //this就是window
sayColor.call(box); //冒充box,作用域就在box对象里面,所以color就是蓝色的

Function对象属性和方法的更多相关文章

  1. Javascript对象属性与方法汇总

    Javascript对象属性与方法汇总 发布时间:2015-03-06 编辑:www.jquerycn.cn 详细介绍下,javascript对象属性与对象方法的相关知识,包括javascript字符 ...

  2. js object 对象 属性和方法的使用

    //object 对象 属性和方法的使用 var person = new Object(); person.name="张海"; person.age="; perso ...

  3. 转: JavaScript 获取对象属性和方法

    一.获取对象属性和方法 Object.keys()for in 返回对象的可枚举属性和方法的名称数组. Object.getOwnPropertyNames() 返回的数组的所有属性(可枚举或不可枚举 ...

  4. Js基础知识7-JavaScript所有内置对象属性和方法汇总

    对象什么的,程序员可是有很多呢... JS三大对象 对象,是任何一个开发者都无法绕开和逃避的话题,她似乎有些深不可测,但如此伟大和巧妙的存在,一定值得你去摸索.发现.征服. 我们都知道,JavaScr ...

  5. JavaScript 获取对象属性和方法

    ShineJaie 原创整理,转载请注明出处. 一.获取对象属性和方法 Object.keys() 返回对象的可枚举属性和方法的名称数组. Object.getOwnPropertyNames() 返 ...

  6. JavaScript 访问对象属性和方法及区别

    这篇文章主要介绍了浅析JavaScript访问对象属性和方法及区别的相关资料,仅供参考 属性是一个变量,用来表示一个对象的特征,如颜色.大小.重量等:方法是一个函数,用来表示对象的操作,如奔跑.呼吸. ...

  7. getSelection、range 对象属性,方法理解,解释

    网上转了一圈发现没有selection方面的解释,自己捣鼓下 以这段文字为例子.. <p><b>法国国营铁路公司(SNCF)20日承认,</b>新订购的2000列火 ...

  8. ES6之6种遍历对象属性的方法

    ES6之6种遍历对象属性的方法 for ... in 循环遍历对象自身的和继承的可枚举属性(不含Symbol属性). Obejct.keys(obj),返回一个数组,包括对象自身的(不含继承的)所有可 ...

  9. JS枚举对象属性的方法及其区别

    愉快的中秋节要过去了,国庆倒计时两个周!!! 闲话不多说,那今天我们来看一看JS中枚举对象属性的方法有哪些以及他们的区别 首先在JS里面枚举对象属性一共有三种方法 for in: 会遍历对象中所有的可 ...

随机推荐

  1. SLAM学习笔记(1)基本概念

    SLAM (simultaneous localization and mapping),也称为CML (Concurrent Mapping and Localization), 即时定位与地图构建 ...

  2. 使用Proj.Net创建空间参考

    在RGEOS项目中,投影变换是通过Proj.Net来实现的. 支持的投影主要包括AlbersProjection.TransverseMercator.Mercator.Krovak.Lambert ...

  3. 图像处理之泛洪填充算法(Flood Fill Algorithm)

    泛洪填充算法(Flood Fill Algorithm) 泛洪填充算法又称洪水填充算法是在很多图形绘制软件中常用的填充算法,最熟悉不过就是 windows paint的油漆桶功能.算法的原理很简单,就 ...

  4. mac osx 启动wireshark闪退

    wireshark启动会提示安装x11 去x11地址安装后 启动还是闪退 原来是姿势不对 这样才行~~ 这一步 这个路径一定要对!路径一定要对!路径一定要对! 然后报错不用管它,如果没反应了,就继续等 ...

  5. 从零开始攻略PHP(4)——数组的使用

    1.数组的概念 数组就是一个用来存储一系列变量值的命名区域. 每个数组元素有一个相关的索引(也成为关键字),它可以用来访问元素. PHP允许间隔性地使用数字或字符串作为数组的索引. 2.数字索引数组 ...

  6. 《数据结构与算法分析:C语言描述_原书第二版》CH3表、栈和队列_reading notes

    表.栈和队列是最简单和最基本的三种数据结构.基本上,每一个有意义的程序都将明晰地至少使用一种这样的数据结构,比如栈在程序中总是要间接地用到,不管你在程序中是否做了声明. 本章学习重点: 理解抽象数据类 ...

  7. 0428—Scrum团队成立及《构建之法》第六、七章读后感

    5.Scrum团队成立 5.1 团队名称:喳喳 团队目标:突破渣渣 团队口号:吱吱喳喳 团队照: 5.2 角色分配 产品负责人: 112冯婉莹 Scrum Master:109张鑫相 PM项目经理:1 ...

  8. JavaScript内的类型转换

    JavaScript内的类型转换 1.分为自动转换和强制转换,我们一般用强制转换.其他类型转换为整数是parseInt();其他类型转化为小数parseFloat(); 2.判断是不是一个合法数字   ...

  9. C#面向对象的方法写数组的功能

    上一篇文章用Java方法写出了可以对数组执行的功能,然后在用实例化后的对象调用这些方法来实现这些功能: 这篇随笔改用C#语言实现同样的功能 方法类:Array using System; using ...

  10. How to wipe silicon to CPU 如何给CPU正确涂抹硅脂

    随 着计算机性能的提升,CPU的功耗也在不断的增大,虽然现在由于改进了工艺使得在功耗方面得到了一定的缓解,但由于近年来显卡性能的不断增强,也开始走上 了CPU功耗性能成正比的老路,功耗依然还是一个值得 ...