js函数

1、什么是函数?

函数就是把一段相对独立的具有特定功能的代码块封装起来,形成一个独立实体,就是函数,起个名字(函数名),在后续开发中可以反复调用。
函数的作用就是封装一段代码,将来可以重复使用。

2、函数的定义
(1)、声明函数

function 函数名() {
  // 函数体
}

注意:

函数声明的时候,函数体并不会执行,只要当函数被调用的时候才会执行。
函数一般都用来干一件事情,函数名称一般使用动词。

(2)、函数表达式

var fn = function () {
  // 函数体
}

(3)、调用函数
语法:函数名();
特点:

函数体只有在调用的时候才会执行,调用需要()进行调用。
可以调用多次(重复使用)

示例:

// 声明函数
function sayHi() {
  console.log("吃了没?");
}
// 调用函数
sayHi();

// 求1-100之间所有数的和
function getSum() {
  var sum = 0;
  for (var  i = 0; i < 100; i++) {
    sum += i;
  }
  console.log(sum);
}
// 调用
getSum();

3、函数的参数
语法:

// 函数内部是一个封闭的环境,可以通过参数的方式,把外部的值传递给函数内部
// 带参数的函数声明
function 函数名(形参1, 形参2, 形参3...) {
  // 函数体
}

注意:

  1. 形式参数:在声明一个函数的时候,为了函数的功能更加灵活,有些值是固定不了的,对于这些固定不了的值。我们可以给函数设置参数。这个参数没有具体的值,仅仅起到一个占位置的作用,我们通常称之为形式参数,也叫形参。
  2. 实际参数:如果函数在声明时,设置了形参,那么在函数调用的时候就需要传入对应的参数,我们把传入的参数叫做实际参数,也叫实参。

示例:

var x = 5, y = 6;
fn(x,y); 
function fn(a, b) {
  console.log(a + b);
}

案例:

// 圆的面积
function getArea(r) {
    var pi = 3.1415926;
    console.log(pi*r*r);
}

getArea(7);   // 153.9380374

// 求两个数中的最大值
function getMax(a,b){
    if (a>b){
        console.log(a);
    }
     console.log(b);
}

getMax(2,3)  // 3

// 求三个数中的最大值
function getMax(a,b,c){
    if (a>b && a>c){
        console.log(a);
    }else if (b>a && b>c){
        console.log(b);
    }else if (c>a && c>b){
        console.log(c);
    }
}

getMax(2,3,4);   // 4

// 求n个数的最大值
function getMax(arr){
    // 参数arr 是数组
    var max = arr[0];
    for (var i=1;i<arr.length;i++){
        // 判断max和数组中之后的每一个元素进行比较
        if (max < arr[i]){
            max = arr[i];
        }
    }
    console.log(max);
}

getMax([12,2,45,1,0])  // 45

// 判断一个数是否是素数(又叫质数,只能被1和自身整除的数)
function judgePrimeNumber(number){
    for (var i=2;i<number;i++){
        var isPrime = true;
        // 判断是否有能被number整除的数
        if (number % i === 0){
            isPrime = false;
            break;
        }
    }
    if (isPrime){
        console.log('质数');
    }else {
        console.log('不是质数');
    }
}

judgePrimeNumber(9)  // 不是质数

5、函数的返回值
当函数执行完的时候,并不是所有时候都要把结果打印。我们期望函数给我一些反馈(比如计算的结果返回进行后续的运算),这个时候可以让函数返回一些东西。也就是返回值。函数通过return返回一个返回值。
语法:

//声明一个带返回值的函数
function 函数名(形参1, 形参2, 形参3...) {
  //函数体
  return 返回值;
}

//可以通过变量来接收这个返回值
var 变量 = 函数名(实参1, 实参2, 实参3...);

函数的调用结果就是返回值,因此我们可以直接对函数调用结果进行操作。
注意:

如果函数没有显示的使用 return语句 ,那么函数有默认的返回值:undefined。
如果函数使用 return语句,那么跟再return后面的值,就成了函数的返回值。
如果函数使用 return语句,但是return后面没有任何值,那么函数的返回值也是:undefined。
函数使用return语句后,这个函数会在执行完 return 语句之后停止并立即退出,也就是说return后面的所有其他代码都不会再执行。

案例:

// 求阶乘 5* 4* 3 *2 * 1
function getJieCheng(n){
    var result = 1;
    for (var i=1;i<=n;i++){
        result *= i;
    }
    return result;
}

var num = getJieCheng(5); 
console.log(num)   // 120


// 求1! + 2! + 3! +...+ n!

function getJieCheng(n){
    var result = 1;
    for (var i=1;i<=n;i++){
        result *= i;
    }
    return result;
}

function getSum(n) {
    // 求1-n之间每一个数的阶乘的累加
    var sum = 0;
    for (var i=1;i<=n;i++){
        // 累加的是每一个数的阶乘
        sum += getJieCheng(i);
    }
    return sum;
}
console.log(getSum(5));  // 153

练习:

// 求斐波那契数列中的第n个数的多少? 1 1 2 3 5 8 13 21

function getFib(n) {
var n1 = 1;
var n2 = 1;
var n3;
for (var i=3; i<=n;i++){
n3 = n1 + n2;
n1 = n2;
n2 = n3;
}
return n3;
}

