首页回顾功能

公司要弄一个首页回顾的功能,可以查看以往某个时间的首页。程序每天自动在上午和下午分别抓取一个页面,生成地址为http://xxx.com/review/channel20090715am.html 的形式。

 

这个功能用到了jQuery UI 的 datepicker日历插件,但是主要的还是通过分析页面地址中的时间信息生成相应链接。

流程如下:
分析页面中的时间信息如20090715am 得出本页面的抓取日期并在页面中显示;
计算前一天的日期 判断是否存在前一天页面的连接(得根据抓取时间);
后一天的亦同;
如果当前页面是am(上午的页面) 则判断是否存在pm(下午的页面);
下午亦同;
 生成相关链接 前一天 后一天 上午 / 下午 并判断链接可用性,如果没有前一天链接,则前一天按钮为不可用 (后一天亦同);
点击下拉框选择预览频道;
点击日历组件日期跳转到相应页面。

查看DEMO 

下面是代码:

ContractedBlock.gifExpandedBlockStart.gifCode

// JavaScript Document By Trance
var dateNow=new Date();
var dateStart=new Date(20097 - 112); //起始时间
var pageurl=window.location.href; //页面地址
var urlClip=pageurl.split("/");
var dateInfo=urlClip[urlClip.length-1];
var urlDate=dateInfo.substr(dateInfo.length-15,8);  //取得时间信息
var ampm=dateInfo.substr(dateInfo.length-7,2); //取得am pm
var pmam="";
var yesterdayLink=true//是否存在前一天链接
var tomorrowLink=true//是否存在后一天链接
function getpmam(){if(ampm=="am"){pmam="pm";}else{pmam="am";}}
getpmam();
var weekArray=["星期日",'星期一',"星期二","星期三","星期四","星期五","星期六"];    
//回顾地址基础
var reviewurl='http://www.titan24.com/review/';
var channel='www'//频道代号
var timetoview=20090715//页面时间
var fomat='.html'//页面格式 (最好不要改)

var analyDate= function (){ //分析页面地址中的时间信息 返回年 月 日 和一个时间对象
    var urldateStr=String(urlDate);
    
var urlYear=Number(urldateStr.substr(0,4));
    
var urlMonth=Number(urldateStr.substr(4,2));    
    
var urlDay=Number(urldateStr.substr(6,2)); 
    
return [urlYear,urlMonth,urlDay,new Date( urlYear , urlMonth -1 ,urlDay)];
    }

function getNeardays(){ //计算前一天 和 后一天的时间 并判断是否存在相应文件
    var yesterday=new Date(analyDate()[3].getTime()-(24*60*60*1000));
    
if(yesterday.getTime()<dateStart.getTime()){
        yesterdayLink
=false;
        }
    
var tomorrow =new Date(analyDate()[3].getTime()+(24*60*60*1000));
    
var timePlug=0;
    
if(ampm=="am"){
        timePlug
=8*60*60*1000;
        }
else{
            timePlug
=20*60*60*1000;
            }
    
if((tomorrow.getTime()+timePlug)>dateNow.getTime()){
        tomorrowLink
=false;
        }
    
return [dateTostring(yesterday),dateTostring(tomorrow)];    
    }
    
//alert(getNeardays()[1])

function creatLinks(){ //创建相应链接
    var neardays=getNeardays();
    
var urlYesterday=pageurl.replace(urlDate,neardays[0]);
    
var urlTomorrow=pageurl.replace(urlDate,neardays[1]);
    
var urlTodayother=pageurl.replace(ampm,pmam);
    
return[urlYesterday,urlTomorrow,urlTodayother]
    
//alert(urlTodayother);
    }
creatLinks()
function dateTostring(adate){ //将日期对象转变为 20090715 形式的字符串
    //if(!(typeof(adate)==object)) return null;
    var adateYear = adate.getFullYear();
    
var adateMonth = adate.getMonth();
    
var adateDate = adate.getDate();
    adateMonth 
= handleBit(adateMonth + 1);
    adateDate 
= handleBit(adateDate);
    
return adateYear+adateMonth+adateDate;
    }

//getNeardays();
function handleBit(bit){ //处理单位的数字
   if(bit.toString().length == 1){
    bit 
= "0" + bit;
   }
   
return bit;
  }    

var getPagedate=function (){ //获得当前页面抓取的时间
    var tmpdate=analyDate();
    
var urlNewdate=tmpdate[3].getDay();
    
var thispageDate="";
    thispageDate
+=tmpdate[0]+'年 '+tmpdate[1]+'月 '+tmpdate[2]+'日 '+weekArray[urlNewdate];
    
//alert(thispageDate);
    return thispageDate;
    }

