- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
对于 webpack 3,我使用的是 moment-timezone-data-webpack-plugin减少我的包大小并且效果很好。测试表明它显着减小了包的大小。我现在已经升级到 webpack 4 和 create-react-app 4,看起来像
据我所知,moment-timezone 在我的应用程序中运行正常,所以我很困惑。
Webpack 4 在减少包大小方面做得更好,但它无法知道我的应用程序运行时需要哪些时区数据,所以我无法想象这怎么可能成为答案的一部分。
最佳答案
很抱歉这不是答案,但希望它能节省一些时间。
MomentJS 已经意识到他们的规模有一段时间了,并已采取措施尝试构建他们的项目,以便更好地剥离它。他们已经构建了他们的项目,因此语言环境是分开存储的。
但是这里的技巧是你提到了 CreateReact4,你没有在干净的房间里测试它,所以任何东西都可能生效。
创建 React 4 文档:
Troubleshooting.md - MomentJS Locales are Missing
If you use a Moment.js, you might notice that only the English localeis available by default. This is because the locale files are large,and you probably only need a subset of all the locales provided byMoment.js.
To add a specific Moment.js locale to your bundle, you need to importit explicitly.
这是因为 CreateReact4 默认配置为删除语言环境
react-scripts/config/webpack.config.js#L671-L678
// Moment.js is an extremely popular library that bundles large locale files
// by default due to how webpack interprets its code. This is a practical
// solution that requires the user to opt into importing specific locales.
// https://github.com/jmblog/how-to-optimize-momentjs-with-webpack
// You can remove this if you don't use Moment.js:
new webpack.IgnorePlugin({
resourceRegExp: /^\.\/locale$/,
contextRegExp: /moment$/,
}),
您可以使用您在问题中提到的插件进一步 trim 它(您是否检查过它是否甚至被调用/兼容?),但大部分 gzip 数据实际上是语言环境,而不是时区数据, (TZ 不会轻易压缩)。
Moment TZ Data Plugin在他们的网站上声明根据配置可以节省各种费用。
Default 1164 KiB 105 KiB
Strip locales 959 KiB (~82%) 56 KiB (~53%)
Strip tz data 265 KiB (~23%) 69 KiB (~66%)
Strip locales & tz data 60 KiB (~5%) 20 KiB (~19%)
因此 CreateReact4 剥离不需要的语言环境的默认行为,默认情况下可能会减少 53%(gzipped)。
但是您声明 Moment-js 使用的是 7k... 所以虽然这是对可能发生的事情的一个很好的分割,但显然还有其他因素在起作用,甚至 moment.js-min 是 18kb。
关于javascript - 为什么 moment-timezone 在 webpack 4 和/或 create react app 4 中使用的空间要少得多?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68603977/
我需要以 [+/-]hh:mm 格式保存手机的时区 我正在使用 TimeZone 类来处理这个问题,但我能得到的唯一格式如下: PST -05:00 GMT +02:00 我宁愿不对结果进行子串化,是
我正在尝试在 Node js 中使用 moment-timezone 来获取所有可用时区的列表,如下所示 - var moment = require('moment-timezone'); var
我正在使用以下代码将时区 (GMT-3) 转换为设备本地时区。 int hour=17,minute=0,day=12,month=6,year=2014; Calendar cal = new Gr
System.setProperty("user.timezone", "America/Chicago"); TimeZone.setDefault(TimeZone.getTimeZone("美国
我想从字符串初始化DateFormatter().timeZone,但是当我做类似的事情时 let dateFormatter = DateFormatter() dateFormatter.time
我通过存储日期组件字典在我的后端存储用户出生日期。它看起来像这样: { "day": 1, "month": 1, "year": 1970, "timeZone":
我一直在开发一个应用程序,它以下面给出的特定格式从服务器获取日期。 "2015-02-03 00:00:00" 我想使用 NSDateFormatter 以不同的 UI 格式显示它们但是当我更改时区时
我有什么 我有一个来自服务器的日期字符串,它的格式是 w3c 日期格式 2016-02-13T09:53:49.871Z 我的问题 当我将消息发布到服务器时,它显示的是 5 小时前而不是现在 我想要什
我正在将我的项目从 Django 1.8.2 升级到 1.9.7,我收到了这个警告: WARNINGS: my_app.my_model.date_available: (fields.W161) F
在下面的代码中: from datetime import datetime import pytz EDT = pytz.timezone('US/Eastern') d1 = datetime.n
我通过以下方式将服务器(Ubuntu 12.04)的时区更改为UTC: echo 'UTC' > /etc/timezone dpkg-reconfigure --frontend nonintera
我想获取洛杉矶的时区信息,现在10/10/2017是夏令时,但是我通过两种方式获取洛杉矶的时区得到了不同的结果。 public class TimeZoneDemo2 { public stati
我把它放在应用程序 Controller 中: before_filter :set_timezone def set_timezone Time.zone = current_user.time_
是否可以转换java.util.TimeZone字符串 sun.util.calendar.ZoneInfo[id=\"America/Los_Angeles\",offset=-28800000,d
当我写这段代码时: Calendar cal = Calendar.getInstance(); cal.setTimeZone(TimeZone.getTimeZone("EST"));
我正在使用 Java 8, 在我们的代码的前面,我们使用 sdf.setTimeZone(TimeZone.getTimeZone("PDT")); 转换为失败的美国太平洋地区(没有抛出任何错误,但转
我不断收到此警告:timezone of object (UTC) is different than current timezone ().我当前的时区是“EET”,如 Sys.timezone(
我正在我的网站上使用时刻时区转换器进行时区日期转换。默认情况下,我在 IST 中显示日期和时间。我有一个按钮可以转换用户时区中的给定时间。此按钮操作调用 moment js 并进行转换。到这里我没有问
我从服务响应中获得时区偏移量为“-5.00”,我需要在 UI 中将其格式化为 CST。我如何在 JavaScript 中转换它?我搜索了一下,不确定JavaScript中有没有直接的方法。 最佳答案
这个问题在这里已经有了答案: Converting string to datetime object (2 个答案) 关闭 6 年前。 我的主机有 UTC 时区,我正在尝试将 PDT 时间字符串转
我是一名优秀的程序员,十分优秀!