您现在的位置是:亿华云 > IT科技类资讯
JavaScript写一个Once函数,让传入函数只执行一次
亿华云2025-10-09 01:31:18【IT科技类资讯】5人已围观
简介大家好,我是前端西瓜哥,今天我们做一道简单的前端面试题。用 JavaScript 实现一个 once 函数,要求传入函数只能执行一次。且第二次及以后再调用时,仍会返回第一次执行的值。效果要求如下:co
大家好,函数我是让传入函前端西瓜哥,今天我们做一道简单的执行前端面试题。
用 JavaScript 实现一个 once 函数,函数要求传入函数只能执行一次。让传入函且第二次及以后再调用时,执行仍会返回第一次执行的函数值。
效果要求如下:
const addOnce = once(function(a,让传入函 b) {
return a + b;
});
addOnce(1, 2); // 3
addOnce(1, 2999); // 依旧是 3思路和实现这里涉及到一个 闭包 的概念。
什么是执行闭包?闭包是一种技术,它能让 一个函数访问另一个函数内的函数变量(或者叫关联的环境)。
一种常见的让传入函方式就是调用一个函数 a,然后这个函数返回了一个新创建的执行函数 b。获得的函数效果是:新的函数 b 可以访问到 a 中声明的b2b供应网变量。
once 函数就要借助闭包的让传入函力量,返回 一个绑定了作用域的执行新函数。
我们先看看实现。
function once(fn) {
let ret; // 缓存结果用
return function(...args) {
if (!fn) return ret;
ret = fn(...args);
fn = undefined; // 表示已经执行过一次
return ret;
}
}利用闭包,我们返回的新函数有两个 “私有” 的变量可以访问:
传入的 fn 函数;额外声明的用于缓存结果的 ret 变量当返回的新函数被调用时,我们先将参数传给 fn,拿到返回值缓存到 ret。然后将 fn 设置为 undefined,用于标识别已经执行了一次,最后返回 ret。
下次再调用时,我们通过判断 fn 为 falsy,直接返回缓存的 ret。
另外,你貌似可以加多一个对 fn 的类型校验:typeof fn === function,来向面试官表达你的云服务器代码的健壮性。
有一个比较有趣的地方:如果返回的是个对象,多次调用的返回值其实都是指向同一个。如果你希望每次返回的对象都是新的对象,可以考虑返回一个拷贝后的对象(如果可以拷贝的话)。
结尾once 的实现并不复杂,只要利用闭包,用封闭的环境保存一个缓存的返回值,以及一个是否执行过的状态,就能控制函数的执行走向。香港云服务器
很赞哦!(9871)
相关文章
- 2. 不要花大价钱买域名,新手鉴别能力不足,容易投资失误。
- 新手注册的域名需要绑定使用吗?该如何操作?
- 商人需要带货怎么选域名?有什么技巧性?
- 新手注册的域名需要绑定使用吗?该如何操作?
- 互联网中的地址是数字的IP地址,域名解析的作用主要就是为了便于记忆。
- am域名有多大魅力?为何会吸引到明星喜好?
- 域名与商标的差异是什么?域名与商标区别有何不同?
- 新手要在哪里注册网站域名?有什么好的方法?
- 用户邮箱的静态密码可能已被钓鱼和同一密码泄露。在没有收到安全警报的情况下,用户在适当的时间内不能更改密码。在此期间,攻击者可以随意输入帐户。启用辅助身份验证后,如果攻击者无法获取移动电话动态密码,他将无法进行身份验证。这样,除非用户的电子邮件密码和手机同时被盗,否则攻击者很难破解用户的邮箱。
- 二级域名为何能掌控搜索引擎?什么方法?