文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vscode工具函数once如何使用

2023-07-05 17:19

关注

这篇文章主要介绍“vscode工具函数once如何使用”,在日常操作中,相信很多人在vscode工具函数once如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vscode工具函数once如何使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

背景

once 函数的起源可以追溯到函数式编程。在函数式编程中,函数被视为不可变的,这意味着它们不应修改任何状态或引用任何状态。因此,在函数式编程中,通常需要一些技巧来处理一些常见问题,例如避免在多次调用相同函数时进行冗余计算。

once 函数是解决此问题的一种方法。它可以将函数转换为只能调用一次的函数,并使用一些技巧来避免冗余计算。使用 once 函数可以减少计算时间和资源的消耗,并提高应用程序的性能。

once 函数在现代 JavaScript 库和框架中非常常见,例如 lodash。它们提供了许多内置的 once 函数来处理各种场景和问题。在实际开发中,我们可以使用这些函数来提高代码的可维护性和可读性,避免冗余计算和网络请求,并提高应用程序的性能。

VSCode中的实现

export function once<T extends Function>(this: unknown, fn: T): T {const _this = this;let didCall = false;let result: unknown;return function () {if (didCall) {return result;}didCall = true;result = fn.apply(_this, arguments);return result;} as unknown as T;}

这个实现比较简单,但还是详细分析解释一下代码

lodash的实现

lodash 到目前的版本已经是高度封装了,它的源码可以在**github.com/lodash/loda&hellip;**看到:

function once(func) {  return before(2, func)}

它本身是调用了 before 函数, before 是一个经过高度抽象的函数,它在被调用次数达到指定次数之前,会继续执行传入的函数,而在达到指定次数时,会返回最后一次执行传入函数的结果:

function before(n, func) {  let result  if (typeof func !== 'function') {    throw new TypeError('Expected a function')  }  return function(...args) {    if (--n > 0) {      result = func.apply(this, args)    }    if (n <= 1) {      func = undefined    }    return result  }}

对于 lodash 这样的工具库而言,它的抽象层次要比 vscode 更高,但实现的原理是相同的,核心都是利用闭包,通过内部变量的状态来判断函数是否已经被调用过,从而保证原始函数只被执行一次。

once的应用

**once**函数是一个常见的JavaScript函数,它用于确保一个函数只能被调用一次。这个函数在以下几个场景下非常有用:

在VSCode中, once 用的非常频繁,通过查看 reference 我们可以看到非常多的使用:

vscode工具函数once如何使用

once的注意事项

this指针问题

once 函数内部,定义了一个名为 _this 的变量,它保存了函数的 this 关键字。这是因为,在使用 applycall 方法调用函数时,需要确保函数中的 this 关键字被正确地绑定。如果没有保存 _this 变量,而是直接使用 this 关键字,可能会导致 this 关键字在多次调用中被意外地修改,从而导致错误或异常。

在使用 once 函数时,如果原始函数需要使用 this 关键字,需要确保 this 关键字被正确地绑定。看看以下代码:

class Counter {  private count = 0;  constructor(private readonly name: string) {}  increment() {    console.log(`${this.name}: Count = ${++this.count}`);  }}const counter1 = new Counter('Counter 1');const counter2 = new Counter('Counter 2');const incrementOnce = once(counter1.increment);incrementOnce.call(counter1); // 输出 "Counter 1: Count = 1"incrementOnce.call(counter2); // 输出 "Counter 1: Count = 2",而不是 "Counter 2: Count = 1"incrementOnce.call(counter1); // 输出 "Counter 1: Count = 2"

在上述代码中,如果我们在多次调用 incrementOnce 函数时,使用了不同的 this 关键字,可能会导致输出结果不正确。例如,上述代码中的第二次调用 incrementOnce 函数时,使用了 counter2 作为 this 关键字,而实际上 incrementOnce 函数中保存的 this 关键字是 counter1,因此输出结果为 "Counter 1: Count = 2",而不是 "Counter 2: Count = 1"。

因此,在使用 once 函数时,需要确保原始函数能够正确地处理 this 关键字,并且在调用 once 函数时,应该指定正确的 this 关键字,以避免意外的错误或异常。

到此,关于“vscode工具函数once如何使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