Web前端开发笔记——第四章 JavaScript程序设计 第六节 函数

简介: Web前端开发笔记——第四章 JavaScript程序设计 第六节 函数

一、函数的定义和声明


JavaScript中的函数与其它语言中的是一样的含义,都是将一组语句打包,使其可重复地使用。在函数内部声明的变量称为局部变量(可以在不同函数内使用名称相同的局部变量),只能在定义的函数内使用,与局部变量相提的还有全局变量,即所有的函数都内都可使用。

例如定义一个简单的hello_world()函数,其目的是在控制台输出“Hello Javascript!”,如下代码:

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title></title>
  </head>
  <body>
  <script>
    function hello_world() {  //定义函数
    console.log("Hello Javascript!");
    }
    hello_world();  //调用函数
  </script>
  </body>
</html>


控制台中运行结果如下:

1667224496680.jpg

函数的定义/声明方式有以下三种:


(一)function关键字声明


直接通过function关键字声明的格式如下,其中function必须是小写:

function 函数名称(参数1,...){
  //函数体
  //return关键字
}


另外函数内可以通过return关键字可将值返回到其调用的地方,该关键字内可以是任何类型的变量数据或表达式

例如下列html代码,定义了一个无参函数,然后在控制台调用该函数,return关键字返回sum的值:

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title></title>
  </head>
  <body>
  <script type="text/javascript">
    function number() {
    var i, j, sum;
    j = 1;
    sum = 0;
    for (i = 1; i <= 10; i++) {
      j *= i;
      sum += j;
    }
    return sum;
    }
    console.log(number());
  </script>
  </body>
</html>

运行结果如下:

1667224560290.jpg


(二)函数表达式定义函数


另外一种方法是通过函数表达式定义函数,这种方式创建的函数称为匿名函数,一般常用函数的创建还是第一种方式,匿名函数的格式如下,即创建一个函数并将其赋值给一个变量:

var 变量名称 = function 函数名称(参数1,...){
  //函数体
  //return关键字
}


两种方式比较起来,第二种方式没有函数声明提升,函数声明提升也就是当在执行JavaScript代码之前会首先读取所有的函数声明,所以即使将函数声明放在调用该函数的语句后面,程序也不会报错。


例如下列html代码,在控制台调用add_number函数,该函数目的是输出number1 + number2的值,并传入两个参数1,2,然后再声明函数add_number:

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title></title>
  </head>
  <body>
  <script type="text/javascript">
    console.log(add_number());//这里并未给参数,所以输出的是非数值NaN
    console.log(add_number(1, 2));
    function add_number(number1, number2) {
    return number1 + number2;
    }
  </script>
  </body>
</html>


运行结果如下:

1667224669020.jpg

而通过第二种方式创建函数并赋值给变量,程序会报错:

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title></title>
  </head>
  <body>
  <script type="text/javascript">
    console.log(number_sum(1, 2));
    console.log(number_sum());
    var number_sum = function add_number(number1, number2) {
    return number1 + number2;
    }
  </script>
  </body>
</html>


运行结果如下:

1667224697918.jpg


(三)Function()构造函数


还有另一种方式是通过Function()构造函数实例化一个函数对象,通过new操作符实现。

例如下列html代码,在控制台输出a+b的值:

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title>text1</title>
  </head>
  <body>
  <script>
    var f_sum = new Function("a", "b", "console.log(a+b)");
    f_sum(3, 5);
  </script>
  </body>
</html>


运行结果如下:

1667224737789.jpg


二、函数的参数


JavaScript中函数对传入的参数没有特定的要求,当实参比函数声明中的形参个数少时,剩余的形参都会被设置为undefined。

例如下列html代码,定义两个有参函数,对其传参:

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title></title>
  </head>
  <body>
  <script type="text/javascript">
    function display1(x, y, z) {
    console.log(x, y, z);
    }
    function display2(x) {
    console.log(x);
    }
    display1(20);
    display2(20, 30, 0);
  </script>
  </body>
</html>


运行结果如下:

1667224766772.jpg


三、函数的调用


在之前的文章中讲到,函数是一种引用数据类型,它实际上是对象,每个函数都是Function类型的实例,函数的调用有以下调用方式,分别是直接调用、方法调用、构造器调用和Apply调用,这里主要介绍前两种。


(一)直接调用


直接调用也就是在声明函数后直接调用,例如用HTML语言和JavaScript程序编写一个程序,要求通过函数实现,在点击提交按钮时检查用户名、电子邮箱和密码检查是否为空。

如下代码,在button中的onclick属性直接调用validate()函数:

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title></title>
  </head>
  <body>
  <form name="reg_form">
    <h2>登 录</h2>
    <p>用户名:<input type="text" name="uname" /></p>
    <p>电子邮箱:<input type="text" name="email" /></p>
    <p>密码:<input type="password" name="password" /></p>
    <button type=" submit" onclick="validate()">提交</button>
  </form>
  <script>
    function validate() {
    var f = document.reg_form;
    if (f.uname.value == "" || f.uname.value == null) {
      alert("请输入姓名");
      f.uname.focus();
      return false;
    }
    if (f.email.value == "" || f.email.value == null) {
      alert("请输入邮箱");
      f.email.focus();
      return false;
    }
    if (f.password.value == "" || f.password.value == null) {
      alert("请输入密码");
      f.password.focus();
      return false;
    }
    }
  </script>
  </body>
