Vue+css实现扫描动画效果(使用@keyframes scan)

实现效果

扫描效果

参考链接

MDN Web Docs: CSS Animations

关键代码

示例代码

html 复制代码
 <div class="scanner-container">
      <div class="scanner-line"></div>
      <div class="scanner-icon">📷</div>
      <p>Scan material barcode to map to this box</p>
      <el-input v-model="form.boxStr" @keyup.enter.native="getPosNameChange()" />
</div>
css 复制代码
.scanner-container {
  border-radius: 4px;
  padding: 16px;
  text-align: center;
  margin: 16px 0;
  position: relative;
  min-height: 180px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  ::v-deep .el-input--small .el-input__inner {
    background-color: #363838;
    color: #e0e0e0;
    height: 55px;
    line-height: 55px;
  }
  p {
    font-size: 14px;
    color: #e0e0e0;
    margin-bottom: 16px;
  }
}

.scanner-line {
  position: absolute;
  width: 100%;
  height: 2px;
  background-color: #5c6bc0;
  top: 50%;
  left: 0;
  animation: scan 2s linear infinite;
  z-index: 1;
}

@keyframes scan {
  0% {
    top: 25%;
  }
  50% {
    top: 75%;
  }
  100% {
    top: 25%;
  }
}

常见问题及解决方法

动画不生效:

确保CSS选择器正确,能够选中需要应用动画的元素。

检查@keyframes定义是否正确,关键帧的百分比和样式是否正确。

确保元素的position属性设置为relativeabsolute,以便动画能够正确应用。 动画性能问题:

尽量避免在动画中使用复杂的CSS属性,如box-shadowborder-radius等。

使用will-change属性来提示浏览器提前优化动画元素

相关推荐
IT_陈寒2 分钟前
Vite 5分钟性能优化实战:从3秒到300ms的冷启动提速技巧(附可复用配置)
前端·人工智能·后端
迦南giser2 分钟前
webpack从0到1详解
前端·javascript·css·webpack·node.js
xkxnq2 分钟前
第二阶段:Vue 组件化开发(第 26天)
前端·javascript·vue.js
华玥作者5 分钟前
uni-app + Vite 项目中使用 @uni-helper/vite-plugin-uni-pages 实现自动路由配置(超详细)
前端·uni-app·vue·vue3·vite
m0_748254667 分钟前
HTML 文本格式化基础
前端·html
十六年开源服务商8 分钟前
WordPress集成GoogleAnalytics最佳实践指南
前端·人工智能·机器学习
小救星小杜、10 分钟前
el-form 表格校验 开始和结束时间,时间选择范围
javascript·vue.js·elementui
狼性书生11 分钟前
uniapp+vue3实现的简单吐司通知弹窗组件
前端·uni-app·vue·组件·插件
克里斯蒂亚诺更新14 分钟前
使用elementUI的表格报错ResizeObserver loop completed with undelivered notifications.
前端·javascript·elementui
陈随易15 分钟前
Vue-Router v5内置文件式路由,告别手写维护的恐惧
前端·后端·程序员