javascript - 我试图将 Seriously.js 导入 meteor 应用程序,我收到一个对象类型错误

标签 javascript node.js oop meteor html5-video

我正在尝试在 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();
});

重新加载后,将应用效果:

Effect

不幸的是,在问题得到解决或修复之前,我们需要对应用程序中使用的所有效果执行此操作。

关于javascript - 我试图将 Seriously.js 导入 meteor 应用程序,我收到一个对象类型错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37739097/

相关文章:

javascript - Microsoft Edge 弹出扩展如何获取背景页面?

javascript - 从字符串 api 响应 aws lambda 中删除 '\'

javascript - 使用discord.js 将机器人消息保存在变量中

mysql - Node.js MySQL - 错误 : connect ECONNREFUSED

r - 如何修改系统打印方式?

javascript - rails : Trying to render a partial on button click

javascript - 在加载状态之前,我需要为 Angular js中的每个状态添加角色?

C++虚函数重新实现

c# - 面向组件的设计 : Problems with dependencies in dialogs

javascript - 如何使用 "this"在事件处理程序中获取类变量