1.函数调用的四种方式
第三种:构造函数调用
如果构造函数调用在圆括号内包含一组实参列表,先计算这些实参表达式,然后传入函数内。这和函数调用和方法调用是一致的。但如果构造函数没有形参,JavaScript构造函数调用的语法是允许省略实参列表和圆括号的。
如:
var o=new Object();
//->等价于
var o=new Object;
 
第四种:使用call()与apply()间接调用(放在后面详细说明)
 
2.函数的实参与形参——可选形参
先看一个例子:
function getA(o,/*optional*/ a){
if(a===undefined){
a=[];
}
for(var pro in o){
a.push(pro);
}
}
上面这个函数调用可以传入一个参数,或者两个参数。
a:一般会在可选形参的前面加上/*optional*,来强调形参是可选的。
b:还有一般将可选参数放在参数列表的最后。
c:如果可选形参不传入实参的话,该参数就会被默认为undefined。
d:当然了,你也可以参入null或undefined作为占位符。
 
3.可变长的实参列表:实参对象(arguments,在全局环境中并不存在的对象)
有时候我们调用函数时,传递的参数超过函数定义的个数时,没有办法直接获得未命名值得引用。
虽然JavaScript的默认行为会把多出的参数自动省略。
但是我们有时候就是需要获得这些个多出的参数,那咋办?(是不是有点贱?- -)
这时钢铁侠就来了!额!不!是实参对象就来解决这个问题了。
在函数体内,arguments就是指向实参对象的引用。
只有函数被调用时,arguments对象才会创建,未调用时其值为null。
arguments.length是实参长度,arguments.callee.length是形参长度。
 
实参对象是一个类数组对象。这样就可以通过下标来访问了,而不需要通过名字来访问。
duang~
来个例子:
function a(x,y){
return x*y;
}
//调用
a('10','10','11');
 
11默认省略,如果我们想获得它,可以把上面的例子改下:
 
function a(x,y){
if(arguments.length!=2){
return x*y;
}else if(arguments.length>2){
return arguments[2]; //这里的arguments[2]就是11了
}
}
 
实参对象有一个重要的用处,就是让函数可以操作任务数量的实参。
例如:
function max(/*...*/){
var max=Number.NEGATIVE_INFINITY;
for(var i=0;i<arguments.length;i++){ if(arguments[i]>max){
max=arguments[i];
}
}
return max;
} var l=max(1,2,3);
alert(l)
 
4.JavaScript中,函数不仅作为一种语法,可以定义可以调用。也是值。
下面来看一个函数定义:
function squ(x){
return x*x;
}
 
理解:这个定义创建一个新的函数对象,并将其赋值给变量squ。
函数的名字实际上是看不见的,它(squ)仅仅是变量的名字,这个边变量指代函数对象。函数还可以赋值给其他的变量,并且仍可以正常工作。
 
var s=squ;    //这里的s与squ指代同一个函数
squ(4); //
s(4); //
 
同样可以将函数赋值给对象的属性。
 
var o={
squ:function(x){
return x*x;
}
}
var y=o.squ(4); //
 
之前在JavaScript权威设计--JavaScript类型,值,变量(简要学习笔记四)最后中说的这个例子就是这样:
var a=1;
function b(){
a=2;
return;
function a(){}
}
//调用
b();
console.log(a) //a=1

正如上面所说函数也是值!function a(){}这函数的名字并不是a,实际上这个函数的名字是看不见的。a仅仅只是变量的名字!指代后面的函数对象。同样你可以给a赋其他值,

a=3等等。当然了这是理解a=1的一个要点,另外一个要点是JavaScript的编译与执行。

JavaScript函数的执行分为编译与执行。先编译后执行。

这里调用b()属于后面的执行期。执行的时候遇到函数内部的a变量。这个a也就是指代function a(){}。编译时,编译到a=2时候,a是全局变量,这时候a=2.继续往下编译,编译至function a(){}时,a称为局部变量a,a=1。大家不要被这里的return吓着,认为下面不会编译,立即返回。这里的return其实只是在执行的时候才会返回。跟编译没有关系。编译的时候已经挂在了作用域链上了。这时在函数内部执行,这里的a。其实上面的函数也即等效于:

var a=1;
function b(){
var a=2; }
//调用
b();
console.log(a) //a=1

也等效于:

var a=1;
function b(){
//a=2;
//return;
var a=function (){}
a=2;
}
//调用
b();
alert(a)

