起因:

很多用户在使用BdTab插件时,反馈说希望添加一个时钟的功能,

而BdTab又是组件模块化的插件,于是在空余时间就用html+js+css写了一款高颜值的分页时钟







源码如下:

需要其他网页组件的同学可以安装插件后获取,

HTML

`

`

JS

`function Flipper (config) {

// 默认配置

this.config = {

// 时钟模块的节点

node: null,

// 初始前牌文字

frontText: 'number0',

// 初始后牌文字

backText: 'number1',

// 翻转动画时间(毫秒,与翻转动画CSS 设置的animation-duration时间要一致)

duration: 600,

}

// 节点的原本class,与html对应,方便后面添加/删除新的class

this.nodeClass = {

flip: 'flip',

front: 'digital front',

back: 'digital back'

}

// 覆盖默认配置

Object.assign(this.config, config)

// 定位前后两个牌的DOM节点

this.frontNode = this.config.node.querySelector('.front')

this.backNode = this.config.node.querySelector('.back')

// 是否处于翻牌动画过程中(防止动画未完成就进入下一次翻牌)

this.isFlipping = false

// 初始化

this._init()

}

Flipper.prototype = {
constructor: Flipper,
// 初始化
_init: function () {
// 设置初始牌面字符
this._setFront(this.config.frontText)
this._setBack(this.config.backText)
},
// 设置前牌文字
_setFront: function (className) {
this.frontNode.setAttribute('class', this.nodeClass.front + ' ' + className)
},
// 设置后牌文字
_setBack: function (className) {
this.backNode.setAttribute('class', this.nodeClass.back + ' ' + className)
},
_flip: function (type, front, back) {
// 如果处于翻转中,则不执行
if (this.isFlipping) {
return false
}
// 设置翻转状态为true
this.isFlipping = true
// 设置前牌文字
this._setFront(front)
// 设置后牌文字
this._setBack(back)
// 根据传递过来的type设置翻转方向
let flipClass = this.nodeClass.flip;
if (type === 'down') {
flipClass += ' down'
} else {
flipClass += ' up'
}
// 添加翻转方向和执行动画的class,执行翻转动画
this.config.node.setAttribute('class', flipClass + ' go')
// 根据设置的动画时间,在动画结束后,还原class并更新前牌文字
setTimeout(() => {
// 还原class
this.config.node.setAttribute('class', flipClass)
// 设置翻转状态为false
this.isFlipping = false
// 将前牌文字设置为当前新的数字,后牌因为被前牌挡住了,就不用设置了。
this._setFront(back)
}, this.config.duration)
},
// 下翻牌
flipDown: function (front, back) {
this._flip('down', front, back)
},
// 上翻牌
flipUp: function (front, back) {
this._flip('up', front, back)
}
} // 定位时钟模块
let clock = document.getElementById('clock')
// 定位6个翻板
let flips = clock.querySelectorAll('.flip')
// 获取当前时间
let now = new Date()
// 格式化当前时间,例如现在是20:30:10,则输出"203010"字符串
let nowTimeStr = formatDate(now, 'hhiiss')
// 格式化下一秒的时间
let nextTimeStr = formatDate(new Date(now.getTime() + 1000), 'hhiiss')
// 定义牌板数组,用来存储6个Flipper翻板对象
let flipObjs = []
for (let i = 0; i < flips.length; i++) {
// 创建6个Flipper实例,初始化并存入flipObjs
flipObjs.push(new Flipper({
// 每个Flipper实例按数组顺序与翻板DOM的顺序一一对应
node: flips[i],
// 按数组顺序取时间字符串对应位置的数字
frontText: 'number' + nowTimeStr[i],
backText: 'number' + nextTimeStr[i]
}))
} //正则格式化日期
function formatDate (date, dateFormat) {
/* 单独格式化年份,根据y的字符数量输出年份
* 例如:yyyy => 2019
yy => 19
y => 9
*/
if (/(y+)/.test(dateFormat)) {
dateFormat = dateFormat.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length));
}
// 格式化月、日、时、分、秒
let o = {
'm+': date.getMonth() + 1,
'd+': date.getDate(),
'h+': date.getHours(),
'i+': date.getMinutes(),
's+': date.getSeconds()
};
for (let k in o) {
if (new RegExp(`(${k})`).test(dateFormat)) {
// 取出对应的值
let str = o[k] + '';
/* 根据设置的格式,输出对应的字符
* 例如: 早上8时,hh => 08,h => 8
* 但是,当数字>=10时,无论格式为一位还是多位,不做截取,这是与年份格式化不一致的地方
* 例如: 下午15时,hh => 15, h => 15
*/
dateFormat = dateFormat.replace(RegExp.$1, (RegExp.$1.length === 1) ? str : padLeftZero(str));
}
}
return dateFormat;
}; //日期时间补零
function padLeftZero (str) {
return ('00' + str).substr(str.length);
} setInterval(function () {
// 获取当前时间
let now = new Date()
// 格式化当前时间
let nowTimeStr = formatDate(new Date(now.getTime() - 1000), 'hhiiss')
// 格式化下一秒时间
let nextTimeStr = formatDate(now, 'hhiiss')
// 将当前时间和下一秒时间逐位对比
for (let i = 0; i < flipObjs.length; i++) {
// 如果前后数字没有变化,则直接跳过,不翻牌
if (nowTimeStr[i] === nextTimeStr[i]) {
continue
}
// 传递前后牌的数字,进行向下翻牌动画
flipObjs[i].flipDown('number' + nowTimeStr[i], 'number' + nextTimeStr[i])
}
})`

