函数创建方式及区别,粗略总结函数原理

2024-02-25 17:48

本文主要是介绍函数创建方式及区别,粗略总结函数原理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JS中函数的创建

版权声明:本文为博主原创文章,未经博主允许不得转载。


首先什么是函数

函数其实一个封装一段代码的对象,之所以要封装是为了便于我们以后代码的重用。通俗的说就是一项任务可能被反复的使用,就要定义函数,以便以后反复使用。

函数的创建

函数声明
定义:
使用function关键字声明一个函数,再指定一个函数名,叫函数声明。
表达式:
function 函数名(参数列表){函数体;return 返回值}

function add1(n1,n2){var sum=n1+n2;return sum;};

函数表达式
定义:
使用function关键字声明一个函数,但未给函数命名,最后将匿名函数赋予一个变量,叫函数表达式,这是最常见的函数表达式语法形式。
表达式:
var 函数名=function (参数列表){函数体;return 返回值}

var add2=function(n1,n2){var sum=n1+n2;return sum;
};

函数构造法
定义:
使用new方法创建一个函数,并传参给函数,声明一个变量接收此函数(参数必须加引号)
表达式:
var 函数名=new function (“参数1”,“参数2”, ……;“函数体;return 返回值”}

var add3=new Function('n1','n2','return n1+n2');
console.log(sum3(2,3));//5

三者的区别
函数声明和函数表达式不同之处在于:

解析器会先读取函数声明,并使其在执行任何代码之前可以访问;

而函数表达式则必须等到解析器执行到它所在的代码行才会真正被解释执行。

从技术角度讲,函数构造法其实是一个函数表达式。一般不推荐用这种方法定义函数,因为这种语法会导致解析两次代码(第一次是解析常规ECMAScript代码,第二次是解析传入构造函数中的字符串),从而影响性能。

//函数声明
fnName();
function fnName(){...
}
//正常,因为‘提升'了函数声明,函数调用可在函数声明之前//函数表达式
fnName();
var fnName=function(){...
}
//报错,变量fnName还未保存对函数的引用,函数调用必须在函数表达式之后

出现这样的原因,是因为函数声明提前(Function declaration Hoisting),后面会讲解声明提前是什么
函数的原理
让引擎按照函数的步骤执行任务
存储:
函数名其实就是一个普通的变量
函数本身是一个引用类型的对象(保存多个数据的复杂数据结构)
函数名通过函数的地址值,引用函数对象
强调: 声明时,不会执行函数的内容。
调用:
1. window中声明变量,准备保存函数的返回值
2. 找到函数对象,创建函数执行时的临时存储空间
3. 将调用时传入的参数值,放入临时存储空间的参数变量中
4. 执行函数体,修改临时存储空间中的变量值
5. 将返回值,返回window中,保存到指定变量
6. 函数执行后,临时存储空间释放!导致,函数内局部变量一同释放
所以: 函数中的参数变量和var的变量,只能在函数调用时,内部使用,出了函数,无法使用。

声明提前
在开始执行程序前,引擎会首先查找所有var声明的变量和function声明的函数,将他们集中到当前作用域的顶部优先创建

总结
强烈建议,所有要用到的变量集中声明在当前作用域的顶部

ES6:
尽量用let代替var
强调:
1. let必须在严格模式下使用!
2. let作为局部变量时,必须放在代码段开头
局部变量let之前的变量不可用
3. 用var 函数名=function(){…} 代替function 函数名(){…}
区别: function 函数名(){…} 会被声明提前
var 函数名=function(){…} 不会被声明提前

    揭示了本质: 函数名其实就是一个变量函数名通过地址引用着函数对象

这篇关于函数创建方式及区别,粗略总结函数原理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/746218

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他