部署DeepSeek模型,进群交流最in玩法!
立即加群
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >时间轴组件 by Vue.js

时间轴组件 by Vue.js

作者头像
司想君
发布于 2019-03-08 09:16:33
发布于 2019-03-08 09:16:33
8.7K04
代码可运行
举报
文章被收录于专栏:司想君司想君
运行总次数:4
代码可运行

在繁重的业务工作中,如何提升自己的技术能力,而不是变为特定业务领域的熟练工,方法之一就是在业务工作当中提炼、抽象出通用的技术内容,总结归纳,并进一步思考是否有更好的解决办法。

在公司的项目开发中,涉及到了移动端H5页面的时间轴展示效果。现有的轮子比如ElementUI、iView中,都没有专门的时间轴组件,于是就萌生了自己封装一个的想法。

说干就干,杜绝拖延症,正好今天周末,就封装了一个时间轴的组件上传到了npm,大家有需求可以安装试一下。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
npm install uni-time-line -S

效果如下图:

实现思路

开发一个vue组件,首先要确定好三要素propsslotevent。因为第一版功能比较简单,所以只使用了props

要实现一个时间轴,可以让用户自定义的内容包括,icon图标的样式、标题的文字、内容体的文字,还有两个条目之间的距离。

于是我们props的定义就出来了:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    uni_data: {//要使用时间轴的内容列表,包含标题和内容
      type: Array,
      default() {
        return [
          {
            title: "这是标题",
            content: "这是内容"
          },
          {
            title: "标题过长会显示省略号",
            content: "内容过长会隐藏"
          },
          {
            title: "更多效果可以自定义",
            content: "更多效果可以自定义"
          }
        ];
      }
    },
    space: {//条目之间的距离,默认100px
      type: String,
      default: "100px"
    },
    uni_icon: {//icon的地址,默认提供一个我觉得还算好看的
      type: String,
      default: "http://qiniu.iborge.cn/dian.png"
    }

上面的定义中,稍微不太好理解的是,如何将条目之间的距离动态的设定到style属性上呢?在这里我们使用了computed,即:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
  computed: {
    uni_space() {
      return "height:" + this.space;
    }
  },

这样,用户传入100px,设置到属性上就是style="height:100px".

下一步就是如何实现时间轴的效果,在这里我想到的一个简单的思路是使用div的左边框。

其实大家看到的每条时间轴的竖线,都是一个box的左边框。将其相对定位一下,将包含icon和标题的p绝对定位在竖线顶端,就实现了时间轴的效果。代码如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
.uni_listbox {
  box-sizing: border-box;
  margin: 20px;
  height: 60px;
  position: relative;
}

.uni_listbox p {
  position: absolute;
  top: 0;
  left: 0;
  margin-left: -9px;
  margin-top: -18px;
  vertical-align: middle;
  height: 16px;
  line-height: 16px;
}

这么一来,基本上完成了时间轴的效果,但还有一点小小的问题。就是列表的最后一项,会有一条竖线,但是下面已经没有了新的内容。这样看上去就会很难看,应该如何处理呢?其实只需要简单的一句表达式就可以:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
:class="[uni_data.length==index+1?uni_listbox_last:uni_listbox_notlast,uni_listbox]"

上面这句话的意思是,如果判断当前为数据的最后一项,那么就使用uni_listbox_last的样式,否则就用uni_listbox_notlast,而uni_listbox的样式,则不管条件如何都会生效。

这样,我们只要把uni_listbox_last的边框去掉,高度降低,就实现了文章开头中图片中的效果。

至此,时间轴的组件基本上就开发完了。

还可以根据自己的需求,添加标题行内容溢出显示省略号等各种效果。

下面贴上完整的源码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<template>
  <div id="uni_timeline">
    <div
      :style="uni_space"
      v-for="(item,index) in uni_data"
      :key="index"
      :class="[uni_data.length==index+1?uni_listbox_last:uni_listbox_notlast,uni_listbox]"
    >
      <p>
        <img :src="uni_icon" :class="uni_timeline_icon">
        <span class="uni_timeline_title">{{item.title}}</span>
      </p>
      <div class="uni_timeline_content">{{item.content}}</div>
    </div>
  </div>
