- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用我所理解的 Javascript 模块模式和 jQuery。
我有一个应用程序,它有一个公共(public)端和一个管理端。每个都有自己的 JS 文件,虽然一些功能是共享的,所以我将它提取到一个公共(public)文件中。 Gulp 将 common + public 文件组合成一个文件供 public 端使用,将 common + admin 文件组合成一个文件供 admin 端使用。
公共(public) JS 文件包含如下内容:
var PublicFoo = (function () {
var bar = function() {
// ..
};
var init = function() {
$button.on('click', Common.someCommonThing);
};
return {
init: init
};
})();
需要此代码的 HTML 页面会像这样触发它:
<script>
PublicFoo.init();
</script>
admin JS 文件包含一些非常相似的东西,也定义了一个 bar()
函数,并调用相同的 Common
模块函数。
var AdminFoo = (function () {
var bar = function() {
// ..
};
var init = function() {
$button.on('click', Common.someCommonThing);
};
return {
init: init
};
})();
公共(public) JS 文件(与公共(public) JS 和管理 JS 共享和组合)包括如下内容:
var Common = (function () {
var someCommonThing = function() {
// Do stuff.
// When done, I want to call bar() in the calling module.
// This does not work, throws 'Uncaught ReferenceError: bar is not defined'
bar();
};
return {
someCommonThing: someCommonThing,
// ...
};
})();
在 Common
模块中,如何引用调用模块中的函数?
我知道 .caller
,但显然 that is non-standard and should not be used .
我也许可以通过某种方式将调用模块的名称作为参数传递给 Common
,并引用它,但这看起来很难看:
// In PublicFoo
var init = function() {
$button.on('click', function() {
Common.someCommonThing(PublicFoo)
});
};
// In Common
var someCommonThing = function(callingModule) {
// ...
callingModule.bar();
我当然也可以提取 bar()
调用并在调用模块中执行它,但这看起来也不是那么整洁:
// In PublicFoo
var init = function() {
$button.on('click', function() {
Common.someCommonThing();
bar();
});
};
// ... and the same thing in AdminFoo
我觉得这一定是 JS 模块 101,这是一个基本要求,但我似乎找不到任何相关信息,尽管我可能使用了错误的术语进行搜索。或者是我找不到如何执行此操作的原因是因为它不应该以这种方式完成?
如何从 Common
模块引用适当的 bar()
?
最佳答案
I know about .caller, but apparently that is non-standard and should not be used.
它在您的情况下也不起作用,因为调用者是事件处理程序,既不是 PublicFoo
也不是 AdminFoo
。
I could maybe somehow pass in the name of the calling module as a parameter to Common, and reference it
是的,如果您希望 someCommonThing
在它完成后做不同的事情,传递对您想要调用的事物的引用是可行的方法。请注意,您真的应该只在事情是异步的时候才使用这样的回调,否则之后返回并调用 bar
(就像在您的最后一个片段中一样)要容易得多。
How can I reference the appropriate
bar()
from theCommon
module?
如果两个 bar
可能会同时加载到页面中,那么就没有办法绕过引用回调的参数。
但是,在您的示例中情况似乎并非如此 - 在一个页面上,AdminFoo
扮演 Foo
的 Angular 色,在另一页上 PublicFoo
承担 Foo
的 Angular 色。
所以只引用 Common
中的 Foo.bar
!让相应的页面用适当的值填充它,即
var Foo = AdminFoo
在管理页面和
var Foo = PublicFoo
在公共(public)页面上。
关于javascript - 如何引用调用 Javascript 模块?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49283084/
为了让我的代码几乎完全用 Jquery 编写,我想用 Jquery 重写 AJAX 调用。 这是从网页到 Tomcat servlet 的调用。 我目前情况的类似代码: var http = new
我想使用 JNI 从 Java 调用 C 函数。在 C 函数中,我想创建一个 JVM 并调用一些 Java 对象。当我尝试创建 JVM 时,JNI_CreateJavaVM 返回 -1。 所以,我想知
环顾四周,我发现从 HTML 调用 Javascript 函数的最佳方法是将函数本身放在 HTML 中,而不是外部 Javascript 文件。所以我一直在网上四处寻找,找到了一些简短的教程,我可以根
我有这个组件: import {Component} from 'angular2/core'; import {UserServices} from '../services/UserService
我正在尝试用 C 实现一个简单的 OpenSSL 客户端/服务器模型,并且对 BIO_* 调用的使用感到好奇,与原始 SSL_* 调用相比,它允许一些不错的功能。 我对此比较陌生,所以我可能会完全错误
我正在处理有关异步调用的难题: 一个 JQuery 函数在用户点击时执行,然后调用一个 php 文件来检查用户输入是否与数据库中已有的信息重叠。如果是这样,则应提示用户确认是否要继续或取消,如果他单击
我有以下类(class)。 public Task { public static Task getInstance(String taskName) { return new
嘿,我正在构建一个小游戏,我正在通过制作一个数字 vector 来创建关卡,该数字 vector 通过枚举与 1-4 种颜色相关联。问题是循环(在 Simon::loadChallenge 中)我将颜
我有一个java spring boot api(数据接收器),客户端调用它来保存一些数据。一旦我完成了数据的持久化,我想进行另一个 api 调用(应该处理持久化的数据 - 数据聚合器),它应该自行异
首先,这涉及桌面应用程序而不是 ASP .Net 应用程序。 我已经为我的项目添加了一个 Web 引用,并构建了各种数据对象,例如 PayerInfo、Address 和 CreditCard。但问题
我如何告诉 FAKE 编译 .fs文件使用 fsc ? 解释如何传递参数的奖励积分,如 -a和 -target:dll . 编辑:我应该澄清一下,我正在尝试在没有 MSBuild/xbuild/.sl
我使用下划线模板配置了一个简单的主干模型和 View 。两个单独的 API 使用完全相同的配置。 API 1 按预期工作。 要重现该问题,请注释掉 API 1 的 URL,并取消注释 API 2 的
我不确定什么是更好的做法或更现实的做法。我希望从头开始创建目录系统,但不确定最佳方法是什么。 我想我在需要显示信息时使用对象,例如 info.php?id=100。有这样的代码用于显示 Game.cl
from datetime import timedelta class A: def __abs__(self): return -self class B1(A):
我在操作此生命游戏示例代码中的数组时遇到问题。 情况: “生命游戏”是约翰·康威发明的一种细胞自动化技术。它由一个细胞网格组成,这些细胞可以根据数学规则生存/死亡/繁殖。该网格中的活细胞和死细胞通过
如果我像这样调用 read() 来读取文件: unsigned char buf[512]; memset(buf, 0, sizeof(unsigned char) * 512); int fd;
我用 C 编写了一个简单的服务器,并希望调用它的功能与调用其他 C 守护程序的功能相同(例如使用 ./ftpd start 调用它并使用 ./ftpd stop 关闭该实例)。显然我遇到的问题是我不知
在 dos 中,当我粘贴此命令时它会起作用: "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" https://google.
在 dos 中,当我粘贴此命令时它会起作用: "C:\Program Files (x86)\Google\Chrome\Application\chrome.exe" https://google.
我希望能够从 cmd 在我的 Windows 10 计算机上调用 python3。 我已重新安装 Python3.7 以确保选择“添加到路径”选项,但仍无法调用 python3 并使 CMD 启动 P
我是一名优秀的程序员,十分优秀!