JavaScript中函数

 2023-09-05 阅读 54 评论 0

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

函数

什么是函数

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

函数的作用就是封装一段代码,将来可以重复使用

函数的定义

  • 函数声明
function 函数名(){// 函数体
}
  • 函数表达式
var fn = function() {// 函数体
}
  • 特点:

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

 

函数的调用

  • 调用函数的语法:

函数名();
  • 特点:

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

函数的参数

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

    1.  形式参数:在声明一个函数的时候,为了函数的功能更加灵活,有些值是固定不了的,对于这些固定不了的 值。我们可以给函数设置参数。这个参数没有具体的值,仅仅起到一个占位置的作用,我们通常称之为形式参数,也叫形参。

    2. 实际参数:如果函数在声明时,设置了形参,那么在函数调用的时候就需要传入对应的参数,我们把传入的参数叫做实际参数,也叫实参。 

函数的返回值

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

返回值语法:

//声明一个带返回值的函数
function 函数名(形参1, 形参2, 形参...){//函数体return 返回值;
}
​
//可以通过变量来接收这个返回值
var 变量 = 函数名(实参1, 实参2, 实参3);

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

返回值详解:

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

arguments的使用

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

案例

1.判断一个数是否是素数

 //    - 判断一个数是否是素数(质数),只能被1和自身整除,质数是从2开始//用这个数字和这个数字前面的所有的数字整除一次(没有1的,没有自身的)function isPrimeNumber(num) {for(var i=2;i<num;i++){if(num%i==0){//说明有一个数字整除了,就没有必要向后继续整除了,此时就已经验证出不是质数return false;}}return true;}console.log(isPrimeNumber(8)?"是质数":"不是质数");

2.  求斐波那契数列,12---144 ( 1 1 2 3 5 8 13 21 34 55 89 144 )

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>$永远的24k纯帅$</title><script>//求斐波那契数列,12---144//1 1 2 3 5 8 13 21 34 55 89 144function getFib(num) {var num1=1;var num2=1;var sum=0;for(var i=3;i<=num;i++){sum=num1+num2;num1=num2;num2=sum;}return sum;}console.log(getFib(12));</script>
</head>
<body>
</body>
</html>

3.翻转数组,返回一个新数组

function reverseArray(arr) {for (var i = 0; i < arr.length / 2; i++) {var temp = arr[i];arr[i] = arr[arr.length - 1 - i];arr[arr.length - 1 - i] = temp;}return arr;}console.log(reverseArray([1, 2, 3, 4, 5]));

4.对数组排序,从小到大(冒泡排序)

    //通过函数实现冒泡排序function sortArray(arr) {//控制比较的轮数for (var i = 0; i < arr.length - 1; i++) {//控制每一轮的比较次数for (var j = 0; j < arr.length - 1 - i; j++) {if (arr[j] > arr[j + 1]) {var temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}//end if}//end for}//end forreturn arr;}console.log(sortArray([0, 19, 34, 10, 100, 2]));

5.输入一个年份,判断是否是闰年[闰年:能被4整数并且不能被100整数,或者能被400整数]
6.输入某年某月某日,判断这一天是这一年的第几天?

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>$永远的24k纯帅$</title><script>//输入,年月日,获取这个日期是这一年的第多少天//判断这个年份是不是闰年function isLeapYear(year) {return year%4==0&&year%100!=0||year%400==0;}//年---月---日:2017年4月28日function getDays(year, month, day) {//定义变量存储对应的天数var days = day;//如果用户输入的是一月份,没必要向后算天数,直接返回天数if (month == 1) {return days;}//代码执行到这里-----说明用户输入的不是1月份//用户输入的是7月份23日----1,2,3  +23//定义一个数组,存储每个月份的天数var months = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];//小于的是输入的月份-1for (var i = 0; i < month - 1; i++) {days += months[i];}//需要判断这个年份是不是闰年if(isLeapYear(year)&&month>2){days++;}return days;}console.log(getDays(2000,3,2));</script>
</head>
<body></body>
</html>

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

 //求一个数字的阶乘function getJieCheng(num) {var result = 1;for (var i = 1; i <= num; i++) {result *= i;}return result;}console.log(getJieCheng(5));//1*2*3*4*5//求一个数字的阶乘和  5的阶乘+4的阶乘+3的阶乘+2的阶乘+1的阶乘function getJieChengSum(num) {//5var sum=0;//和for(var i=1;i<=num;i++){sum+=getJieCheng(i);}return sum;}console.log(getJieChengSum(5));//1 +2+ 6+ 24+120
