这个文章用于归档一些我在工作或者平时写项目时碰上的 BUG。

Element Plus

表单校验通过但阻塞后续流程

今天上线给策划用的项目,他们反馈提交表单时无效。我在本地看了下代码没有任何问题,事件触发也正常。

最后是发现 formRules 中自定义的校验规则,除去捕获到的校验错误有 callback,正常情况下没有捕获的校验错误也必须得返回一个空的 callback,否则是无法通过校验而且不会有校验错误的提示!!!

const formRules = ref<FormRules>({
  name: [
    {
      validator: (rule, value, callback) => {
        const c = 'something'

        if (c) {
          callback(new Error('课程名称已存在'))
        }
        // 这里一定要记得调用一次callback()
        callback()
      }
    }
  ]
})

table 设置高度问题

一般使用el-table时,大部分都需要固定表格高度防止整个页面滚动。element-plus 文档给了 api: height来设置。但是如果是这种形式calc(100% - 12px)这种计算形式,会出现表格底部多出来一部分,这部分高度。

如果给计算高度,el-tableel-table__inner-wrapper都会设置这个高度。

解决: 添加max-height使用计算高度,height使用 100%高度

<el-table
  :data="pageDataSource"
  max-height="calc(100% - 38px)"
  height="100%"
>

el-select 宽度问题

最近给项目更新了 element-plus 版本到最新的 2.7+,之前的老版本是 2.4,更新之后发现,我自定义样式的 select 组件样式完全错乱了,而且没有就算使用原来组件的样式,该组件也没有宽度。

这就很奇怪,我开始还以为是我打包后的样式没有引入进去。尝试从这方面找问题一直找不到,后面我就来到官方仓库的 issues 下找问题,发现了根本原因,官方在 2.5.0 版本对 el-select 进行了重构,组件的 dom 结构完全变了。

stylelint v15

今天按照我自己文章统一代码风格和规范项目代码搭建项目时,走到配置 stylelint 这步时出现了问题:

  1. 按照步骤安装了 stylelint 和一系列相关依赖
  2. 新建了stylelintrc.cjs等文件
  3. 添加script脚本命令"lint:stylelint": "stylelint \"./**/*.{css,less,scss,vue,html}\" --fix"
  4. 运行脚本命令

然后就发现了报错:

一系列的 unknown…

原因是我安装了的stylelintv15 以上的版本,stylelint 的 github issues 中已经有提出到这个bug并且已经关闭了,原因就是 v15 已经废弃了"stylelint-config-prettier"

原文: 从 Stylelint v15 开始,所有与样式相关的规则已被弃用。如果您使用的是 v15 或更高版本并且不使用这些已弃用的规则,则不再需要此插件。

所以删掉这行代码重启 IDE 即可:

// stylelintrc.cjs
module.exports = {
  extends: [
    'stylelint-config-standard',
    'stylelint-config-prettier', // [!code --]
    'stylelint-config-recommended-scss',
    'stylelint-config-standard-vue'
  ]
}

commit 报错

使用git-cz来提交项目代码时,执行pnpm commit后会出现报错:

.commitlintrc.cjs的编码改成 utf-8 即可。

eslint 报错

有可能在项目中碰到下面这种情况:

你可能会以为是eslint文件的配置有问题,后来发现配置正常;你也可能会以为是ts.config.json配置有问题,后来发现配置也是正常的。

其实问题原因是在于你的eslint文件的格式,当你的eslint版本大于等于v8.21时,且文件格式为eslint.config.js就会出现这种问题,这时候只需要打开 vscode 的一项配置即可:

TIP

另外,可能会以为配置文件改成.eslintrc.js就可以了,这样确实没错,但是要注意的是官方将在 v9 版本中废弃这种格式。 https://zh-hans.eslint.org/docs/latest/use/configure/configuration-files

新版 Volar(vue-official)

这个 bug 应该会在后期修复,记录下我当时碰到的时间点(2024-03-21)。

最近打开 vscode 会有提示说volar已经废弃,建议使用新插件Vue-official,更新之后,会发现很多项目都会报错无法识别导入的文件、和方法啥的。这在仓库 issues 中也有提出各种各样的 bug。应该就是新的插件还不稳定,这只能等官方修复了。

但是项目一直爆红那也没办法开发了,那怎么办呢?亲测把插件降级到v1.8.27版本能解决这个问题。但是有时候还是不生效,需要频繁来回切换版本才能解决。

Safari 上音频播放显示错误

这个问题是由于你加载的文件类型错误的原因,可以看看 network 中文件请求的 response type 是不是application/json或者application/octet-stream等,要确保加载的音频为audio/xxx,在 Safari 上才能播放正确。请找你的后端帮你处理成音频类型返回吧。

Safari 网页遮挡

在 Safari 浏览器中网页会被遮挡底部或顶部。

不管是新的还是就的 ios,它们的 safari 浏览器的屏幕高度(screen height)都是包括了工具栏和地址栏的。就是图中括起来的部分,可以看到网页会被地址栏工具栏遮挡掉一部分,而且上下滑动也无法解决。而安卓的屏幕高度并不会包括工具栏地址栏。

所以,尽量避免给标签设置100vh单位的高度,这将会导致网页在 safari 浏览器被遮挡一部分。

TIP

当然你也可以通过给标签设置paddingmargin让页面被遮挡部分留空,但是这并不是一个好的办法。

React 出现 @@INIT action…

@@INIT or REPLACE action resets the state of the app or last actions RE-APPLIED.

启动 React 项目可能你会有这种类似的错误,这是由于 Redux Devtool 浏览器插件导致的,禁用掉后就正常了。

如果需要使用这个插件,可以参考其他办法:

redux devtool 一次崩溃的bug的解决

@@INIT action resets the state of the app

AntD 组件 popover 配合 checkbox 出现无限抖动

先看例子,第三个 popover 是异常的:

你能发现这个 bug 是因为什么原因导致的吗?

我通过查看打开 popover 过程中的动画时,发现有一个动画会一直重复执行:

TIP

打开 animations 标签需要在tab右侧菜单中的更多工具打开 animations

这时候就可以根据执行动画的元素 span.ant-checkbox.ant-checkbox-checked::after 去找到对应的元素了。找到后可以发现 checkbox 选中后伪元素的样式为:

.ant-checkbox-checked::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 1px solid #1890ff;
  border-radius: 2px;
  visibility: hidden;
  animation: antCheckboxEffect 0.36s ease-in-out;
  animation-fill-mode: backwards;
  content: '';
}

@keyframes antCheckboxEffect {
  0% {
    transform: scale(1);
    opacity: 0.5;
  }
  100% {
    transform: scale(1.6);
    opacity: 0;
  }
}

看到 animation 属性后禁用掉或者修改动画属性scale使效果扩大变小一点,这个bug就解决了。这是第一种解决方式。

这个原因应该是因为选中过程的动画放大导致的,而且bug出现的条件为:

  1. popover的content有一层div包裹
  2. 这个div有overflow: auto属性
  3. checkbox横向排列时不管哪个选中都会触发bug
  4. chechbox纵向排列时,只有最后一个checkbox选中才会触发bug

第二种解决方法就是给div加上一个适当的上下padding就可以解决

CC BY-NC-SA 4.0 2023-PRESENT © Leet