JavaScript函数(一)

一、函数

 1、是一个独立的功能模块,可以重复使用,维护方便。

2、使用:

function f(x,y) {  //定义函数
    return x * y;  //返回值
}
console.log(f(f(5,6), f(7,8)));  //返回1680。重复调用函数

3、声明语法:

 function 函数名([参数]){
		
		    函数体语句;
		}

 (1)'function':是关键字,必须小写

(2)'函数名':用户标识符,建议采用驼峰命名(第一个单词是动词,后面的单词首字母大写)
        
                     做到'见名知义'

(3)'参数':函数可以有参数也可以没有参数。'()'不能省略的

(4)'{}':表示函数的作用范围

 注意:函数定义后并不会执行,只有当函数调用后才会执行

4、函数的调用:

  (1)直接调用:
        
             函数名(参数)

(2)触发事件调用:
        
            事件名 = 函数名(参数)

5、Node.js:

(1)构建JavaScript程序的独立的运行环境

 (2)创建后台程序

(3)环境变量:当应用程序的安装路径和用户程序的路径不同时,计算机系统可以找到应用程序的位置

6、DOS(Disk Option System)

 (1)目录(文件夹)转换:

cd 文件夹名

  . :表示当前目录(文件夹)

 .. :表示当前目录的上一级目录

 \ : 表示根目录(从盘符开始的目录)

(2)列举目录下的文件和文件夹:

 dir

dir /p: 分屏显示文件和文件夹

dir /w:  宽屏显示文件和文件夹

7、函数的参数:参入运算的数据

(1)形参(形式参数):在函数定义时出现在函数首部的参数,只是占位符,没有实际的数据

(2)实参(实在参数): 在函数调用时出现在函数首部的参数,是有确定值的变量或常量

(3)参数之间的数据传递:实参将数据传递给形参(按值传递),传递的方向是单向的(实参-->形参)

数据传递时实参和形参按从左到右一一对应匹配与名称无关

(4)参数的数量:函数的实参和形参的个数可以不同

A、实参的个数多于形参的个数:函数正常运行,多余的实参被忽略

B、实参的个数少于形参的个数: 多余的形参会变成undefined的变量

8、函数的返回值:函数可以有返回值,也可以没有返回值

(1)有返回值的函数:函数体中通过return语法返回一个值,这个决定程序下一步操作

 (2)无返回值的函数:函数只实现某种功能,不需要返回值(函数体中没有return语句)

9、arguments的使用:是JavaScript的一个内置对象(是一个数组),保存了调用函数时传递的所有实参

10、回调函数:将函数A作为参数传递给函数B,在函数B中调用函数A,函数A称为回调函数

11、函数的递归调用:

(1)什么是递归:函数自己调用自己

(2)用递归解决问题条件

  A、问题可以分解,分解后得到的新问题的解法与原问题的解法相同

   B、分解的过程要有明确的结束条件

(3)递归的过程:(以5的阶乘为例)

   A、自上而下分解问题:5!

5!-->5*4!

4! -->4*3!

  3!-->3*2!

2!-->2*1!

B、自下而上回溯得到问题的解

1!-->2!-->3!-->4!-->5!

二、作用域:变量的作用范围

1、全局作用域(全局变量):在函数外部定义的变量或在函数内部没有使用var声明的变量。在浏览器页面没有关闭之前一直占用内存空间。比较耗费内存。在浏览器页面关闭时才释放内存

2、局部作用域(局部变量):在函数内部用var关键字定义的变量。只在函数内部起作用,函数调用结束后,局部变量所占的内存就会被释放。

3、块级作用域:ES6(ECMAScript 2016)使用let声明的变量,作用范围在语句块中

4、作用域链:

作用域链用来在函数执行时求出标识符的值。该链中包含多个对象,在对标识符进行求值的过程中,会从链首的对象开始,然后依次查找后面的对象,直到在某个对象中找到与标识符名称相同的属性。如果在作用域链的顶端(全局对象)中仍然没有找到同名的属性,则返回 undefined 的属性值。

Guess you like

Origin blog.csdn.net/qq_48315043/article/details/121218782