//函数内部可以调用其他的函数
8.求一个数组中的最大值和最小值还有和
//求一个数组中的最大值和最小值还有和/***  给我一个数组,我返回一个数组(最大值,最小值,和)* @param array参数是一个数组* @returns {*[]}返回值是一个数组,第一个元素值是最大值,第二个元素值是最小值,第三个元素值是和*/function getArrayMaxAndMinAndSum(array) {var min = array[0];//最小值var max = array[0];//最大值var sum = 0;//和for (var i = 0; i < array.length; i++) {sum += array[i];//和//最大值if (max < array[i]) {max = array[i];}// end if//最小值if (min > array[i]) {min = array[i];}// end if}// end forvar arr = [max, min, sum];return arr;}//测试var resultArray = getArrayMaxAndMinAndSum([1, 2, 3, 4, 5, 6, 7]);console.log("最大值:" + resultArray[0]);//7console.log("最小值:" + resultArray[1]);//1console.log("和:" + resultArray[2]);//28

函数其它

匿名函数

匿名函数:没有名字的函数

匿名函数如何使用:

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

关于匿名函数自调用的作用:防止全局变量污染。

自调用函数

匿名函数不能通过直接调用来执行,因此可以通过匿名函数的自调用的方式来执行

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

函数是一种数据类型

function fn() {}
console.log(typeof fn);
  • 函数作为参数

因为函数也是一种类型,可以把函数作为两一个函数的参数,在两一个函数中调用

  • 函数做为返回值

因为函数是一种类型,所以可以把函数可以作为返回值从函数内部返回,这种用法在后面很常见。

作用域

作用域:变量可以起作用的范围

全局变量和局部变量

  • 全局变量

    在任何地方都可以访问到的变量就是全局变量,对应全局作用域

  • 局部变量

    只在固定的代码片段内可访问到的变量,最常见的例如函数内部。对应局部作用域(函数作用域)

使用var声明的变量是全局变量。

函数内部声明的变量是局部变量。

 隐式全局变量:声明的变量没有var,就叫隐式全局变量

全局变量是不能被删除的,隐式全局变量是可以被删除(delete)的
定义变量使用var是不会被删除的,没有var是可以删除的 

块级作用域

任何一对花括号({和})中的语句集都属于一个块,在这之中定义的所有变量在代码块外都是不可见的,我们称之为块级作用域。 在es5之前没有块级作用域的的概念,只有函数作用域,现阶段可以认为JavaScript没有块级作用域 。

作用域链

只有函数可以制造作用域结构, 那么只要是代码,就至少有一个作用域, 即全局作用域。凡是代码中有函数,那么这个函数就构成另一个作用域。如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域。
​
将这样的所有的作用域列出来,可以有一个结构: 函数内指向函数外的链式结构。就称作作用域链。 
// 案例1:
function f1() {function f2() {}
}var num = 456;
function f3() {function f4() {    }
}

// 案例2
function f1() {var num = 123;function f2() {console.log( num );}f2();
}
var num = 456;
f1();

预解析

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

预解析过程:

  1. 把变量的声明提升到当前作用域的最前面,只会提升声明,不会提升赋值。

  2. 把函数的声明提升到当前作用域的最前面,只会提升声明,不会提升调用。

  3. 先提升var,在提升function

变量提升

  • 变量提升

    定义变量的时候,变量的声明会被提升到作用域的最上面,变量的赋值不会提升。

  • 函数提升

    JavaScript解析器首先会把当前作用域的函数声明提前到整个作用域的最前面

<!doctype html>
<html lang="en">
<head><meta charset="UTF-8"><title>Document</title><script>// 1、-----------------------------------
//        var num = 10;
//        fun();
//        function fun() {
//            console.log(num);//undefined
//            var num = 20;
//        }//2、-----------------------------------
//        var a = 18;
//        f1();
//        function f1() {
//            var b = 9;
//            console.log(a);//undefined
//            console.log(b);//9
//            var a = '123';
//        }// 3、-----------(执行过程解析如4所示)------------------------f1();console.log(c);//9console.log(b);//9console.log(a);//  Uncaught ReferenceError: a is not defined 出错function f1() {var a = b = c = 9;console.log(a);//9console.log(b);//9console.log(c);//9}
//        // 4、-----------------------------------  (4实际上是3的执行过程)
//     
//        function f1() {
//            var a;//局部变量
//            a=9;
//            //隐式全局变量
//            b=9;
//            c=9;
//            console.log(a);//9
//            console.log(b);//9
//            console.log(c);//9
//        }
//        f1();
//        console.log(c);//  9
//        console.log(b);// 9
//        console.log(a);//报错  </script>
</head>
<body></body>
</html>

 

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://808629.com/894.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 86后生记录生活 Inc. 保留所有权利。

底部版权信息