</html>


运行结果如下:

1667224807367.jpg

1667224819825.jpg

1667224830784.jpg


(二)方法调用


若将函数赋值给对象的成员,则此时函数就做叫方法,即方法的调用。

<!DOCTYPE html>
<html>
  <head>
  <meta charset="utf-8">
  <title></title>
  </head>
  <body>
  <script>
    var num = function() {
    console.log("HELLO javascript!");
    console.log(this);
    }
    var fun = {};
    fun.a = num; //将函数num赋值给一个对象fun
    fun.a(); //调用方法
  </script>
  </body>
</html>


运行结果如下,在控制台中可见该方法调用的结果是Object:

1667224454882.jpg

相关文章
|
2月前
|
前端开发 JavaScript 安全
前端性能调优:HTTP/2与HTTPS在Web加速中的应用
【10月更文挑战第27天】本文介绍了HTTP/2和HTTPS在前端性能调优中的应用。通过多路复用、服务器推送和头部压缩等特性,HTTP/2显著提升了Web性能。同时,HTTPS确保了数据传输的安全性。文章提供了示例代码,展示了如何使用Node.js创建一个HTTP/2服务器。
69 3
|
2月前
|
JavaScript 前端开发 Java
springboot解决js前端跨域问题,javascript跨域问题解决
本文介绍了如何在Spring Boot项目中编写Filter过滤器以处理跨域问题,并通过一个示例展示了使用JavaScript进行跨域请求的方法。首先,在Spring Boot应用中添加一个实现了`Filter`接口的类,设置响应头允许所有来源的跨域请求。接着,通过一个简单的HTML页面和jQuery发送AJAX请求到指定URL,验证跨域请求是否成功。文中还提供了请求成功的响应数据样例及请求效果截图。
springboot解决js前端跨域问题,javascript跨域问题解决
|
2月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
44 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
2月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
54 5
|
2月前
|
缓存 前端开发 JavaScript
JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式
本文深入解析了JavaScript前端路由的实现原理及其在单页应用中的重要性,涵盖前端路由概念、基本原理、常见实现方式(Hash路由和History路由)、优点及挑战,并通过实际案例分析,帮助开发者更好地理解和应用这一关键技术,提升用户体验。
81 1
|
2月前
|
JSON 前端开发 JavaScript
聊聊 Go 语言中的 JSON 序列化与 js 前端交互类型失真问题
在Web开发中,后端与前端的数据交换常使用JSON格式,但JavaScript的数字类型仅能安全处理-2^53到2^53间的整数,超出此范围会导致精度丢失。本文通过Go语言的`encoding/json`包,介绍如何通过将大整数以字符串形式序列化和反序列化,有效解决这一问题,确保前后端数据交换的准确性。
56 4
|
2月前
|
消息中间件 前端开发 JavaScript
探索微前端架构:构建现代Web应用的新策略
本文探讨了微前端架构的概念、优势及实施策略,旨在解决传统单体应用难以快速迭代和团队协作的问题。微前端允许不同团队独立开发、部署应用的各部分,提升灵活性与可维护性。文中还讨论了技术栈灵活性、独立部署、团队自治等优势,并提出了定义清晰接口、使用Web组件、状态管理和样式隔离等实施策略。
|
2月前
|
资源调度 前端开发 JavaScript
vite3+vue3 实现前端部署加密混淆 javascript-obfuscator
【11月更文挑战第10天】本文介绍了在 Vite 3 + Vue 3 项目中使用 `javascript-obfuscator` 实现前端代码加密混淆的详细步骤,包括安装依赖、创建混淆脚本、修改 `package.json` 脚本命令、构建项目并执行混淆,以及在 HTML 文件中引用混淆后的文件。通过这些步骤,可以有效提高代码的安全性。
115 2
|
2月前
|
监控 前端开发 JavaScript
探索微前端架构:构建可扩展的现代Web应用
【10月更文挑战第29天】本文探讨了微前端架构的核心概念、优势及实施策略,通过将大型前端应用拆分为多个独立的微应用,提高开发效率、增强可维护性,并支持灵活的技术选型。实际案例包括Spotify和Zalando的成功应用。
|
2月前
|
设计模式 前端开发 JavaScript
揭秘!前端大牛们如何巧妙利用JavaScript,打造智能交互体验!
【10月更文挑战第30天】前端开发领域充满了无限可能与创意,JavaScript作为核心语言,凭借强大的功能和灵活性,成为打造智能交互体验的重要工具。本文介绍前端大牛如何利用JavaScript实现平滑滚动、复杂动画、实时数据更新和智能表单验证等效果,展示了JavaScript的多样性和强大能力。
61 4