gpt4 book ai didi

javascript - 将类绑定(bind)到 ES6 中的全局范围

转载 作者:行者123 更新时间:2023-11-30 07:56:19 26 4
gpt4 key购买 nike

我试图在 ES6 不使用任何 jQuery 的情况下重新创建 jQuery 验证器, 我在尝试重新创建其添加验证方法的功能时遇到了障碍通过使用 Global scope,也就是说,如果您在任何地方调用 Validator.addMethod,它将在 Validator 中运行相关函数并添加一个Validator 的方法。

我似乎无法在 ES6 中执行此操作,因为我不允许将我的类导出到全局范围,我的类永远无法从窗口对象访问,例如 jQuery 是,如果没有这个,任何想要添加新验证函数的人都必须导入 一个新函数来添加它类,我不能简单地调用

Validator.addMethod('required', function(element, value){
return value.length > 0;
})

在加载验证器类后我想要的任何文件上,所以我的问题是,这在 ES6 中真的不可能还是我遗漏了什么?我已经知道这不是最佳做法,并且愿意接受建议,但即使对于不精通 ES6 的人来说,这个想法也易于使用。

最佳答案

ES6 及更高版本旨在避免污染全局范围。您的顾虑只是 JavaScript 中许多邪恶的不良编码实践的解决方案

顺便说一句,您始终可以访问 window 对象并添加一个与您的类调用方式相同的属性:

class Validator {}

window.Validator = Validator;

...因为类仍然是构造函数和原型(prototype)继承,由基于类的语法包裹。

如果您要在浏览器和 NodeJS 中分发您的库,您可能需要这样做:

class Validator {}

var global = window || global;
global.Validator = Validator;

顺便说一句,如果你想以正确的方式做事,你可以使用通用模块定义来分发你的库。 Learn more at the official GitHub repository of Universal Module Definition (UMD) .

关于javascript - 将类绑定(bind)到 ES6 中的全局范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38796519/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com