$(
function(){
    
//标记当前页面时期       
    $("#today").html(getPagedate());    
    addLinks();
    
function addLinks(){ //判断可用性 并加链接
        var linkarray=creatLinks();
        
if(!yesterdayLink){
            $(
"span.yesterday").show();
            }
else{
                $(
"#yesterday").attr("href",linkarray[0]).show();
                }
        
if(!tomorrowLink){
            $(
"span.tomorrow").show();
            }
else{
                $(
"#tomorrow").attr("href",linkarray[1]).show();    
                }            
        $(
"#"+pmam).attr("href",linkarray[2]).show();
        $(
"span."+ampm).show();
        }    
    $(
"#datepicker").datepicker({    
    currentText: 
'今天',
    monthNamesShort: [
'1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月'], // 月份名,简写,支持HTML
    dayNames: weekArray , // 星期名,支持HTML
    dayNamesMin: ['','','','','','',''], // 日历首列显示的星期名,最简,支持HTML
    minDate: dateStart, //开始日期
    maxDate:  dateNow, //可选截止日期
    changeMonth: true//显示月份下拉条
    changeYear: true//显示年下拉条
    dateFormat: 'yymmdd',//设置日期格式
    onSelect:function(){ 
        timetoview
=Number($(this).val());            
        makelinks(); 
//选择后自动跳转
        }
    });    
    
//自动跳转
    function makelinks(){
        
var linktogo=reviewurl+channel+timetoview+ampm+fomat;
        window.open(linktogo,
"_self"); //auto open
        }
    
//改变频道代号
    $("#chn_seler").change(function(){
        channel
=$(this).val();    
    })
//end of document.ready           
})

 

转载于:https://www.cnblogs.com/trance/archive/2009/07/16/1525035.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/363138.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

多表关联更新字段

update jdjc_cy gset g.ypmc(select w.cymc from jdjc_spjdcy w where w.cydzjg.zj) where g.cydh020-JLSP14001转载于:https://www.cnblogs.com/zhuyeshen/p/10685220.html

使对易失性字段的操作原子化

总览 易失字段的预期行为是&#xff0c;它们在多线程应用程序中的行为应与在单线程应用程序中的行为相同。 禁止它们表现相同的方式&#xff0c;但不能保证它们表现相同的方式。 Java 5.0中的解决方案是使用AtomicXxxx类&#xff0c;但是这些类在内存&#xff08;它们添加标头…

浏览器内核总结

一般来讲&#xff0c;浏览器分为外壳部分和渲染部分。外壳部分就是用户看得见摸得到的外观和操作界面;而渲染部分则包括了浏览器内核和JS引擎&#xff0c;其中JS引擎主要负责执行javascript语言实现网页上的动作&#xff0c;而内核则负责渲染网页&#xff0c;把数据变成用户可以…

SDHelper module加密系统解密

电脑上运行了SDHelper module&#xff0c;文档修改就会被加密&#xff0c;无法在别的电脑打开&#xff0c;工作中无意中发现的方法可以避开加密 1&#xff1a;可以通过打开文档并登录你的office&#xff0c;生成分享链接出去可以避免加密 2&#xff1a;本地起一个vue的项目&…

nehe教程混合这一节需要注意的两个地方

//glDepthFunc(GL_LESS); //glEnable(GL_DEPTH_TEST);///关掉深度测试,否则没效果,原因是后画的物体通不过测试,当然也就不能混合了 glDepthRange(0.0, 1.0); glClearDepth(1.0); glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); glClearColor(0.0, 0.0, 0.0, …

Kubernetes CRD开发模式及源码实现深入剖析-Kubernetes商业环境实战

专注于大数据及容器云核心技术解密&#xff0c;可提供全栈的大数据云原生平台咨询方案&#xff0c;请持续关注本套博客。如有任何学术交流&#xff0c;可随时联系。留言请关注《数据云技术社区》公众号。 1 CRD资源扩展 CRD 即CustomResourceDefinition&#xff0c;是 kubernet…

禁止浏览器缓存

近期在改页面的时候看到了页面中有response.setHeader("Pragma","No-cache"); 这样的语句&#xff0c;不知道是做什么的&#xff0c;经查得知原来是禁止浏览器缓存的&#xff0c;现把Html&#xff0c;Asp&#xff0c;Php&#xff0c;Jsp4种语言禁止浏览器缓…

Spring @Transactional实际如何工作?

