- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近看到了一个我无法解释的问题,我不知道如何调试以找出是什么改变了我所看到的。刚开始时,我无法设置重现环境,因为我不知道是什么原因造成的。我只能解释我所看到的,看看是否有人看过或知道如何弄清楚发生了什么。
所以,正如标题所说,我的页面上有一个正常启动的元素,但在某个时候元素的类属性之一(即“class1 class2 等”)确实在每个元素之间放置了一个空格字符(即“c l a s s 1 c l a s s 2 e t c”)。
这发生在包含两个 JavaScript 包的页面上,它们都使用 Webpack 打包并使用 Babel。这个问题只发生在 IE11 中,所以 Babel 转换也使用了一些 core-js polyfills,其中我使用的是 core-js 3。这对两个包都是通用的。我在这些包的各种版本中看到过这个问题,有些组合没有出现这个问题,但是一个包的某些版本会一直导致它。并且这两个包似乎都能够导致它,通过在一个包中隔离一个包并更改另一个包并看到事情发生变化来证明。所以我倾向于它与依赖关系有关(即 webpack、babel、core-js 或其他东西,但这些是主要的东西)。当我看到哪些包好哪些不好时,我比较了构建输出,但没有注意到任何突出的原因。
这是我上面描述的类属性的屏幕截图:
所以,我的问题:
就像我说的,这是一个非常奇怪的问题,所以我真的不希望得到任何答案,但如果有人能提供任何帮助或关于该怎么做的想法,我将不胜感激。谢谢。
编辑:添加一些配置,一切都很标准
包 1(非 UI 组件):包 1 Babel 配置:
module.exports = {
"presets": [
[
"@babel/preset-env",
{
targets: {
browsers: [
"> 0.25%",
"last 2 versions",
"ie 11",
"edge 18",
"safari >= 11",
"not dead"
]
},
corejs: 3,
useBuiltIns: "usage",
debug: false
}
]
],
"ignore": [
/babel-/,
/@babel\/runtime/,
/core-js/,
/regenerator-runtime/
],
"plugins": [
[
"@babel/plugin-proposal-decorators",
{
legacy: true
}
],
[
"@babel/plugin-proposal-class-properties",
{
loose: true
}
],
[
"@babel/plugin-transform-runtime",
{
regenerator: true,
corejs: 3
}
]
],
"sourceMaps": true,
"sourceType": "unambiguous"
};
Package 1 Webpack 配置(合并在一起):
(常见):
{
entry: path.join( __dirname, 'src', 'Main.js' ),
devtool: 'source-map',
output: {
devtoolNamespace: 'APPNAME'
},
module: {
rules: [
{
enforce: 'pre',
test: /\.js$/,
loader: 'eslint-loader',
exclude: [
/node_modules/
]
},
{
test: /\.js$/,
loader: 'babel-loader',
}
]
},
plugins: [
new webpack.optimize.LimitChunkCountPlugin({
maxChunks: 1
})
]
};
(生产):
{
mode: 'production',
output: {
path: path.join(__dirname, 'dist'),
filename: libnamemin
},
optimization: {
moduleIds: 'total-size',
mangleWasmImports: true,
concatenateModules: false,
minimizer: [
new BabelMinifyPlugin({
removeDebugger: true,
mangle: true
},{
comments: false,
sourceMap: 'source-map'
})
]
},
module: {
rules: []
},
plugins: [
new CleanWebpackPlugin(),
new BundleAnalyzerPlugin({
analyzerMode: 'static',
openAnalyzer: false,
generateStatsFile: true,
reportFilename: path.join(__dirname, './reports/bundle/report.html'),
statsFilename: path.join(__dirname, './reports/bundle/stats.json')
})
]
};
包2(UI组件使用“customElements”,在IE11中,“webcomponentsjs”polyfill)包2 Babel配置:
module.exports = {
"presets": [
[
"@babel/preset-env",
{
targets: {
browsers: [
"> 0.25%",
"last 2 versions",
"ie 11",
"edge 18",
"safari >= 11",
"not dead"
]
},
corejs: 3,
useBuiltIns: "usage",
debug: false
}
]
],
"ignore": [
/babel-/,
/@babel\/runtime/,
/core-js/,
/regenerator-runtime/,
/webcomponentsjs/,
/@webcomponents/
],
"plugins": [
[
"@babel/plugin-proposal-decorators",
{
legacy: true
}
],
[
"@babel/plugin-proposal-class-properties",
{
loose: true
}
],
[
"@babel/plugin-transform-runtime",
{
regenerator: true,
corejs: 3
}
],
[
"@babel/plugin-syntax-dynamic-import",
{ }
]
],
"sourceMaps": true,
"sourceType": "unambiguous"
};
Package 2 Webpack 配置(合并在一起):
(常见)
{
entry: path.join( __dirname, 'src', 'App.js' ),
devtool: 'source-map',
output: {
devtoolNamespace: 'APPNAME'
},
module: {
rules: [
{
enforce: 'pre',
test: /\.js$/,
loader: 'eslint-loader',
exclude: [
/node_modules/
]
},
{
test: /\.(svg|png|woff|woff2)$/,
loader: 'url-loader'
},
{
test: /\.css|\.s(c|a)ss$/,
use: [
'to-string-loader',
{
loader: 'css-loader',
options: {
importLoaders: 1
}
},
{
loader: 'sass-loader',
options: {
sassOptions: {
importer: jsonImporter()
}
}
}
]
},
{
test: /\.js$/,
loader: 'babel-loader',
options: {
root : __dirname,
rootMode: 'upward-optional'
}
}
]
},
plugins: [
new UnusedFilesWebpackPlugin({
patterns: ['./src/resources/images/*', './src/resources/logos/*'],
}),
new webpack.optimize.LimitChunkCountPlugin({
maxChunks: 1
})
]
};
(生产):
{
mode: 'production',
output: {
path: path.join(__dirname, 'build'),
filename: 'APPNAME.min.js'
},
optimization: {
moduleIds: 'total-size',
mangleWasmImports: true,
concatenateModules: false,
minimizer: [
new BabelMinifyPlugin({
removeDebugger: true,
mangle: true
},{
comments: false,
sourceMap: 'source-map'
})
]
},
module: {
rules: []
},
plugins: [
new CleanWebpackPlugin(),
new webpack.DefinePlugin({
'process.env.__TF_NAME__': JSON.stringify(pkg.name),
'process.env.__TF_VERSIONBUILD__': JSON.stringify('__METADATA_VERSION_BUILD__'),
'process.env.__TF_VERSION__': JSON.stringify('__METADATA_VERSION__'),
'process.env.__TF_BUILDDATE__': JSON.stringify((new Date(Date.now())).toUTCString())
}),
new BundleAnalyzerPlugin({
analyzerMode: 'static',
openAnalyzer: false,
generateStatsFile: true,
reportFilename: path.join(__dirname, './reports/bundle/report.html'),
statsFilename: path.join(__dirname, './reports/bundle/stats.json'),
})
]
};
最佳答案
这对谷歌来说不是一个容易的问题,但我在尝试的过程中找到了这篇文章!
最终,我通过(繁琐的)调试找到了问题的原因。事实证明这是 core-js
问题的结果:
https://github.com/zloirock/core-js/issues/751
使用以下命令降级解决了问题:
npm install core-js@3.5.0 --save
关于javascript - HTML 元素的属性文本字面上在字符之间添加了空格(或者如何找出正在改变元素属性的内容?),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63963633/
我有这个代码来查找这个模式:201409250200131738007947036000 - 1,在文本内 final String patternStr = "(\\d{
我正在尝试使用正则表达式清除一些用户输入,以删除 [ 和 ] 并删除任何大于 1 个空格的空格。但我似乎无法实现我想要的效果。这是我第一次使用正则表达式,所以我对如何写出来有点困惑。 (preg_re
我正在尝试构建这个简单的正则表达式来匹配 Java 中的单词+空格,但我在尝试解决它时感到困惑。该网站上有很多类似的示例,但答案大多给出了正则表达式本身,而没有解释它是如何构造的。 我正在寻找的是形成
好吧,我已经阅读了很多建议如何消除多余空间的帖子,但无论出于何种原因,我似乎无法将这些建议应用到我的系统中,所以我在这里寻求您的帮助。 这些是我代码的最后几行: for line in rli
所以我正在我的测试存储上学习网页抓取,但我不确定如何正确地从“sizes”数组中删除空的新行。 const $ = cheerio.load(body) $('div.lis
这个问题已经有答案了: How to prevent invalid characters from being typed into input fields (8 个回答) 已关闭 9 年前。 是
有人知道如何让扫描仪忽略空间吗?我想输入名字和第二个名字,但扫描仪不让我输入,我想保存全名 String name; System.out.print("Enter name: "); name =
这个问题在这里已经有了答案: Make Vim show ALL white spaces as a character (23 个回答) 关闭 8 年前。 VIM(使用 Solarized Dar
我想使用 StreamTokenizer 从 java 文件中提取名称。我已将空格设置为逗号 inputTokenizer.whitespaceChars(',', ','); 但是,
我正在使用此代码逐行读取 txt 文件。 // Open the file that is the first command line parameter FileInputStream fstre
我似乎无法弄清楚我需要的正则表达式。这就是我想要实现的目标: {ANY CHAR} + @javax.persistence.Column(name = "{ANY 30 CHARS}") + {AN
我正在运行 StyleCop(顺便说一句,如果你想提供高质量的代码,我完全推荐它)... 我有这条线 [System.Xml.Serialization.XmlRootAttribute(Namesp
我刚刚更新到 PhpStorm 2016,我突然注意到,每次我按 Ctrl + S 保存文件时,它都会删除我在测试这段代码后按下以继续编写的空格/制表符。 请帮忙,这对我来说很烦人,因为我在每一行代码
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 Improve th
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度的了解。包括尝试的解决方案、为什么它们不起作用以及预期结果
我已经看过几十个关于这个主题的问题和答案,但我仍然无法解决我的问题。 我在我的代码中使用了一个外部 ffmpeg 转换器,我将文件路径作为参数传递,如下所示: OutputPackage oo = c
谁能详细解释一下它们是什么以及它们之间的区别。提前致谢。 最佳答案 转义序列是代表其他内容的字符序列。例如(“\n” = 新行,“\?” = 问号等)。有关更详细的列表,请检查:https://en.
我无法从我的 javascript 文本中删除换行符。这是我正在处理的数据示例: 0: "Christian Pulisic" 1: "↵" 2: "From Wikipedia, the free
我有一个问题 - 我似乎无法从字符串的开头/结尾删除新行/空格。我在正则表达式的开头和结尾使用 \s ,甚至在获取字符串后使用 .trim() ,但无济于事。 public void extractI
我是 php 的新手,我正在尝试将一系列变量添加到 html 超链接中。但是,任何返回空格的变量都会弄乱超链接。 Grants Test
我是一名优秀的程序员,十分优秀!