问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

ASP.NET里面用JS与C#代码实现倒计时同步

发布网友 发布时间:2022-04-22 17:25

我来回答

6个回答

懂视网 时间:2022-04-22 21:47

这篇文章主要介绍了关于Javascript实现商品秒杀倒计时(时间与服务器时间同步)的解析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

在一些购物商城经常看到有很多商品做秒杀活动,也就是倒计时,本篇文章给大家介绍Javascript实现商品秒杀倒计时(时间与服务器时间同步),需要的朋友可以了解下

现在有很多网站都在做秒杀商品,而这其中有一个很重要的环节就是倒计时。

关于倒计时,有下面几点需要注意:

1.应该使用服务器时间而不是本地时间(本地时间存在时区不同、用户自行设置等问题)。

2.要考虑网络传输的耗时。

3.获取时间时可直接从AJAX的响应头中读取(通过getResponseHeader('Date')来获得),服务器端不需要专门写时间生成脚本。

过程分析:

1.从服务器读到一个时间戳之后便开始计时,不考虑网络传输的耗时:


图中的各项标注分别是(上面的时间线采用标准时间,与服务器和页面的时间均无关):

start——页面项服务器发起AJAX请求时的时间。

www_start——服务器响应页面的请求并返回时间戳给页面的时间。

pc_start——页面接受到服务器返回的时间戳并开始计时的时间。

www_end——服务器倒计时结束的时间。

pc_end——页面倒计时结束的时间,同时也是用户在倒计时结束那一刻点击按钮的时间。

end——服务器接收到用户点击信息的时间。

可以看出,即使在倒计时结束的那一刻(也就是秒杀开始那一刻)用户就立即点击鼠标,也会比实际开始抢拍的时间(www_end,即服务器倒计时结束的时间)晚一些(可以很容易的看出,这个时间差正好等于pc_start - start,也就是AJAX从开始发送到接收到响应信息的耗时)。如果有些内行在页面倒计时结束前用脚本发送请求,那么其他用户可就亏大了。所以,我们要解决掉这个时间误差的问题。

2.为了解决时间误差的问题,我们将把页面倒计时的时间缩短一小截(由上面的分析可以得出,这一小截正好等于pc_start - start),使得用户在倒计时结束时发送给服务器的抢拍信息正好在服务器倒计时结束时被接收到:

图中的各项标注与Pic.1中相同(时间线采用标准时间,与服务器和页面的时间均无关),新增的两项标注的含义如下:

old_pc_end——在未对网络传输耗时进行处理的情况下pc_end的时间。

old_end——在未对网络传输耗时进行处理的情况下end的时间。

由Pic.2可见,网络传输耗时造成的时间误差已经完全被弥补了,弥补的方法是“将倒计时结束的时间提前pc_start - start”。但是解决了网络传输耗时造成的误差问题,还有用户电脑时间和服务器时间不相同的问题,下面我们继续讨论。

3.用户的电脑时间和服务器时间一定是有差异的,甚至差几个时区,怎么解决这个问题呢?方法的要点如下:

A. 当页面接收到服务器返回的时间戳www_t时,立即开始计时。

B. 当页面接收到服务器返回的时间戳www_t时,立即计算本地时间和服务器返回的时间戳的时间差t=new Date().getTime() - www_t*1000。

C. 仍然使用new Date().getTime()来计时,而不是使用setInterval()函数(计时器很不稳定,误差也很大),但时间的显示与程序的逻辑必须基于本地时间和上一步(B中)求得的时间偏差t。

结论要点:

页面从接收到服务器响应的时间戳开始计时,计时的时长应减掉AJAX从发送到接收整个过程的耗时,计时过程则使用本地时间来实现(本地时间+时间偏差)。

有任何疑问或建议请留言,谢谢!

javascript小技巧:同步服务器时间、同步倒计时

之前在网上看到有人提问,如何在页面上同步显示服务器的时间,其实实现方法有几种,可能一般人立马就想到可以使用Ajax每隔一秒去请求服务器,然后将服务器获取到时间显示在页面上,这样虽然能够实现,但存在一个很大的问题,那就是每隔一秒去请求服务器,这样如果用户多了,服务器就会崩溃(内存占用率会很大),所以在我看来,这种方法不可行,我这里给出一种解决方案,能够实现同步服务器时间、同步倒计时,却不占用服务器太多资源,下面我给写实现的思路

