JavaScript基础知识(函数、作用域)

目录

一、函数

2、使用:声明(定义函数)、调用

3、声明语法

4、函数的调用

5、Node.js

6、DOS(Disk Option System)

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

8、函数的返回值

9、arguments的使用

10、回调函数

11、函数的递归调用

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

1、全局作用域(全局变量)

2、局部作用域(局部变量)

3、块级作用域

4、作用域链


一、函数

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

2、使用:声明(定义函数)、调用

3、声明语法

function 函数名([参数]){
		
	函数体语句;
}
//函数定义
function getSum(a,b){//a和b是形参,在定义时没有确定的形参,只是占位符
    var sum = a+b;
    return sum;
}

注意:'function':是关键字,必须小写

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

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

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

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

4、函数的调用

(1)直接调用:

函数名(参数)

//参数传递是单向的:只是实参把数据传递给形参,形参发生改变不会影响到实参
function swap(a,b){
    console.log("(形参:a="+a+",b="+b);
    var temp = a;
    a = b;
    b = temp;

    console.log("(形参:a="+a+",b="+b);
}

var t = 10,k=25;
console.log("实参:t="+t+",k="+k);
swap(t,k);
console.log("实参:t="+t+",k="+k);

(2)触发事件调用

事件名 = 函数名(参数)

var k=10,t=25;
var s= getSum(k,t);//10和25或(k和t)就是实参,在函数调用时出现在函数首部的参数叫实参,是有确定值的变量或常量
console.log("s=",s);

5、Node.js

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

(2)创建后台程序

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

6、DOS(Disk Option System)

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

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

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

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

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

dir

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

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

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

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

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

(3)参数之间的数据传递:实参将数据传递给形参(按值传递),传递的方向是单向的(实参-->形参)数据传递时实参和形参按从左到右一一对应匹配与名称无关

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

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

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

8、函数的返回值

函数可以有返回值,也可以没有返回值

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

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

9、arguments的使用

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

10、回调函数

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

11、函数的递归调用

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

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

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

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

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

1、全局作用域(全局变量)

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

2、局部作用域(局部变量)

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

3、块级作用域

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

for(let i=0;i<100;i++){
}

4、作用域链

作用域链是由一系列变量对象组成,在这个单向通道中,可以查询变量对象中的标识符,就能访问到上一层作用域中的变量了

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值