【函数的声明格式】
1.函数的声明格式:
function 函数名(参数1,参数2,...){
  函数体代码
  return 返回值;
}


函数的调用:
① 直接调用:函数名(参数1的值,参数2的值,....);
② 时间调用方式:直接在html标签中,使用事件名="函数名()"
<button ondblclick="saySth('哈哈哈','yellow')">点击按钮,打印内容</button>
2.函数的注意事项:
① 函数名必须符合小驼峰法则,(首字母小写,之后每个单词首字母大写)
② 函数名后面的()中,可以有参数,也可以没有参数,分别称为 有参函数 和 无参函数;
③ 声明函数时的参数列表,称为形参列表,形式参数。(变量的名字)
function saySth(str,color){}
调用函数是的参数列表,称为实参列表,实际参数。(变量的赋值)
saySth("hello!!!","red");

④ 函数的形参列表个数,与实参列表个数,没有实际关联关系。
函数参数的个数,取决于实参列表。
如果实参列表的个数<形参列表,则为赋值的形参,将为Undefind。
⑤ 函数可以有返回值,使用return返回结果。
调用函数时,可以使用一个变量接受函数的返回结果。如果函数没有返回值,则接受的结果为undefined;
function fun(){
  return "哈哈";
}
var num = func();   num="哈哈"
⑥ 函数中变量的作用域:
在函数中,使用var声明的变量,为局部变量,只能在函数内部访问;
不用var声明的变量,为全部变量,在函数外面也能访问;
函数的形参列表,默认为函数的举局部变量,只能在函数内部使用。
⑦ 函数的声明与函数的调用,没有先后之分。即,可以在声明函数前,调用函数。
fun(); //声明之前调用可以。
function fun(){}

【匿名函数的声明使用】
1.声明一个匿名函数,直接赋值给某一个事件。
window.onload= function(){}
2.使用匿名函数表达式。将匿名函数,赋值给一个变量。
声明:var func=function (){}
调用:func();

注意:使用匿名函数表达式时,函数的调用,必须放在函数声明语句之后!!!
(与普通函数的区别)
3.自执函数:
① !function(){}();    可以使用多种与运算符开头,一般用!
!function(形参列表){}(实参列表);
② (function(){}());    使用()将函数集函数后的括号包裹。
③ (function(){})();    使用()值包裹函数部分;

三种写法的特点
① 使用!开头结构清晰,不容易混乱,推荐使用;
② 能够表明匿名函数与调用的()为一个整体,官方推荐使用;
③ 无法表示函数与之后剖的()的整体性,不推荐使用;

【函数的内部属性】
1.Arguments对象
① 作用:用于储存调用函数时的所有实参。
当我们调用函数,并用实参赋值时,实际上 到arguments数组中, 可以在函数中,使用arguments[n]的形式调用。n从0开始。

② arguments数组的个数,取决于实参列表,与形参无关。
但是,一旦第N个位置的形参、实参、arguments都存在时,形参将于arguments绑定,同步变化。
(即在函数中修改形参的值,arguments也会改变。反之,亦成立。)
③ arguments.callee 是arguments的重要标志。表示arguments所在函数的引用地址;
在函数里面,可以使用arguments.callee()调用函数本身。

递归
在函数内部,调用函数自身的写法,叫做递归。
递归分为两部分: 递 和 归。 以递归调用语句为界限,可以将函数分为上下两部分。
递:当函数执行上半部,遇到自身的语句时,继续进入内层函数,在执行上半部分。直到执行哇按最内层函数。
归:当内层函数执行以后面,在从最内层函数开始,逐渐执行函数的下半部分。

当最外层函数执行时,遇到自身调用语句,会进入内层函数执行,而外层函数的后半部分暂不执行。
直到内层函数执行完以后,在逐步向外执行。

【js代码的执行顺序问题】
js代码在运行时,会分为两大部分:检查装载和执行阶段
检查装载阶段:会先检测代码的语法错误,进行变量、函数的声明。
执行阶段:变量得瑟赋值、函数的调用等,都属于执行阶段。

以一下代码为例:
console.log(num);   Undefine
var num=10;

func1();    函数可以正常执行
function func1(){}

func2();    函数不能执行,打印func2,显示Undefine
var func2= function(){}


-----------检查装载阶段----------
var num;

var func1 = function(){};

var func2;

----------------------------------------

-----------代码执行阶段----------
console.log(num);
var num = 10;

func1 ();

func2 ();
func2 = function(){}

----------------------------------------

console.log(num);    Undefine
var num=10;

func1();    函数可以正常执行
function func1(){}

func2();    函数不能执行,打印func2,显示Undefine
var func2= function(){}