CSS

` /组件高度/

.component-size-height {

display: flex;

height: 80px;

line-height: 80px;

}

.flip {
position: relative;
width: 40px; /*组件宽度*/
font-weight: bold; /*组件文字加粗*/
font-size: 60px; /*组件文字大小*/
color: #fff; /*组件文字颜色*/
font-family: "Helvetica Neue";
overflow: hidden; } .clock-item {
display: flex;
border-radius: 10px;
overflow: hidden
} .flip .digital:before,
.flip .digital:after {
content: "";
position: absolute;
left: 0;
right: 0;
background: #000000;
overflow: hidden;
box-sizing: border-box;
} .flip .left1:before {
/*text-align: right;*/
} .flip .digital:before {
top: 0;
bottom: 50%;
border-bottom: solid 1px #cec8c8;
/*text-align: right;*/
} .flip .digital:after {
top: 50%;
bottom: 0;
line-height: 0;
/*text-align: right;*/ } .flip .number0:before,
.flip .number0:after {
content: "0";
} .flip .number1:before,
.flip .number1:after {
content: "1";
} .flip .number2:before,
.flip .number2:after {
content: "2";
} .flip .number3:before,
.flip .number3:after {
content: "3";
} .flip .number4:before,
.flip .number4:after {
content: "4";
} .flip .number5:before,
.flip .number5:after {
content: "5";
} .flip .number6:before,
.flip .number6:after {
content: "6";
} .flip .number7:before,
.flip .number7:after {
content: "7";
} .flip .number8:before,
.flip .number8:after {
content: "8";
} .flip .number9:before,
.flip .number9:after {
content: "9";
} /*================*/
/*向下翻*/
.flip.down .front:before {
z-index: 3;
} .flip.down .back:after {
z-index: 2;
transform-origin: 50% 0;
transform: perspective(160px) rotateX(180deg);
} .flip.down .front:after,
.flip.down .back:before {
z-index: 1;
} /*向上翻*/
.flip.up .front:after {
z-index: 3;
} .flip.up .back:before {
z-index: 2;
transform-origin: 50% 100%;
transform: perspective(160px) rotateX(-180deg);
} .flip.up .front:before,
.flip.up .back:after {
z-index: 1;
} .flip.down.go .front:before {
transform-origin: 50% 100%;
animation: frontFlipDown 0.6s ease-in-out both;
box-shadow: 0 -2px 6px rgba(255, 255, 255, 0.3);
backface-visibility: hidden;
} .flip.down.go .back:after {
animation: backFlipDown 0.6s ease-in-out both;
} @keyframes frontFlipDown {
0% {
transform: perspective(160px) rotateX(0deg);
} 100% {
transform: perspective(160px) rotateX(-180deg);
}
} @keyframes backFlipDown {
0% {
transform: perspective(160px) rotateX(180deg);
} 100% {
transform: perspective(160px) rotateX(0deg);
}
} .flip.up.go .front:after {
transform-origin: 50% 0;
animation: frontFlipUp 0.6s ease-in-out both;
box-shadow: 0 2px 6px rgba(255, 255, 255, 0.3);
backface-visibility: hidden;
} .flip.up.go .back:before {
animation: backFlipUp 0.6s ease-in-out both;
} @keyframes frontFlipUp {
0% {
transform: perspective(160px) rotateX(0deg);
} 100% {
transform: perspective(160px) rotateX(180deg);
}
} @keyframes backFlipUp {
0% {
transform: perspective(160px) rotateX(-180deg);
} 100% {
transform: perspective(160px) rotateX(0deg);
}
} .clock {
/*text-align: center;*/
} .clock em {
display: inline-block;
line-height: 102px;
font-size: 66px;
font-style: normal;
vertical-align: top;
} .clock-item div:nth-child(1) div:before, .clock-item div:nth-child(1) div:after {
/*color: red;*/
text-align: right;
} .clock-item div:nth-child(2) div:before, .clock-item div:nth-child(2) div:after {
/*color: #13e8ab;*/
text-align: left;
}`

