修改element-plus的时间线timeline组件为横向时间线(vue3+elementPlus)

文章描述了作者如何修改饿了么的竖向组件以符合项目需求,展示了Vue模板、el-timeline的使用以及CSS样式调整的过程,以实现实时活动进度显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目需求:

发现饿了么的组件是竖向的 并且也不符合项目需求,便对组件进行修改

<template>
  <div class="processBox">
    <div class="title">工程进度</div>
    <el-divider />
    <div class="timelineProcessBox">
      <el-timeline class="timeline">
        <el-timeline-item
          class="lineitem"
          :class="activity.done ? 'active' : 'inactive'"
          v-for="(activity, index) in activities"
          :key="index"
          :timestamp="activity.time"
        >
          <span style="display: flex; flex-direction: column">
            <span style="margin: 10px 0; font-size: 16px">
              {{ activity.content }}
            </span>
            <span style="color: #8c8c8c; font-size: 14px">
              {{ activity.people }}
            </span>
          </span>
        </el-timeline-item>
      </el-timeline>
    </div>
  </div>
</template>
<script lang="ts" setup>
const activities = [
  {
    content: '开工阶段',
    time: '2018-04-12 20:46',
    people: '五六七',
    done: true,
  },
  {
    content: '实施阶段',
    people: '吉吉国王',
    done: false,
    time: '2018-04-03 20:46',
  },
  {
    content: '竣工阶段',
    done: false,
    people: '熊大',
    time: '2018-04-03 20:46',
  },
  {
    content: '结算阶段',
    people: '',
    done: false,
    time: '',
  },
]
</script>
<style lang="scss" scoped>
.processBox {
  background-color: #fff;
  height: 210px;

  .title {
    font-size: 16px;
    font-weight: 600;
    padding-left: 32px;
    padding-top: 16px;
  }
  .timelineProcessBox {
    .timeline {
      display: flex;
      width: 95%;
      margin: 40px auto;
      .lineitem {
        transform: translateX(50%);
        width: 25%;
      }
    }
  }
}

:deep(.el-timeline-item__tail) {
  border-left: none;
  border-top: 2px solid #e4e7ed;
  width: 100%;
  position: absolute;
  top: 6px;
}
:deep(.el-timeline-item__wrapper) {
  padding-left: 0;
  position: absolute;
  top: 20px;
  transform: translateX(-50%);
  text-align: center;
}
:deep(.el-timeline-item__timestamp) {
  font-size: 14px;
}
.active {
  :deep(.el-timeline-item__node) {
    background-color: $login_word;
  }
  :deep(.el-timeline-item__tail) {
    border-color: $login_word;
  }
}
// 有active样式的下一个li
.active + li {
  :deep(.el-timeline-item__node) {
    background-color: $login_word;
  }
}
</style>

实现出来的样式:

### 文心快码 Zulu 的技术资料与教程 文心快码 Zulu 是一种基于开源 JDK 提供的长期支持版本 (LTS),它为企业级应用提供了稳定性和兼容性保障[^1]。以下是关于其使用教程和技术文档的相关说明: #### 安装指南 安装文心快码 Zulu 需要遵循官方推荐的标准流程。通常情况下,可以从官方网站下载适合操作系统的二进制文件并解压到目标目录[^2]。对于 Linux 用户而言,可以采用如下命令完成基本安装: ```bash tar -xvzf zulu<version>-linux_x64.tar.gz -C /opt/zulu/ export JAVA_HOME=/opt/zulu/jdk<version> export PATH=$JAVA_HOME/bin:$PATH ``` #### 基本配置 为了确保环境变量设置正确,在 `.bashrc` 文件中添加 `JAVA_HOME` 和更新路径是非常重要的一步[^3]。通过执行以下脚本验证 Java 是否成功加载: ```bash java -version ``` 如果返回的是所安装的具体版本号,则表明配置无误。 #### 性能调优建议 针对生产环境中运行的应用程序,调整 JVM 参数能够显著提升性能表现。例如增加堆内存大小或者启用 G1 Garbage Collector 可以改善高负载下的响应速度[^4]: ```properties -Xms512m -Xmx2g -XX:+UseG1GC ``` #### 调试技巧 当遇到复杂问题时,利用 `-verbose`, `-Xlog` 等选项可以帮助开发者深入理解内部机制以及定位错误根源[^5]。下面展示了一个简单的日志记录参数例子: ```properties -XX:LogFile=gc.log -Xlog:gc*:file=gc.log:time,uptime,pid,tid,level,tags ```
评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值