第一步,当用户第一次浏览页面时,服务器首先获取当前时间并显示在页面上(比如:显示在ID为timebox span中)

第二步,设置一个每隔一秒就计算新的时间(新时间以服务器时间为初始值,然后每隔一秒累加一秒并生成新的时间)

第三步,显示第二步计算的时间

是不是很简单,总结成一句话就是:以服务器时间为初始值,然后在页面上自动每隔一秒就累加一秒生成新时间,这样就能保证与服务器时间同步了,误差基本在几秒内,应该没关系了,好了看一下实现的代码吧:

<span id="timebox">11:21:55</span> //第一次将服务器时间显示在这里
<script type="text/javascript">
 $(function () {
 var oTime = $("#timebox");
 var ts = oTime.text().split(":", 3);
 var tnums = [parseInt(ts[0]), parseInt(ts[1]), parseInt(ts[2])];
 setInterval(function () {
 tnums = getNextTimeNumber(tnums[0], tnums[1], tnums[2]);
 showNewTime(tnums[0], tnums[1], tnums[2]);
 }, 1000);
 function showNewTime(h, m, s) {
 var timeStr = ("0" + h.toString()).substr(-2) + ":"
  + ("0" + m.toString()).substr(-2) + ":"
  + ("0" + s.toString()).substr(-2);
 oTime.text(timeStr);
 }
 function getNextTimeNumber(h, m, s) {
 if (++s == 60) {
 s = 0;
 }
 if (s == 0) {
 if (++m == 60) {
  m = 0;
 }
 }
 if (m == 0) {
 if (++h == 24) {
  h = 0;
 }
 }
 return [h, m, s];
 }
 });
</script>

代码很简单在此就不多作说明(我上面只显示时分秒,大家也可以加上日期,加上日期可在当h==0时,直接从服务器获取一个日期或完整的时间,作为一次时间的校对),不懂的可以在下面评论,我会及时回复的,然后按照这种思路来实现一下同步倒计时,首先说明一下,什么是同步倒计时,就是类似秒杀一样,设置一个结束时间,然后计算当前时间与结束时间之间间隔,而且必需保证在不同的电脑、浏览器上显示的倒计时时间均相同,实现代码如下:

<!DOCTYPE html>
<html>
<head>
 <title>同步倒计时</title>
 <script type="text/javascript" src="jquery-1.4.4.min.js"></script>
</head>
<body>
 <span id="timebox">1天00时00分12秒</span> <!--假设:1天00时00分12秒是从服务器获取的倒计时数据-->
 <script type="text/javascript">
 $(function () {
 var tid = setInterval(function () {
 var oTimebox = $("#timebox");
 var syTime = oTimebox.text();
 var totalSec = getTotalSecond(syTime) - 1;
 if (totalSec >= 0) {
  oTimebox.text(getNewSyTime(totalSec));
 } else {
  clearInterval(tid);
 }
 
 }, 1000);
 
 //根据剩余时间字符串计算出总秒数
 function getTotalSecond(timestr) {
 var reg = /d+/g;
 var timenums = new Array();
 while ((r = reg.exec(timestr)) != null) {
  timenums.push(parseInt(r));
 }
 var second = 0, i = 0;
 if (timenums.length == 4) {
  second += timenums[0] * 24 * 3600;
  i = 1;
 }
 second += timenums[i] * 3600 + timenums[++i] * 60 + timenums[++i];
 return second;
 }
 
 //根据剩余秒数生成时间格式
 function getNewSyTime(sec) {
 var s = sec % 60;
 sec = (sec - s) / 60; //min
 var m = sec % 60;
 sec = (sec - m) / 60; //hour
 var h = sec % 24;
 var d = (sec - h) / 24;//day
 var syTimeStr = "";
 if (d > 0) {
  syTimeStr += d.toString() + "天";
 }
 
 syTimeStr += ("0" + h.toString()).substr(-2) + "时"
  + ("0" + m.toString()).substr(-2) + "分"
  + ("0" + s.toString()).substr(-2) + "秒";
 
 return syTimeStr;
 }
 
 });
 </script>
</body>
</html>

为了保证倒计时的精确度,我采用了先将倒计时时间间隔统一计算成秒,然后减1秒再重新生成时间格式,当然也可以按照上面时间同步的例子,直接进行时间减少,方法很多,我这个不一定是最优的,欢迎大家交流,谢谢!

