js/jq 倒计时插件(一)
//很多时候我们需要用到倒计时比如(一些发布会倒计时,秒杀倒计时,活动倒计时等),接下来将介绍两种倒计时插件的写法
//html结构
<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<script src="jquery-2.1.3.min.js"></script>
<style>
.downTim {
font-size: 16px;
color: #000;
} </style> <body>
<!--一般的活动需要倒计时,也有活动持续时间-->
<!--data-difftime是倒计时时间-->
<!--data-goingtime是倒计是结束后活动进行持续时间-->
<div class="downTim" data-difftime="3600" data-goingtime='6000'>
<div class="downTim" data-difftime="3600" data-goingtime='6000'></div>
</body>
<script src="downTime.js"></script>
<script>
$(function() {
downTimeFun();
}); </script> </html>
html文件中定义了两个时间,有疑问了?为什么要定义这两个时间?
因为:不直接new Date()获取当前时间来倒计时是避免设备(电脑手机)上的本地时间被恶意修改,这样定义时间就可以由服务器端传入时间,由服务器去控制这个时间
//dowbTime.js文件
function downTimeFun() {
//最开始的时间(js文件加载进来一开始拿到的本地时间)
var zuikaishiTime = new Date();
//相差值的时间
var chazhiTime = zuikaishiTime;
$(".downTim").each(function () {//有多个downTime元素,所以用each方法遍历
var $this = $(this);
//判断连接全局变量
var in_app = null;
//用来判断是否显示天数的变量
var lxfday = $this.attr("lxfday");
//多少时间后倒计时
var _difftime = $this.attr("data-difftime") * 1000;
//活动持续进行多少时间
var _goingtime = $this.attr('data-goingtime') * 1000;
//每一秒轮回一次执行的倒计时函数
var lunfun = function () {
//绝对时间计算方式(轮回每次后拿到的本地时间)
chazhiTime = new Date();
//经过了多少秒(每次拿到的本地时间-最开始拿到的本地时间)
var jingguoTime = chazhiTime - zuikaishiTime;
//倒计时剩余时间(倒计时的总时间-经过了的时间)
var difftime = _difftime - jingguoTime;
//活动剩余时间(活动持续进行总时间-经过的时间)
var goingtime = _goingtime - jingguoTime;
//转换
//毫秒除以1000得秒
var seconds = difftime / 1000;
//秒除以60得分(用Math.floor方法向下取时间)
var minutes = Math.floor(seconds / 60);
//取时
var hours = Math.floor(minutes / 60);
//取天
var days = Math.floor(hours / 24);
//"%"是取余运算,可以理解为60进一后取余数,然后只要余数。
var CHour = hours % 24;
var CMinute = minutes % 60;
var CSecond = Math.floor(seconds % 60);
//小于9的数前面都补上0
if (CHour <= 9) CHour = '0' + CHour;
if (CMinute <= 9) CMinute = '0' + CMinute;
if (CSecond <= 9) CSecond = '0' + CSecond;
//减去倒计时,活动持续时间的数据
var holdtime = difftime + goingtime;
if (holdtime <= 0) {
//已经结束
$this.html("<span>已经结束</span>");
} else if (holdtime > 0 && 0 < difftime) {
//还没开始
if (days == 0) {
//输出没有天数的数据
$this.html("倒计时 <span>" + CHour + "</span>:<span>" + CMinute + "</span>:<span>" + CSecond + "</span>");
} else {
//输出有天数的数据
$this.html("倒计时 <span>" + days + "</span>天<span>" + CHour + "</span>:<span>" + CMinute + "</span>" + CSecond + "</span>");
};
setTimeout(function () {
if (!difftime <= 0) {
lunfun();
}
}, 1000);
} else if (holdtime > 0 && difftime <= 0) {
//正在进行时的时间
$this.html("<span>正在进行时</span>");
setTimeout(function () {
if (!holdtime <= 0) {
lunfun();
}
}, 1000);
};
};
lunfun();
});
window.downTimeFun = downTimeFun;
};
js/jq 倒计时插件(一)的更多相关文章
- js 简单倒计时插件和使用方法
// 倒计时插件 (function (){ function countdown(config){ var startDate = config.start ? new Date(config.st ...
- js时间倒计时
看了网上的其他的例子,觉得写的都有点复杂,不好理解,于是自己动手写了个. 本来想封装成jquery插件,但是觉得因为功能很简单,没有必要做成jquery插件,引用的时候不需要引入jqery库,这里直接 ...
- js&jq 发送验证码倒计时
<input type="text" name='' id="btn"> //发送验证码倒计时var wait=30; function t ...
- 及其简易的js 倒计时插件
网上虽然有很多漂亮的且很实用的倒计时插件,但是,对于需要自己定制的倒计时来讲确实一个不小的障碍.最近我们的英语在线教育产品,在线考试模块需要用到一个计时器,所以顺势开发了一个自己的及时器. http: ...
- jq分页插件
jq分页插件 http://www.zhangxinxu.com/jq/pagination_zh/ html --------------- <tbody id="hiddenres ...
- 怎么用jq封装插件
怎么用jq封装插件 以隔行变色为例 实现原理:1.找到表格的奇偶行,然后添加不同的class,激活行高亮显示也很简单,只要判断mouseover事件,然后添加一个class,mouseout的时候,再 ...
- 微信小程序之倒计时插件 wxTimer
微信小程序之倒计时插件 wxTimer 介绍: 用于在微信小程序中进行倒计时的组件. 功能: 1.最基础的当然就是倒计时功能了. 2.可以设置倒计时结束后执行的事件. 3.可以设置倒计时执行过程中 ...
- 倒计时的js实现 倒计时 js Jquery
by zhangxinxu from http://www.zhangxinxu.com本文地址:http://www.zhangxinxu.com/wordpress/?p=987 一.如火如荼的团 ...
- jQuery倒计时插件
倒计时jQuery插件 引言 最近又换工作了,还不错,我换工作的次数其实有点频繁,2014年7月份毕业,到现在工作已经换了3份了,工资跟刚毕业时候相比也涨了点儿,最近一次换工作我离开了深圳,来到了北京 ...
随机推荐
- 【JavaScript】call和apply区别及使用方法
一.方法的定义call方法: 语法:fun.call(thisArg[, arg1[, arg2[, ...]]])定义:调用一个对象的一个方法,以另一个对象替换当前对象.说明:call 方法可以用来 ...
- 【wireshark】插件开发(三):Lua插件 Dissector
// TODO: 部分内容需要修改 1. 骨架 首先新建一个文件,命名为foo.lua,注意此文件的编码方式不能是带BOM的UTF8,否则wireshark加载它时会出错(不识别BOM): -- @b ...
- iOS 模拟不同的字体大小
 真的是神器!! 参考 Creating Self-Sizing Table View Cells