JS学习三(函数)的更多相关文章

  1. js学习之函数表达式及闭包

    来自<javascript高级程序设计 第三版:作者Nicholas C. Zakas>的学习笔记(七) 直接切入主题~ 定义函数的方式有两种: 函数声明 function functio ...

  2. js学习之函数的参数传递

    我们都知道在 ECMAScript 中,数据类型分为原始类型(又称值类型/基本类型)和引用类型(又称对象类型):这里我将按照这两种类型分别对函数进行传参,看一下到底发生了什么. 参数的理解 首先,我们 ...

  3. js学习-自定义函数、对象的字面量、json对象学习小结

    一.自定义对象的构造: var student=new Object(); //object是顶级对象,使用构造函数的方法创建一个对象,此处的意思是创建了一个学生的空对象 student.name=& ...

  4. js学习之函数声明与函数表达式区别[原创]

    作为一名js初学者,与大家分享下.Javascript中有函数声明提升的功能,会优先编译函数声明部分.比如, ff(); function ff(){ alert("hello world. ...

  5. js学习之函数

    1/.js中函数就是对象. 2/以表达式方式定义的函数一般不要函数名以使代码紧凑. 3/js中函数声明的方式会被默认提到外部脚本或最前面,所以在其定义前的代码也可调用. 然而以表达式方式的则不行. 4 ...

  6. Oracle的基本学习(三)—函数

    一.字符函数   1.大小写控制函数 --lower:使字母变为小写-- --upper:使字母变为大写-- --initcap:使字符的第一个字母变为大写-- select lower('ABC') ...

  7. node.js学习三--------------------- http服务器模块的搭建

    /** * http服务器的搭建,相当于php中的Apache或者java中的tomcat服务器 */ // 导包 const http=require("http"); //创建 ...

  8. js学习笔记 -- 函数

    js函数有类似javaMethod用法 Math.max.apply( Math.max.call( Array map,reduce,filter,sort , , , , , , , , ]; v ...

  9. js学习:函数

    概述 函数的声明 JavaScript 有三种声明函数的方法 function 命令 function命令声明的代码区块,就是一个函数.function命令后面是函数名,函数名后面是一对圆括号,里面是 ...

随机推荐

  1. RabbitMQ安装以及java使用(二)

    上一篇记录了rabbitmq的安装,这一篇记录一下rabbitmq的java客户端的简单使用,当然在项目中我们有更为复杂的应用场景,这里只有最简单的点对点生产者与消费者模式. 1.建立工程 首先建立一 ...

  2. Linux配置全局jdk

    Linux配置全局jdk 1.确保相应文件夹下有apache-tomcat和jdk的压缩文件 注意:jdk文件必须为适应Linux版本的文件 (如果已经有了相应文件,可以跳过以下第2-3个步骤) 2. ...

  3. [NOIP2011] 聪明的质监员 二分+前缀和

    考试的时候打的二分但没有用前缀和维护.但是有个小细节手误打错了结果挂掉了. 绝对值的话可能会想到三分,但是注意到w增大的时候y是减小的,所以单调性很明显,用二分就可以.但注意一个问题,就是二分最后的结 ...

  4. SO_REUSEADDR与SO_REUSEPORT平台差异性与测试

    前些天,与另外一个项目组的同事聊天的时候,谈到他遇到的一个有意思的BUG.在window上启动服务器,然后客户端连接的时候收到一些奇怪的消息,查证了,原来是他自己的另一个工具也在相同的地址上监听,客户 ...

  5. Selenium 新窗口处理方法

    有时点击一个链接,跳到一个新的窗口,这时WebDriver需切换到新窗口,才能对新窗口的元素进行操作 这里封装一个switchToWindow方法: public boolean switchToWi ...

  6. PyV8

    待完善 pyv8是个js解析引擎, PyV8 是 V8 引擎的 Python 语言封装,这是 Python 和 JavaScript 对象之间的桥,支持在 Python 脚本中调用 V8 引擎. # ...

  7. 【LeetCode】数组-3(605)-种花问题( 1 的两侧不能有 1 )

    开始的思路:首先统计需要种几只花,用花的数目统计连续 0 的个数.... ...[囧]突然觉得情况有点复杂啊,有连续的又有分散的怎么能统计全呢? 好吧这里喔偷偷的瞄了一眼参看答案... ...(就一眼 ...

  8. 【转】session和cookie详解

    会话(Session)跟踪是Web程序中常用的技术,用来跟踪用户的整个会话.常用的会话跟踪技术是Cookie与Session.Cookie通过在客户端记录信息确定用户身份,Session通过在服务器端 ...

  9. 【.Net Core 2.0 生态】-- 好文收藏

    随笔分类 - .NET Core - dotNet实训营 .Net Core 2.0 生态(1).NET Standard 2.0 特性介绍和使用指南 .Net Core 2.0 生态(2).NET ...

  10. ELK5.0搭建部署

    ###关闭防火墙 service iptables stop ###定义vi=vim alias vi=vim vi ~/.bashrc alias vi='vim' yum -y install l ...