</template>
<script>
export default {
  data() {
    return {
      uni_timeline_icon: "uni_timeline_icon",
      uni_listbox_last: "uni_listbox_last",
      uni_listbox_notlast: "uni_listbox_notlast",
      uni_listbox: "uni_listbox"
    };
  },
  computed: {
    uni_space() {
      return "height:" + this.space;
    }
  },
  props: {
    uni_data: {
      type: Array,
      default() {
        return [
          {
            title: "这是标题",
            content: "这是内容"
          },
          {
            title: "标题过长会显示省略号",
            content: "内容过长会隐藏"
          },
          {
            title: "更多效果可以自定义",
            content: "更多效果可以自定义"
          }
        ];
      }
    },
    space: {
      type: String,
      default: "100px"
    },
    uni_icon: {
      type: String,
      default: "http://qiniu.iborge.cn/dian.png"
    }
  }
};
</script>

<style>
* {
  margin: 0;
  padding: 0;
}
.uni_listbox {
  box-sizing: border-box;
  margin: 20px;
  height: 60px;
  position: relative;
}
.uni_listbox_last {
  height: 20px;
}
.uni_listbox_notlast {
  height: 60px;
  margin-left: 18px;
  border-left: 3px solid rgb(228, 228, 228);
}
.uni_listbox p {
  position: absolute;
  top: 0;
  left: 0;
  /* transform: translateY(-50%); */
  margin-left: -9px;
  margin-top: -18px;
  vertical-align: middle;
  height: 16px;
  line-height: 16px;
}
.uni_timeline_icon {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  width: 16px;
  height: 16px;
  vertical-align: middle;
}
.uni_timeline_title {
  font-weight: bold;
  text-align: left;
  display: inline-block;
  width: 300px;
  margin: 0 30px;
  color: rgb(100, 100, 100);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.uni_timeline_content {
  text-align: left;
  height: 70%;
  padding: 10px 21px;
  font-size: 14px;
  color: rgb(100, 100, 100);
  overflow: hidden;
}
</style>
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-01-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 CodingBoys 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
HTML5+CSS3响应式垂直时间轴,高端,大气
HTML5+CSS3响应式垂直时间轴,使用了HTML5标签<section>,时间轴中所有的内容包括标题、简介、时间和图像都放在.cd-timeline-block的DIV中,多个DIV形成一个序列,并把这些DIV放在<section>中。
用户5997198
2019/08/09
2K0
HTML5+CSS3响应式垂直时间轴,高端,大气
Html+Css实现——时间轴日志
💬个人网站:【芒果个人日志】​​​​​​ 💬原文地址:Html+Css实现——时间轴日志 - 芒果个人日志 (wyz-math.cn) 💂作者简介: THUNDER王,一名热爱财税和SAP ABAP编程以及热爱分享的博主。目前于江西师范大学会计学专业大二本科在读,同时任汉硕云(广东)科技有限公司ABAP开发顾问。在学习工作中,我通常使用偏后端的开发语言ABAP,SQL进行任务的完成,对SAP企业管理系统,SAP ABAP开发和数据库具有较深入的研究。 💅文章概要:本篇文章,主要讲解一下如何创建一个
THUNDER王
2023/02/23
1.9K0
Html+Css实现——时间轴日志
炫酷CSS3垂直时间轴特效开源库【合集】
这是一款炫酷css3垂直时间轴特效。该css3垂直时间轴特效通过伪元素来制作炫酷的半圆形,所有半圆形连接为一条曲线路径,组成时间轴的线路。兼容PC端和移动端。
用户5997198
2019/09/12
1.4K0
炫酷CSS3垂直时间轴特效开源库【合集】
超炫酷CSS3垂直时间轴特效开源库
这是一款超炫酷CSS3垂直时间轴特效。该特效通过HTML DOM元素和CSS transform来制作非常炫酷的时间轴布局效果。
用户5997198
2019/09/10
1.1K0
超炫酷CSS3垂直时间轴特效开源库
蓝色时间轴个人博客网页模板代码
看雪时间轴个人博客模板,女生唯美简洁个人博客静态页面模板,蓝色时间轴个人网页模板,下雪空间个人模板代码.这是一个有关看雪时间轴的css3+html5网站静态的个人博客网页模板
博客趣
2024/01/15
3410
蓝色时间轴个人博客网页模板代码
7b2美化-首页添加导航会员区块
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
小狐狸说事
2022/11/17
8120
CSS实用技巧(中)
我们经常使用CSS,但是却不怎么了解CSS,本文主要对vertical-align、BFC、position中开发过程不怎么注意的特性进行简要总结,从本文中,你将了解到以下内容:
冬夜先生
2021/09/07
1.6K0
非插件实现Emlog时间轴归档代码分享
文件缓存型时间轴归档,后台更新缓存或者发布新文章的时候会自动更新;本站这个代码是使用缓存系统的,是需要修改内核文件的。慎用!
用户8099761
2023/05/10
3160
纯CSS时间轴列表
需要实现时间轴列表,左边一串小圆点,右边是列表内容,需要小圆点位置与列表项对应,最终效果如下:
ayqy贾杰
2023/03/15
3.1K0
纯CSS时间轴列表
通过GASP让vue实现动态效果
单页应用及支持它们的前端框架提供了一个很好的机会,可以为程序设计提供令人惊叹的交互层,本文,我们将了解 vue.js 及如何集成 GASP 动画库来添加令人惊叹的动画效果。
icepy
2019/12/03
3.3K0
通过GASP让vue实现动态效果
【React】【案例】:TimeLine 时间轴
目录 1. 组件基础 2. 需求分析 3. 关键技术 4. 代码实现 5. 形态展示 1. 组件基础 可视化地呈现时间流信息。 2. 需求分析 3. 关键技术 为什么不直接用 antd、elementui、iview 等开源组件? antd 很优秀,但是.... antd 不支持 label、content 按指定比例分布; antd 在dot定制时,难以控制UI界面呈现; elementui 不能将 label 放在左边; .... 但是以 antd 为基础改造,会快很多; 主体采用什么html结构实
WEBJ2EE
2020/04/21
8.3K0
【React】【案例】:TimeLine 时间轴
uni-app首页样式分享
分享一张首页样式 # 首页涉及内容 城市选择、轮播、一些列表 # 预览效果 # 代码 index.vue <template> <view class="page"> <uni-popup :
薛定喵君
2020/08/27
1K0
uni-app首页样式分享
wordpress优化经历(四)——一把伞的时间轴归档页模板
一把伞的时间轴归档页模板文件 链接一:https://download.csdn.net/download/qq_42038623/21072565
不愿意做鱼的小鲸鱼
2022/09/26
2750
wordpress优化经历(四)——一把伞的时间轴归档页模板
HTML+CSS案例-学成在线首页
目录 网页效果 index.html代码 style.css代码 百度网盘链接 网页效果 网页效果浏览 index.html代码 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial
yangjiao
2021/12/08
3.7K0
CSS布局之需要掌握的小技巧
vertical-align属性对于inline元素、inline-block元素和table-cell元素有效,对块元素无效。
xinxin-l
2022/03/29
4190
CSS布局之需要掌握的小技巧
分享一个用来挂备案的单页
新建index.html,复制以下html代码 更改<title>我的随笔记录</title>为 你提交备案时写的网站名称 更改下方的ICP备xxxxxx号-1为 你自己的备案号
wo.
2021/06/15
3.2K1
分享一个用来挂备案的单页
暑期生鲜商城静态
background-size:100%;总是X轴100%铺满整个容器,Y轴可能被裁剪会出现空白填不满部分,图片不变形。 background-size:100% 100%;图片不保持比例放大或缩小使X轴与Y轴都铺满整个容器,图片可能会变形。 background-size:cover;图片保持比例放大或缩小使X轴与Y轴都铺满整个容器,但图片超出容器部分会被裁剪掉,图片不变形。 background-size:contain;图片保持比例放大或缩小填充容器,若不能完整填充容器,X轴或Y轴都有可能出现白边,图片不变形。
姜姜178
2022/11/18
3470
暑期生鲜商城静态
VUE实战—商品控件与购物车联动(9)
在商品组件的<template>标签内完成项目结构,以及数据,事件的绑定,与判断逻辑的书写。
前端大彬哥
2019/07/22
8510
VUE实战—商品控件与购物车联动(9)
网站添加时间轴样式
折腾网站就少不了的如公司大事记或网站成长历程之类的页面,时间轴样式相比直接的文字列表会更加清楚美观。 闲话少说吧,直接上代码。
楚客追梦
2022/11/11
2.6K0
网站添加时间轴样式
49个常用的CSS代码片段,建议整理收藏
text-shadow 为网页字体添加阴影,通过对text-shadow属性设置相关的属性值。
前端达人
2021/07/16
2.3K0
相关推荐
HTML5+CSS3响应式垂直时间轴,高端,大气
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档