在本文中&#xff0c;我们将深入探讨Spring事务管理。 我们将讨论Transactional在Transactional如何真正工作。 其他即将发布的帖子将包括&#xff1a; 如何使用传播和隔离等功能 主要陷阱是什么以及如何避免它们 JPA和事务管理 重要的是要注意&#xff0c;JPA本身不提供任何…

python3-开发进阶-RESTful 软件架构风格

一. 什么是RESTful REST与技术无关&#xff0c;代表的是一种软件架构风格&#xff0c;REST是Representational State Transfer的简称&#xff0c;中文翻译为“表征状态转移”REST从资源的角度类审视整个网络&#xff0c;它将分布在网络中某个节点的资源通过URL进行标识&#x…

mysql卸载重装总是卡在starting server这一选项

因为自己不小心把msyql给下载了&#xff0c;重装了一个5.7版本的可是在安装时卡在starting server这一部分&#xff0c;运行不下去。重写卸载重装仍然不成功&#xff0c;还是卡在starting server.无法继续下面的安装&#xff0c;查看日志也没有报错信息。 问题分析&#xff1a;…

两款开源Web功能测试工具

参考自&#xff1a;http://www.ibm.com/developerworks/cn/web/wa-aj-testing/twill:官网&#xff1a;http://twill.idyll.org/安装&#xff1a;easy_install twill运行&#xff1a;twill-sh文档&#xff1a;http://twill.idyll.org/windmill安装&#xff1a;easy_install wind…

箭头函数与普通函数的区别

箭头函数&#xff1a; let fun () > {console.log(lalalala); } 普通函数&#xff1a; function fun() {console.log(lalla); } 箭头函数相当于匿名函数&#xff0c;并且简化了函数定义。箭头函数有两种格式&#xff0c;一种只包含一个表达式&#xff0c;连{ ... }和return…

前端基础-HTML标记语言

阅读目录 一、 HTML标签与文档结构二、 HTML标签详细语法与注意点三、 HTML中标签分类四、 HTML注释 一、 HTML标签与文档结构 HTML作为一门标记语言&#xff0c;是通过各种各样的标签来标记网页内容的。我们学习HTML主要就是学习的HTML标签。 那什么是标签呢&#xff1f; #…

cf1199解题报告

目录 cf1199解题报告ABCDEFcf1199解题报告 发一波水题。 A 模拟 #include <bits/stdc.h> #define ll long long using namespace std; const int _1e67; int n,x,y,a[_]; int main() {scanf("%d%d%d",&n,&x,&y);for(int i1;i<n;i) scanf("…

带有Gradle的Docker容器分为4个步骤

您是否需要通过Java Web应用程序创建Docker映像&#xff1f; 您在使用Gradle吗&#xff1f; 如果是这样&#xff0c;那么您距Docker nivana仅4步之遥。 对于此示例&#xff0c;我将使用一个简单的Spring Boot应用程序。 您可以在我的名为galoshe的Github存储库中找到所有源代码…

ImagesSprite V1.1.1 Beta发布

ImagesSprite v 1.1 发布后有网友提出样式显示了&#xff0c;但不能复制&#xff0c;现做调整如下&#xff08;20090804&#xff09;&#xff1a; 1.修正主界面下方css样式不能复制。 2.修正生成时透明色没有保存。【下载ImagesSprite V1.1.1 Beta】- 点击:4次转载于:https://w…

使用Spark构建简单的RESTful API

免责声明 &#xff1a;这篇文章是关于名为Spark的Java微型Web框架的&#xff0c;而不是关于数据处理引擎Apache Spark的 。 在此博客文章中&#xff0c;我们将看到如何使用Spark构建简单的Web服务。 如免责声明中所述&#xff0c;Spark是受Ruby框架Sinatra启发的Java微型Web框…

cf1206解题报告

目录 cf1206解题报告ABCDE&#xff0c;Fcf1206解题报告 A 模拟 #include <bits/stdc.h> using namespace std; int n,m,a[1010],b[12910]; int dsr[1111]; int main() {scanf("%d",&n);for(int i1;i<n;i) scanf("%d",&a[i]),dsr[a[i]]1;s…

canvas时钟

<!DOCTYPE html><html><head lang"en"><meta charset"UTF-8"><title></title></head><body><canvas id"canvas" width"500" height"500">您的浏览器不支持&#xff…

第七周

这个作业属于哪个课程C语言程序设计 &#xff08;第三版&#xff09;这个作业要求在哪里2019春季第七周作业我的课程目标学习指针的运用这个作业在哪个具体方面帮助我实现目标这个作业让我知道了指针实用性参考文献无一、2019春第七周作业&#xff08;基础题&#xff09; 7-2 自…