- 【bzoj3224】【Tyvj 1728】 普通平衡树 树状数组
您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入$x$数2. 删除$x$数(若有多个相同的数,因只删除一个)3. 查询$x$数的排名(若有多个相同的数,因输出最小 ...
- POJ 1260
//状态转移方程: F[i] = min{f[k] + (a[k+1]+………+a[i]+10} * p[i]} #include <iostream> #define MAXN 105 ...
- openerp学习笔记 视图样式(表格行颜色、按钮,字段只读、隐藏,按钮状态、类型、图标、权限,group边距,聚合[合计、平均],样式)
表格行颜色: <tree string="请假单列表" colors="red:state == 'refuse';blue:state = ...
- Spring Security构建Rest服务-1001-spring social开发第三方登录之spring social基本原理
OAuth协议是一个授权协议,目的是让用户在不将服务提供商的用户名密码交给第三方应用的条件下,让第三方应用可以有权限访问用户存在服务提供商上的资源. 接着上一篇说的,在第三方应用获取到用户资源后,如果 ...
- filebeat output redis 报错 i/o timeout
filebeat output redis 报错 i/o timeout 先把报错内容贴出来. ERROR redis/client. go: Failed to RPUSH to redis li ...
- Unity Shader之使用Cubemap实现反射效果
1.Cubemap是啥 Cubemap,即立方体纹理,包含6张图像,每张图像对应立方体的一个面,跟二维纹理不同,我们使用三维坐标去对这种纹理进行采样, 在unity中,可以使用Cubemap来实现天空 ...
- [九省联考 2018]秘密袭击coat
Description 题库链接 给出一棵 \(n\) 个点的树,每个点有点权.求所有联通块的权值 \(k\) 大和,对 \(64123\) 取模. \(1\leq n,k\leq 1666\) So ...