热心网友 时间:2022-04-22 18:55

在javascript中加入请求.可以是ajaxpro来实现或者其他来写.反正随便写代码.只要在后台请求到剩余时间即可
只要有人竞拍,剩余时间就保存下时间
javascript获取剩余时间并显示你都实现了

竞拍时间可以考虑用application来保存或者保存到数据库
用户请求的时候以现在的时间减去保存的时间就是花费了的时间了.要多少秒竞拍中减去,小于等于0时就结束.

编辑一下
=================
15秒每秒请求一次的话会比较费时和消耗服务器
如果大于5秒,则在10秒和5秒的时候请求一下.反正有时间,如果有人重新拍了.则重新计数,只是重新的计数可能不会从15开始,比如有人在13秒的时候竞拍了.到10秒的时候才请求.已经耗去3秒.则显示从12秒倒计时了
小于5秒的时候则每秒请求一次...

热心网友 时间:2022-04-22 20:13

客户端用AJAX每秒向服务器发一次请求,获取现在应该是第几秒。

热心网友 时间:2022-04-22 21:47

用线程锁死,lock(this)应该能解决

热心网友 时间:2022-04-22 23:39

用timer控件就可以了 简单 方便~~

热心网友 时间:2022-04-23 01:47

Application
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
显卡降价矿难了!分享几个检测矿卡的实用软件 怎么分辨二手显卡刷bios 下文教你 怎么识别矿卡 鉴别矿卡的方法介绍 怎么设置小度在家回家视频通话? 贵阳砂岩雕塑厂有哪些 西安市长安二中附近有老年公寓没 来西安这么久了第一次租到性价比高的房子,松鼠公寓良心推荐_西安... 陕西省自强中等专业学校2024年学费多少 宝鸡市区有什么比较好的楼盘 乔安如何远程监控 黄豆红枣芝麻花生核桃一起打豆浆吗 小孩早餐可以每天吃核桃黑豆芝麻花生黄豆一起打豆浆吃吗?有什么更详细食谱吗?和什么加在一起能利湿呢? 请问:黄豆,核桃仁,黑芝麻和花生米做出来的豆浆不连豆渣吃有营养吗? 这个电路里的功率开关BTS6143D是怎么工作的 怎么看身份证绑定的 怎么看身份证绑定了几个 Mr.Children的历年作品 查询身份证绑定了几个 求动漫好听的歌 Mr.Children的发展经历 自己名下有几个怎么查 跪求所有好听的英文日文韩文歌曲 Mr.children唱过哪些歌? 求英语达人帮助翻译一段话 自己名下有几个怎么查 推荐几首好听流行的英文歌,绝对反对复制!我不喜欢说唱的那种,喜欢比较伤感的。 ★求助★请英语不错的帮帮忙 谢谢! 一个网友跟我说想看看我,我说在抖音朋友圈不都看到了吗?我这样说对不对呢 关于冠词的单选题 一个身份证可以绑定几个 cortex a8是armel还是armhf架构 你好,请问linux版本的火狐浏览器能在arm架构的开发板ubuntu系统运行吗? 恒泰证券极速版是什么意思 恒泰证券极速版签约要不要缴费? 方证证券极速板有Mac版吗? 手机证券极速版有电脑版吗 请问中信建投证券网上交易极速版(通达信) V6.04哪 里的下载?谢谢!!! 怎么解决 软件包的体系架构(i386)与本机系统的架构(amd64)不符 我用的是中国银河证券海王星急速版v2.066 总是登陆不上,提示是通讯故障或服务已关闭 同花顺极速版是不是所有券商都可以用?华泰联合证券开的户可以用同花顺极速版下单吗? 中信建投网上交易极速版(通达信)的登录方式是什么? 我用的是中国银河证券海王星急速版v2.061,总是登录不上,提示是连接后台失败,请稍后重试!(0:2(2011 江海证券怎么样? 为什么墨尔本汽水那么贵? 国内哪里有卖澳洲的那个SOLO柠檬味碳酸饮料啊?? 飞机能托运碳酸饮料吗?能的话能托运多少?从澳大利亚到上海的飞机 碳酸饮料和软饮料的区别? 移动硬盘1TB相当于电脑硬盘的多少G? 三氯蔗糖在澳大利亚哪些产品中可以使用? 一台服务器的电源模块标示应接100-240v交流输入,可为什么接240V直流电源时服务器也可正常运行?