javascript - Magento 2 : moment is not defined

标签 javascript requirejs momentjs magento2

我正在尝试在我的 Magento 2 网站上使用 Shipping Time JS 插件,它需要 moment.js 和 jQuery 才能工作,但它不工作。我在第 49 行的 shiptime.js 中收到一个ReferenceError: moment is not defined,如下所示:

try {
        if (moment === undefined || $ === undefined ) throw Error("please include jquery & moment.js");
    } catch (e) {
        console.log(e);
    }

==============

我的 require.js

这就是我的 requirejs-config.js 的样子,它位于 app/design/frontend/##/##/requirejs-config.js 中:

var config = { // eslint-disable-line no-unused-vars
packages: [{
    name: 'momentjs',
    location: 'js/',
    main: 'moment'
}],
map: {
    '*': {
        'menu': 'Magento_Theme/js/disable-menu',
        'shippingtime': 'js/shiptime'
    }
},
shim: {
   'momentjs': {
       deps: ['jquery']
   },
  'shippingtime': {
      deps: ['jquery',',momentjs']
  }
}

};

jQuery 在其他地方加载并且肯定正在加载(我有各种其他 jQuery 库都在工作)。

==============

调试

我最初以为没有加载 moment.js/shiptime.js 文件,但是当我检查源和网络面板时它们加载了。为了进一步测试这一点,我执行了以下操作以查看 moment.js 是否会输出任何内容:

require(['momentjs'], function (moment) {

        console.log(moment().format('LLLL'));
    });

这确实在控制台中输出了日期,所以 moment.js 肯定正在加载,这是我的 shiptime.js 文件代码,它不起作用并给我上面提到的错误:

require(['jquery', 'shippingtime', 'momentjs'], function (moment) {
        jQuery(document).ready(function () {
            jQuery(function($) {
                jQuery('.shipping-time').shipTime();
            });
        });
    });

如有任何建议,我们将不胜感激!

最佳答案

自从我使用 requirejs 以来已经有一段时间了,但由于没有人更聪明地插话,但我很乐意帮助您继续进行故障排除。将 jQueryrequirejs 一起使用可能会很棘手,尤其是对于像 Magento 这样的大型复杂平台。

在无法看到您的所有代码的情况下,我会考虑并调查以下内容:

  1. 如有必要,您是否以无冲突的方式正确初始化了 jQuery
  2. 您是否按预期使用 require()define()
  3. 您是否精通 Magento 在使用 requirejs 时遇到的独特挑战
  4. 您是否查看并遵循了关于将 momentrequirejs 一起使用的复杂性的建议

这里有一些对应的读物:

  1. On No-Conflict
  2. require() vs define() plus other good insights
  3. On Magento 2 with RequireJS
  4. 关于 Moment 和 RequireJS 的复杂性
    1. https://momentjs.com/docs/#/use-it/require-js/
    2. https://github.com/requirejs/requirejs/issues/1554#issuecomment-226269905

最后一件事要尝试:

在您的最终代码示例中,您将 moment 传递给函数,而不是 jQuery。您是否尝试过以下方式:

require(['jquery', 'momentjs', 'shippingtime'], function($, moment) {
  $(document).ready(function() {
    $('.shipping-time').shipTime();
  });
});

关于javascript - Magento 2 : moment is not defined,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57196886/

相关文章:

javascript - 将 json 数据 POST 到 Bottle

javascript - Dojo 声明 - 默认属性的范围(实例或静态)

javascript - 如何用Momentjs精确计算年龄?

javascript - 时刻范围 : Need to divide day into 15 minute slices

javascript - 如何获取本周的日期范围?

javascript - 粘性侧边栏停止在页脚上方 30 像素?

javascript - 在javascript数组中插入项目并排序

javascript - 显示集合的模板在数据插入后不会自动更新

javascript - 将 Openlayers 3 和 proj4js 与 RequireJS 结合使用

backbone.js - backbone.localStorage,require.js, "Uncaught TypeError: undefined is not a function"