var r = getFib(5);
console.log® // 5

6、arguments的使用。
JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一个内置属性。也就是说所有函数都内置了一个arguments对象,arguments对象中存储了传递的所有的实参。arguments是一个伪数组,因此及可以进行遍历。

function test() {
    console.log(arguments);  // Arguments(2) [4, 5, callee: ƒ, Symbol(Symbol.iterator): ƒ] 像数组,不是数组
}

test(4,5);

案例:

求任意个数的最大值。
function getMax() {
	var max = arguments[0];
    for (var i=1;i<arguments.length;i++){
		if(max < arguments[i]){
			max = arguments[i];
        }
	}
	return max
}
var max = getMax(5,10,1);
console.log(max);   // 10

7、匿名函数
没有名字的函数。
语法:

function () {
    // 函数体
}

调用方式:

(1)、将匿名函数赋值给一个变量,这样就可以通过变量进行调用。
(2)、匿名函数自调用

8、自调用函数
当函数书写完成之后立即调用,而不是我们手动调用。
匿名函数不能通过直接调用来执行,因此可以通过匿名函数的自调用的方式来执行。
语法:

(function () {
  alert(123);
})();

9、函数也是一种数据类型。
因为函数是一种数据类型,所以函数可以作为另一个函数的参数。

var fn = function () {
    console.log('我是传过来的函数')
}
console.log(typeof fn);   // function

function test(fun){
    fun();
}

test(fn);   // 我是传过来的函数

注意:

当我们调用函数的时候,如果没有传递参数,此时形参的值是undinfed。

10、代码规范

1.命名规范	
	变量、函数 的命名 必须要有意义
	变量 的名称一般用名词
	函数 的名称一般用动词
2.变量规范   
	操作符的前后要有空格
	var name = 'zs';	  5 + 6
3.注释规范
	// 这里是注释
4.空格规范
	if (true) {
      
	}
	for (var i = 0; i <= 100; i++) {
      
	}
5.换行规范
	var arr = [1, 2, 3, 4];
	if (a > b) {
      
	}
	for (var i = 0; i < 10; i++) {
      
	}
	function fn() {
      
	}

11、变量作用域
作用域:变量可以起作用的范围。
全局变量:在任何地方都可以访问到的变量就是全局变量,对应全局作用域。
局部变量:只在固定的代码片段内可访问到的变量,最常见的例如函数内部。对应局部作用域(函数作用域)。

不使用var声明的变量是全局变量,不推荐使用。
变量退出作用域之后会销毁,全局变量关闭网页或浏览器才会销毁。

12、作用域链

<script>
// 全局作用域  -- 0级作用域链
var num = 5;
function f1() {
	// f1 局部作用域 -- 1级作用域链
	var num = 15;
	function f2() {
		// f2 局部作用域 -- 2级作用域链
		console.log(num);  // 15
 	}
 	f2();
}
f1();
</script>

调用f2时,先从f2里找,f2里没有。此时就会从上一级作用域找。

13、预解析
JavaScript代码的执行是由浏览器中的JavaScript解析器来执行的。JavaScript解析器执行JavaScript代码的时候,分为两个过程:预解析过程和代码执行过程

var num = 5;
console.log(num); // 5

交换顺序后

console.log(num); // undefined
var num = 5;

去掉var num = 5;后

console.log(num); // 抛出num未定义的异常

对于函数

function f1() {
	console.log('hello');
}
f1();  // hello

交换顺序后

f1();  // hello
function f1() {
	console.log('hello');
}

javascript代码执行之前会进行预解析。
预解析过程:

  1. 把变量的声明提升到当前作用域的最前面,只会提升声明,不会提升赋值。
  2. 把函数的声明提升到当前作用域的最前面,只会提升声明,不会提升调用。
  3. 先提升var,在提升function

回到刚刚的问题,预解析过程:

// 对于变量,会将变量提升到作用域最顶端
var num;
console.log(num);
num = 5;


// 对于函数,他会将函数提升到作用域最前。
function f1() {
	console.log('hello');
}
f1();

案例1:

var a = 25;
function abc() {
  alert(a);   
  var a = 10;
}
abc();

代码执行之前进行预解析

var a;
function abc() {
	// 局部作用域也要进行预解析
	// var a;
  alert(a);    // undefined
  var a = 10;
}
a = 25;
abc();

案例二:

console.log(a);
function a() {
  console.log('aaaaa');
}
var a = 1;
console.log(a);

预解析过程
注意:在预解析过程中,如果函数名和变量名相同,此时函数优先。

var a;
function a() {
  console.log('aaaaa');
}
console.log(a);   // function a()
 a = 1;
console.log(a);  // 1

变量提升

var num = 10;
fun();
function fun() {
  console.log(num);   // undefined
  var num = 20;
}
// ----------------------------

var a = 18;
f1();
function f1() {
  var b = 9;
  console.log(a);  // undefined
  console.log(b);   // 9
  var a = '123';
}


// ----------------------------


f1();
console.log(c);  
console.log(b);  
console.log(a);  
function f1() {
  var a = b = c = 9;  // 表示 局部变量var a=9; 全局变量 b=9;c=9
  console.log(a);  
  console.log(b);  
  console.log(c);  
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值