高颜值,类似Fliqlo的翻页时钟-BdTab新标签页插件组件的更多相关文章

  1. Firefox在新标签页打开“书签”和“搜索栏”(无需插件)

    转自   初来灬炸到的博客 前言 每次打开书签前,都需要创建新标签页. 每次搜索前,都需要创建新标签页.  这个真滴很麻烦.下面介绍的方法非常简单,不需要任何插件,通过修改浏览器参数即可. 名词 设置 ...

  2. Web编程基础--HTML、CSS、JavaScript 学习之课程作业“仿360极速浏览器新标签页”

    Web编程基础--HTML.CSS.JavaScript 学习之课程作业"仿360极速浏览器新标签页" 背景: 作为一个中专网站建设出身,之前总是做静态的HTML+CSS+DIV没 ...

  3. 最新 去掉 Chrome 新标签页的8个缩略图

    chrome的新标签页的8个缩略图实在让人不爽,网上找了一些去掉这个略缩图的方法,其中很多已经失效.不过其中一个插件虽然按照原来的方法已经不能用了,但是稍微变通一下仍然是可以用的(本方法于2017.1 ...

  4. HTML:模拟链接被按下,在新标签页打开页面,不使用window.open(可能被拦截)

    当按下一个按钮时,想打开一个新的标签页,可以使用window.open去实现但是因为使用window.open在新窗口或者新标签页中打开页面,有可能被浏览器给拦截.为了解决这个问题,可以模拟链接被按下 ...

  5. (转载)HTML:模拟链接被按下,在新标签页打开页面,不使用window.open(可能被拦截)

    原文: http://www.cppblog.com/biao/archive/2010/08/21/124196.html 当按下一个按钮时,想打开一个新的标签页,可以使用window.open去实 ...

  6. js实现在新标签页打开页面

    这种方法打开新标签页要在IE9+以上浏览器才可以! <html> <head> <meta http-equiv="Content-type" con ...

  7. 代码方式设置WordPress内所有URL链接都在新标签页打开

    本文由荒原之梦原创,原文链接:http://zhaokaifeng.com/?p=699 前言: WordPress默认情况下几乎所有URL链接都是在同一个标签页打开.这样的话,读者点击一个链接就会离 ...

  8. selenium 打开新标签页(非窗口)

    如何利用webdriver打开多个标签页和链接呢,到处查找得到的往往只是如何打开标签页. 打开标签页很简单,浏览器打开标签页的快捷键是ctrl+t,那把ctrl+t的按键事件传入即可,很多种实现方式, ...

  9. 如何设置使chrome新标签页中打开链接自动跳转到新标签页?

    在新标签打开链接的时候这样点选 Ctrl+左键 或者 鼠标中键 或者 右键链接选择'新标签页中打开链接', 可实现出现新标签页但不自动跳转 但是这个有问题, 即, 新标签只是在背景打开, 操作后并不会 ...

随机推荐

  1. JVM 输出 GC 日志导致 JVM 卡住,我 TM 人傻了

    本系列是 我TM人傻了 系列第七期[捂脸],往期精彩回顾: 升级到Spring 5.3.x之后,GC次数急剧增加,我TM人傻了:https://zhuanlan.zhihu.com/p/3970425 ...

  2. c# sqlsugar,hisql,freesql orm框架全方位性能测试对比 sqlserver 性能测试

    在2022年1月份本人做过一次sqlsugar,hisql,freesql三个框架的性能测试,上次主要是测的sqlserver下的常规插入(非bulkcopy的方式数据插入),hisql与目前比较流行 ...

  3. django生成迁移文件和执行迁移的命令

    生成迁移文件: python manage.py makemigrations    #创建数据库迁移文件 执行迁移: python manage.py migrate    # 根据数据库迁移文件生 ...

  4. HashMap的实现原理?如何保证HashMap线程安全?

    A:HashMap简单说就是它根据建的hashcode值存储数据的,大多数情况下可以直接定位到它的值,因而具有很快的访问速度,但遍历的顺序是不确定的. B:HashMap基于哈希表,底层结构由数组来实 ...

  5. 隐私计算FATE-多分类神经网络算法测试

    一.说明 本文分享基于 Fate 使用 横向联邦 神经网络算法 对 多分类 的数据进行 模型训练,并使用该模型对数据进行 多分类预测. 二分类算法:是指待预测的 label 标签的取值只有两种:直白来 ...

  6. 螣龙安科携手51CTO:网络安全实战课程最新发布

    一年一度的双十一狂欢节即将来临了,相信各大电商平台也正摩拳擦掌跃跃欲试中.回顾2019年,阿里巴巴双十一狂欢节的单日交易额就达到了2684亿人民币,创造了电商交易历史上新的记录. 当人们愉快地购买着自 ...

  7. for增强

    package study5ran2yl.study; public class ForDemo02 { public static void main(String[] args) { int[] ...

  8. CD 从抓轨到搭建流媒体服务器 —— 以《月临寐乡》为例

    2022-07-19 v0.0.1 由于某些原因,进了 Static World 的群并入坑了 月临寐乡 ,梦开始了.作为幻想乡的新人,也算是有了自己喜欢的社团.但是更细节的东西,狐狐脑子一下子塞不下 ...

  9. 7.5 The Morning after Halloween

    本题主要是存储的问题,在存储上笔者原先的代码占用了大量的内存空间 这边笔者采用暴力的思想直接硬开所有情况的16^6的数组来存储该问题,当然这在时间上是十分浪费的,因为初始化实在太慢了,剩下的就是状态转 ...

  10. k8s配置集ConfigMap详解

    ConfigMap介绍 ConfigMap和Secret是Kubernetes系统上两种特殊类型的存储卷,ConfigMap对象用于为容器中的应用提供配置文件等信息.但是比较敏感的数据,例如密钥.证书 ...