JavaScript权威设计--JavaScript函数(简要学习笔记十一)的更多相关文章

  1. JavaScript权威设计--事件处理介绍(简要学习笔记十七)

    1.事件相关概念 事件类型:一个用来说明发生什么类型事件的字符串 事件目标:是发生的事件或与之相关的对象. 事件处理程序(事件监听程序):是处理货响应事件的函数. 事件对象:是与特定事件相关并且包含有 ...

  2. JavaScript权威设计--Window对象(简要学习笔记十三)

    1.Window对象是所有客户端JavaScript特性和API的主要接入点. Window对象中的一个重要属性是document,它引用Document对象. JavaScript程序可以通过Doc ...

  3. JavaScript权威设计--JavaScript函数(简要学习笔记十)

    1.函数命名规范 函数命名通常以动词为前缀的词组.通常第一个字符小写.当包含多个单词时,一种约定是将单词以下划线分割,就像"like_Zqz()". 还有一种就是"lik ...

  4. javascript权威指南第6版学习笔记

    javascript权威指南第6版学习笔记 javascript数组.函数是特殊对象 看一点少一点. 3.1.4 hello.js内容是 var x=.3-.2;var y=.2-.1 console ...

  5. JavaScript权威设计--JavaScript数组(简要学习笔记九)

    1.数组的创建 如: var a=[1.1,null,"a"]; var b=[1, ,3]; //中间的那个元素是undefined var c=[ , , ] 这里c.leng ...

  6. JavaScript权威设计--JavaScript对象(简要学习笔记七)

    1.with语句 语法: width(object){ statement } with语句可用于临时扩展作用域链.作用域链可以按序检索的对象列表,通过它可以进行变量名解析. with将object添 ...

  7. JavaScript权威设计--JavaScript表达式与运算符,语句(简要学习笔记六)

    1.delete是一元操作符,用来删除对象属性或者元素. var a={ x:1, y:2 } delete a.x; //删除x属性 “x”in a //false:a对象中已经不存在x属性 ale ...

  8. JavaScript权威设计--JavaScript脚本化文档Document与CSS(简要学习笔记十五)

    1.Document与Element和TEXT是Node的子类. Document:树形的根部节点 Element:HTML元素的节点 TEXT:文本节点   >>HtmlElement与 ...

  9. JavaScript权威设计--JavaScript表达式与运算符(简要学习笔记五)

    1.3种原始表达式     1.直接量:    1.23    //数字直接量                         “hello”    //字符串直接量                 ...

随机推荐

  1. Asp.net Boilerplate之AbpSession扩展

    当前Abp版本1.2,项目类型为MVC5. 以属性的形式扩展AbpSession,并在"记住我"后,下次自动登录也能获取到扩展属性的值,版权归"角落的白板报"所 ...

  2. [linux]阿里云主机的免登陆安全SSH配置与思考

    公司服务器使用的第三方云端服务,即阿里云,而本地需要经常去登录到服务器做相应的配置工作,鉴于此,每次登录都要使用密码是比较烦躁的,本着极速思想,我们需要配置我们的免登陆. 一 理论概述 SSH介绍 S ...

  3. ExtJS 4.2 业务开发(二)数据展示和查询

    本篇开始模拟一个船舶管理系统,提供查询.添加.修改船舶的功能,这里介绍其中的数据展示和查询功能. 目录 1. 数据展示 2. 数据查询 3. 在线演示 1. 数据展示 在这里我们将模拟一个船舶管理系统 ...

  4. javascript中的事件冒泡和事件捕获

    1.事件冒泡 IE 的事件流叫做事件冒泡(event bubbling),即事件开始时由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播到较为不具体的节点(文档).以下面的HTML ...

  5. C++随笔:.NET CoreCLR之GC探索(4)

    今天继续来 带大家讲解CoreCLR之GC,首先我们继续看这个GCSample,这篇文章是上一篇文章的继续,如果有不清楚的,还请翻到我写的上一篇随笔.下面我们继续: // Initialize fre ...

  6. Asp.net Core 初探(发布和部署Linux)

    前言 俗话说三天不学习,赶不上刘少奇.Asp.net Core更新这么长时间一直观望,周末帝都小雨,宅在家看了下Core Web App,顺便搭建了个HelloWorld环境来尝尝鲜,第一次看到.Ne ...

  7. MSYS2环境下编译X265

    HEVC(High Efficiency Video Coding),是一种新的视频压缩标准.可以替代H.264/ AVC编码,使得保持相同质量的情况下,体积减少40%左右.目前有多种实现版本,x26 ...

  8. H3 BPM让天下没有难用的流程之功能介绍

    H3 BPM10.0功能地图如下:  图:H3 BPM 功能地图 一.流程引擎 H3  BPM 流程引擎遵循WFMC 标准的工作流引擎技术,设计可运行的流程和表单,实现工作任务在人与人.人与系统.系统 ...

  9. mysql 大表拆分成csv导出

    最近公司有一个几千万行的大表需要按照城市的id字段拆分成不同的csv文件. 写了一个自动化的shell脚本 在/home/hdh 下面 linux-xud0:/home/hdh # lltotal 1 ...

  10. Linux下高cpu解决方案

    昨天搞定了一个十万火急的issue,客户抱怨产品升级后系统会变慢和CPU使用率相当高,客户脾气很大,声称不尽快解决这个问题就退货,弄得我们 R&D压力很大,解决这个issue的任务分给了我,客 ...