JS 只让函数触发一次的方法

在 JavaScript 中,可以通过以下几种方法实现让一个函数只触发一次:

一、使用标志变量

javascript 复制代码
let hasTriggered = false;
function myFunction() {
  if (!hasTriggered) {
    // 执行函数逻辑
    console.log('Function triggered for the first time.');
    hasTriggered = true;
  }
}

二、使用闭包

javascript 复制代码
const onceFunction = (function () {
  let hasTriggered = false;
  return function () {
    if (!hasTriggered) {
      // 执行函数逻辑
      console.log('Function triggered for the first time.');
      hasTriggered = true;
    }
  };
})();

三、使用立即调用函数表达式(IIFE)结合闭包

javascript 复制代码
const myFunction = (function () {
  let triggered = false;
  return function () {
    if (!triggered) {
      console.log('Function triggered for the first time.');
      triggered = true;
    }
  };
})();

四、借助事件监听器的once选项(如果在特定事件场景下)

如果是在处理事件的场景下,可以使用事件监听器的once选项来确保处理函数只执行一次。

javascript 复制代码
const element = document.getElementById('myElement');
element.addEventListener('click', function handleClick() {
  // 执行函数逻辑
  console.log('Function triggered for the first time.');
}, { once: true });

除了以上三种方法,还有其他方法可以让函数只触发一次吗?

以下是另一种方法来实现让函数只触发一次:

利用代理对象

javascript 复制代码
function myFunction() {
  console.log('Function triggered for the first time.');
}

const proxyHandler = {
  apply: function (target, thisArg, args) {
    const result = Reflect.apply(target, thisArg, args);
    // 修改函数自身,使其变为一个空函数,确保后续调用不执行任何操作
    thisArg.myFunction = function () {};
    return result;
  },
};

const obj = {
  myFunction: myFunction,
};

const proxyObj = new Proxy(obj, proxyHandler);

proxyObj.myFunction();
proxyObj.myFunction(); // 不会再有输出

在这个方法中,使用了代理对象来拦截函数的调用。当函数第一次被调用时,执行原始函数的逻辑,然后修改函数自身为一个空函数,这样后续的调用就不会执行任何操作了。

相关推荐
~patience~2 分钟前
简单易懂的计数器(理解Qt的信号和槽机制)
开发语言·qt
我只会写Bug啊2 分钟前
B站/爱奇艺防录屏防截屏原理及Vue3实战实现
前端·软件开发
尚墨11113 分钟前
Java RestTemplate报错Invalid mime type “charset=utf-8“: does not contain ‘/‘
java·开发语言
我命由我123454 分钟前
Java 开发使用 MyBatis PostgreSQL 问题:传入的参数为 null,CONCAT 函数无法推断参数的数据类型
java·开发语言·数据库·学习·postgresql·mybatis·学习方法
蜗牛攻城狮5 分钟前
前端构建工具详解:Vite 与 Webpack 深度对比与实战指南
前端·webpack·vite·构建工具
爱装代码的小瓶子5 分钟前
【c++知识铺子】map和set的底层-红黑树
java·开发语言·c++
洛阳泰山6 分钟前
Java实现周易六爻自动排盘:根据卜卦的时间推算出天干地支
java·开发语言·周易·六爻
北极象7 分钟前
Electron 通用技术架构分析
javascript·架构·electron
apihz8 分钟前
随机英文姓名生成API接口详细教程:免费、简单、高效
android·java·运维·服务器·开发语言