当你使用webpack时,是否有任何方法可以停止moment.js加载所有的locale(我只需要英语)?我在看源代码,似乎如果hasModule是定义的,这是为webpack,那么它总是试图要求()每个地区。我很确定这需要一个拉请求来修复。但是我们是否可以通过webpack配置来解决这个问题呢?

下面是加载momentjs的webpack配置:

resolve: {
            alias: {
                moment: path.join(__dirname, "src/lib/bower/moment/moment.js")
            },
        },

然后在任何我需要它的地方,我只需要('moment')。这是有效的,但它增加了大约250kb的不需要的语言文件到我的包。我还使用了momentjs和gulp的凉亭版本。

另外,如果webpack配置不能解决这个问题,这里有一个加载locale的函数的链接。我试着添加&& module.exports.loadLocales到if语句,但我猜webpack实际上并没有以那种方式工作。它只是要求无论什么。我想它现在用的是正则表达式所以我不知道你会怎么去修正它。


当前回答

在我们的项目中,我包括了这样的moment: import moment from 'moment/src/moment';这似乎奏效了。我们对moment的使用非常简单,所以我不确定是否会与SDK有任何不一致。我认为这是可行的,因为WebPack不知道如何静态地找到locale文件,所以你会得到一个警告(这很容易通过在moment/src/lib/locale/locale添加一个空文件夹来隐藏),但没有locale包含。

其他回答

使用webpack2和moment的最新版本,您可以:

import {fn as moment} from 'moment'

然后在webpack.config.js中:

resolve: {
    packageMains: ['jsnext:main', 'main']
}

下面是在NPM安装程序中使用postinstall脚本的另一个解决方案。

你可以在你的包裹上放一条线。json文件:

{
  "scripts": {
    ...
    "postinstall": "find node_modules/moment/locale -type f -not -name 'en-gb.js' -not -name 'pl.js' -printf '%p\\n' | xargs rm"
    ...
  }
}

因此,不需要的区域设置将在npm install完成安装包后立即删除。

在我的例子中,只有engb和pl locale将保留在bundle中。

如果你已经有postinstall脚本,你可以添加脚本到现有的命令:

{
  "scripts": {
    ...
    "postinstall": "previous_command && find node_modules/moment/locale -type f -not -name 'en-gb.js' -not -name 'pl.js' -printf '%p\\n' | xargs rm"
    ...
  }
}

更新:2021 还有许多其他的库,你可能想签出:

https://date-fns.org https://github.com/iamkun/dayjs

最初的回答: 似乎合适的模块化时刻库永远不会出现然而,我刚刚结束使用https://github.com/ksloan/moment-mini像import *时刻从'moment-mini';

根据亚当·麦克米克的回答,你已经很接近了,把你的别名改成

resolve: {
    alias: {
        moment: 'moment/src/moment'
    },
},

在我们的项目中,我包括了这样的moment: import moment from 'moment/src/moment';这似乎奏效了。我们对moment的使用非常简单,所以我不确定是否会与SDK有任何不一致。我认为这是可行的,因为WebPack不知道如何静态地找到locale文件,所以你会得到一个警告(这很容易通过在moment/src/lib/locale/locale添加一个空文件夹来隐藏),但没有locale包含。