- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试在 Meteor 应用程序中使用 Seriously.js 库 ( https://github.com/brianchirls/Seriously.js/ )。我已将该库放在我的 meteor 应用程序的/imports 文件夹中,并且我在整个函数的最顶部从 seriously.js 导出一个变量 Seriously:
export var Seriously = (function (root, factory) {
'use strict';
if (typeof define === 'function' && define.amd) {
// AMD. Register as an anonymous module.
define('seriously', function () {
var Seriously = factory(root);
if (!root.Seriously) {
root.Seriously = Seriously;
}
return Seriously;
});
} else if (typeof exports === 'object') {
// Node. Does not work with strict CommonJS, but
// only CommonJS-like enviroments that support module.exports,
// like Node.
module.exports = factory(root);
.
.
.
etc.
Seriously.js 代码的其余部分是相同的。然后,在客户端脚本中,我这样导入:
import {Seriously} from '/imports/seriously/seriously.js';
然后我有客户端代码。但是,在运行代码时,浏览器会抛出这个错误:
meteor.js?hash=ae8b8af…:930 Exception from Tracker afterFlush function:
2016-06-09 21:30:19.486 meteor.js?hash=ae8b8af…:930 TypeError: _seriously.Seriously is not a constructor
它引用了我的这部分代码:
var seriously = new Seriously();
并在 meteor 中编译:
var seriously = new _seriously.Seriously();
我尝试了多种方法将 Seriously 类导出到 meteor 中,但似乎没有任何效果,我遇到了同样的错误。有什么方法可以将这个库正确地导入到 meteor 中吗?
最佳答案
由于您在使用全新的 meteor 应用程序时也遇到了问题,我们将从一个新的应用程序开始:
meteor create myapp
cd myapp
meteor npm install
meteor
这里没什么特别的,我们只是在创建一个基本的应用程序。我们想使用 Meteor 提供的模块系统,这将确保我们的代码只在我们要求时运行。为此,我们将我们的库放在 imports
文件夹中,如果使用 import
语句从另一个文件引用该文件,Meteor 只会捆绑并包含该文件。我们可以将我们的 seriously.js
放在以下文件夹中:
imports/seriously/seriously.js
如果我们坚持使用默认的新应用程序,我们可以编辑 client/main.js
文件来导入它,这就是不同之处。
我们需要使用不带大括号的导入语句,例如:
import Seriously from '/imports/seriously/seriously.js';
import
语句中花括号内的部分是命名导出。为支持这一点,库必须执行类似 export { Something, SomethingElse, etc. }
的操作。
Seriously 是标准的第 3 方 JS 库,不使用此语法,因此我们回退到 export default Something
。在没有大括号的情况下导入时,我们只是将默认导出分配给我们选择的变量标识符,例如 Seriously
。
随着 import
的工作,我们现在可以在渲染模板时使用 Seriously:
Template.hello.onRendered(function helloOnRendered() {
var seriously = new Seriously();
var icon = seriously.source('#icon');
var target = seriously.target('#canvas');
target.source = icon;
seriously.go();
});
关于效果,如果您需要它们(显然是这种情况),由于 Meteor 在 1.3 中使用的新解析/导入代码,我们将遇到更多问题。
如果您尝试导入这样的效果:
import Seriously from '/imports/seriously/seriously.js';
import '/imports/seriously/effects/seriously.vignette.js';
Meteor 的输出将是:
Unable to resolve some modules:
"seriously" in /Users/HiDeo/test/myapp/imports/seriously/effects/seriously.vignette.js (web.browser)
If you notice problems related to these missing modules, consider running:
meteor npm install --save seriously
在 Web 浏览器中加载它会导致 Uncaught Error: Cannot find module 'seriously'
。
此问题在 this post 中有描述在他们的论坛上,但目前没有解决。
如果我们看the source code对于这个晕影效果,我们可以看到加载机制与论坛帖子中描述的相同并且存在问题。
在我们的例子中,factory(require('seriously'));
将被执行,但是没有模块'seriously'。正如帖子中所述,在问题得到解决之前,我们需要修改此加载机制以执行 factory(require('/imports/seriously/seriously.js'));
代替。整个 block 看起来像这样:
if (typeof define === 'function' && define.amd) {
// AMD. Register as an anonymous module.
define(['seriously'], factory);
} else if (typeof exports === 'object') {
// Node/CommonJS
factory(require('/imports/seriously/seriously.js'));
} else {
if (!root.Seriously) {
root.Seriously = { plugin: function (name, opt) { this[name] = opt; } };
}
factory(root.Seriously);
}
然后我们可以修改我们的代码以使用这个新效果:
Template.hello.onRendered(function helloOnRendered() {
var seriously = new Seriously();
var icon = seriously.source('#icon');
var target = seriously.target('#canvas');
var vignette = seriously.effect('vignette');
vignette.source = icon;
vignette.amount = 10;
target.source = vignette;
seriously.go();
});
重新加载后,将应用效果:
不幸的是,在问题得到解决或修复之前,我们需要对应用程序中使用的所有效果执行此操作。
关于javascript - 我试图将 Seriously.js 导入 meteor 应用程序,我收到一个对象类型错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37739097/
我正在通过 labrepl 工作,我看到了一些遵循此模式的代码: ;; Pattern (apply #(apply f %&) coll) ;; Concrete example user=> (a
我从未向应用商店提交过应用,但我会在不久的将来提交。 到目前为止,我对为 iPhone 而非 iPad 进行设计感到很自在。 我了解,通过将通用PAID 应用放到应用商店,客户只需支付一次就可以同时使
我有一个应用程序,它使用不同的 Facebook 应用程序(2 个不同的 AppID)在 Facebook 上发布并显示它是“通过 iPhone”/“通过 iPad”。 当 Facebook 应用程序
我有一个要求,我们必须通过将网站源文件保存在本地 iOS 应用程序中来在 iOS 应用程序 Webview 中运行网站。 Angular 需要服务器来运行应用程序,但由于我们将文件保存在本地,我们无法
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
假设我有一个安装在用户设备上的 Android 应用程序 A,我的应用程序有一个 AppWidget,我们可以让其他 Android 开发人员在其中以每次安装成本为基础发布他们的应用程序推广广告。因此
Secrets of the JavaScript Ninja中有一个例子它提供了以下代码来绕过 JavaScript 的 Math.min() 函数,该函数需要一个可变长度列表。 Example:
当我分别将数组和对象传递给 function.apply() 时,我得到 NaN 的 o/p,但是当我传递对象和数组时,我得到一个数字。为什么会发生这种情况? 由于数组也被视为对象,为什么我无法使用它
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界. 这篇CFSDN的博客文章ASP转换格林威治时间函数DateDiff()应用由作者收集整理,如果你
我正在将列表传递给 map并且想要返回一个带有合并名称的 data.frame 对象。 例如: library(tidyverse) library(broom) mtcars %>% spl
我有一个非常基本的问题,但我不知道如何实现它:我有一个返回数据框,其中每个工具的返回值是按行排列的: tmp<-as.data.frame(t(data.frame(a=rnorm(250,0,1)
我正在使用我的 FB 应用创建群组并邀请用户加入我的应用群组,第一次一切正常。当我尝试创建另一个组时,出现以下错误: {"(OAuthException - #4009) (#4009) 在有更多用户
我们正在开发一款类似于“会说话的本”应用程序的 child 应用程序。它包含大量用于交互式动画的 JPEG 图像序列。 问题是动画在 iPad Air 上播放正常,但在 iPad 2 上播放缓慢或滞后
我关注 clojure 一段时间了,它的一些功能非常令人兴奋(持久数据结构、函数式方法、不可变状态)。然而,由于我仍在学习,我想了解如何在实际场景中应用,证明其好处,然后演化并应用于更复杂的问题。即,
我开发了一个仅使用挪威语的应用程序。该应用程序不使用本地化,因为它应该仅以一种语言(挪威语)显示。但是,我已在 Info.plist 文件中将“本地化 native 开发区域”设置为“no”。我还使用
读完 Anthony's response 后上a style-related parser question ,我试图说服自己编写单体解析器仍然可以相当紧凑。 所以而不是 reference ::
multicore 库中是否有类似 sapply 的东西?还是我必须 unlist(mclapply(..)) 才能实现这一点? 如果它不存在:推理是什么? 提前致谢,如果这是一个愚蠢的问题,我们深表
我喜欢在窗口中弹出结果,以便更容易查看和查找(例如,它们不会随着控制台继续滚动而丢失)。一种方法是使用 sink() 和 file.show()。例如: y <- rnorm(100); x <- r
我有一个如下所示的 spring mvc Controller @RequestMapping(value="/new", method=RequestMethod.POST) public Stri
我正在阅读 StructureMap关于依赖注入(inject),首先有两部分初始化映射,具体类类型的接口(interface),另一部分只是实例化(请求实例)。 第一部分需要配置和设置,这是在 Bo
我是一名优秀的程序员,十分优秀!