源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

国内首发 -- ajax完整功能框架

  • 时间:2021-07-14 01:05 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:国内首发 -- ajax完整功能框架
经过仔细研究和分析,终于让AJAX的模拟浏览器功能达到一个新的高峰. 下面将给我源代码,希望喜欢的朋友转载的时候注明转载出处,这样不管对你自己,还是对本人,都是一种极大的尊重. 记得有篇文章数落AJAX的"七宗罪"中说到,AJAX在浏览页面的时候不能使用链接收藏,也就是浏览器的标签功能,更不更使用浏览器的后退.然后也有篇文章翻译了一个老外的AJAX组件,实现了历史记录和后退功能,但是语义有点看不懂,所以在分析了那个组件之后,找出了精华部分,然后重写了这个AJAX RSS应用,并给出所有功能实现的方法注释. 目前在火狐下这个应用还不能使用,不过应该很快就可以解决这个问题. 点这里查看效果 [url=http://www.cnrui.cn/rss]查看[/url]: 源代码: 页面部分,保存为 index.html:
 程序代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "[url=http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd]http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd[/url]"> <html xmlns="[url=http://www.w3.org/1999/xhtml]http://www.w3.org/1999/xhtml[/url]"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>AJAX初级应用-RSS无刷新聚合器(RC 060221)</title> <style type="text/css"> <!-- @import url("read.css"); --> </style> <script type="text/javascript" src="rss.js"></script> </head> <body> <div class="title"> AJAX初级应用-RSS无刷新聚合器   <div class="close" id="clobar" onclick="closebar('sidebar','clobar');">关闭侧边栏</div> </div> <div class="body">   <div class="sidebar" id="sidebar">     <div class="spacecla">       <!--在这里按照相同的格式添加你需要的连接 -->       <a href="javascript:ent('clear');">胡东平个人空间</a><br />       <a href="javascript:ent('a-fei');">OM-Space</a><br />       <a href="javascript:ent('ryanxia');">RYAN Graphics</a><br />       <a href="javascript:ent('awflasher');">活着而已</a><br />       <a href="javascript:ent('seles');">Seles空间</a><br />       <a href="javascript:ent('wawa');">WAWA-Fairy's blog</a><br />       <a href="javascript:ent('dreammx');">大懒人的布拉格</a><br />       <a href="javascript:setlist(12);">除错模式</a><br />     </div>     <div class="special">       <div class="spetit">特别感谢:</div>       <br />             <h4><a href="#">LT</a></h4>       -- 至今为止,之所以我可以做我自己认为喜欢的事情,完全是因为LT对我的强力后台支持。所以让我可以强烈藐视一切不公平现象,因为导致出现不公平现象的起因永远是人,而这个人通常是那种过于自以为是的垃圾。<br />       <br />       <h4><a href="[url=http://www.ryanxia.com/]http://www.ryanxia.com[/url]" target="_blank">夏锐</a></h4>       -- 是他带我走进了网页设计这个神奇的领域,并让我认识到了CSS,从此让我进入到一个充满奇迹的世界。虽然他因为某种原因不能在与我们一起共事,但是他的对我的启蒙将永远铭记于心!<br />       <br />       <h4><a href="#">张天鸣</a></h4>       -- 假如有一天我成为一个优秀的程序设计师,那么他的功劳应该是最大的,始终不厌其烦地给我解释一些很弱智的问题,但是就因为这样的精神,把我领进了程序设计的大门,让我受益终生!AJAX的概念就是他传达给我的。<br />     </div>   </div>   <div class="main" id="main">     <div class="maintit" id="listnum"></div>     <div class="nonetab"></div>     <div class="mainbg" id="prolist">       <h5><a href="#">使用帮助信息</a></h5>       <span>发表时间:2006.02.21</span>       <div class="article"> 如果你看到这些文字,我想你可能遇到麻烦了!看看下面给出的一些帮助信息是否有你需要的!</div>       <div class="bottom"> <a href="#">作者:胡东平</a> </div>       <h5><a href="#">帮助</a></h5>       <span>发表时间:2005.02.21</span>       <div class="article"> 本范例为个人原创,如需转载请联系作者QQ:100829912<br />         <br />         1、假如你一直看到的是这个页面,没有任何内容出现:<br />         <br />         请照步骤(工具 - Internet 选项 - 安全 - 自定义级别 - 通过域访问数据资源 - 启用)!<br />                 因为这个作品是为了让大家熟悉AJAX重点功能,所以会出现这个问题。<br />         <br />         假如还是不行,那么你需要检查一下你的浏览器,因为时间的原故,本人只在IE6 sp1上测试,其他浏览没有试过,不过估计在其他浏览器上肯定会出现一些问题,毕竟新技术还需要时间来支持。<br />         <br />         2、希望当你看到这个代码的时候,你会喜欢上ajax技术,这个范例只是一个很基本的应用,但是作者也付出了一定的时间和精力,希望你能够尊重作者的劳动成果,需要的话你可以免费拿去使用,但是最好不要用于商业用途,并且能够注明转载出处,谢谢!</div>       <div class="bottom"> <a href="#">作者:胡东平</a> </div>     </div>   </div> </div> <div class="footer"> 胡东平个人空间 © 转载须注明出处<br />   <a href="[url=http://blog.cnrui.cn/]http://blog.cnrui.cn[/url]" target="_blank">CopyRight By Clear Online Space</a> </div> <!--提示窗口 --> <div id="loadifo" style="display:none" onclick="ent(delChar());"></div> <iframe id="historyFrame" style="display:none" src="blank.html"></iframe> </body> </html>
隐藏Ifream部分: 保存为 blank.html:
[img]http://www.cnrui.cn/blog/images/code.gif[/img] 程序代码
<html>    <script language="JavaScript">             function pageLoaded() {                window.parent.dhtmlHistory.iframeLoaded(window.location);             }    </script>    <body onLoad="pageLoaded()">       <h1>blank.html - 这个东西很重要的,兄弟!</h1>    </body> </html>
css部分: 保存为 read.css :
[img]http://www.cnrui.cn/blog/images/code.gif[/img] 程序代码
body {     margin: 0px;     padding: 0px;     font-size: 9pt; } h4 {     font-size: 9pt;     display: inline; } h5 {     display: inline;     margin-left: 10px; } span {     margin-left: 20px;     color: #666; } a {     text-decoration: none;     color: #900; } a:hover {     color: #F90; } .title{     filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr="#0099FF", endColorStr="#003366", gradientType="0");     height: 30px;     font-weight: bold;     color: #FFF;     padding-top: 20px;     padding-left: 20px;     border-bottom: 2px solid #FFF; } .close {     float: right;     margin-right: 50px;     cursor:pointer; } .body {     clear: both;     width: 1002px; } .sidebar {     width: 200px;     float: left;     top: 20px;     padding-top: 10px;     filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr="#0066CC", endColorStr="#FFFFFF", gradientType="0");     text-align: center; } .spacecla a{     font-weight: bold;     color: #E1F1FF;     text-decoration: none;     float: left;     width: 120px;     padding: 5px 5px 3px;     border-bottom: 1px dashed #6FF; } .spacecla a:hover{     color: #FFF;     background: #09F; } .special {     margin-top: 50px;     width: 150px;     color: #666;     line-height: 15px;     padding-top: 5px;     padding-bottom: 5px;     text-align: left; } .spetit {     font-weight: bold;     color: #FFFFFF;     border-bottom: 2px solid #EEE; } .spacecla {     width: 150px; } .special a {     color: #000; } .nonetab {     height: 10px;     background: #EEE; } .main {     width: 800px;     float: right; } .maintit {     background: #000;     height: 17px;     color: #FFF;     text-align: center;     padding-top: 3px; } .mainbg {     background: #EEE;     float: left;     width: 100%;     overflow: hidden; } .mainbg2 {     background: #EEE;     float: left;     width: 100%;     filter: Alpha(Opacity=30); } .article img {     border-width: 0px;     border-style: none; } .article {     padding: 5px;     text-indent: 2em;     border-top: 1px solid #06F;     margin-left: 10px; } .bottom {     filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr="#EEEEEE", endColorStr="#FFFFFF", gradientType="1");     height: 13px;     text-align: right;     padding-right: 20px;     padding-top: 3px;     margin-bottom: 10px; } .footer {     height: 30px;     filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr="#0066CC", endColorStr="#B9E3FF", gradientType="1");     text-align: center;     padding-top: 5px;     line-height: 15px;     color: #FFF;     clear: both; } .footer a {     color: #EEE; } #loadifo {     position: absolute;     top: 200px;     width: 120px;     background: #F69;     padding: 10px;     filter: Alpha(Opacity=90);     text-align: center;     color: #FFF;     border: 1px dashed #909;     left: 400px; }
重点:核心代码部分: 保存为 rss.js :
[img]http://www.cnrui.cn/blog/images/code.gif[/img] 程序代码
<!-- //控制ID function getId(objId){     return document.getElementById(objId) } //链接对应数组,请注明转载自[url=http://www.cnrui.cn/blog]http://www.cnrui.cn/blog[/url] function urlArrary(urlName){     switch(urlName){         case "clear":             return "[url=http://www.cnrui.cn/blog/feed.asp]http://www.cnrui.cn/blog/feed.asp[/url]"         case "a-fei":             return "[url=http://www.a-fei.net/blog/rss.xml]http://www.a-fei.net/blog/rss.xml[/url]"         case "ryanxia":             return "[url=http://www.ryanxia.com/]http://www.ryanxia.com[/url]/blog/feedrss2.asp"         case "awflasher":             return "[url=http://www.awflasher.com/blog/feed.asp]http://www.awflasher.com/blog/feed.asp[/url]"         case "seles":             return "[url=http://www.cnrui.cn/seles/feedrss2.asp]http://www.cnrui.cn/seles/feedrss2.asp[/url]"         case "wawa":             return "[url=http://a-fei.net/wawa/blog/rss2.php]http://a-fei.net/wawa/blog/rss2.php[/url]"         case "dreammx":             return "[url=http://www.dreammx.com/xhyl/feed.asp]http://www.dreammx.com/xhyl/feed.asp[/url]"         default:             return false     } } //侧边栏控制,请注明自[url=http://www.cnrui.cn/blog]http://www.cnrui.cn/blog[/url]转载 function closebar(targetid,objId){     if(document.getElementById){         target = getId(targetid);         objsty = getId(objId);         if(target.style.display == "none"){             target.style.display = "";             main.style.width = "800px";             objsty.innerHTML = "关闭侧边栏"         }else{             target.style.display = "none";             main.style.width = "100%";             objsty.innerHTML = "开启侧边栏"         }     } } //加载变灰,注明自[url=http://www.cnrui.cn/blog]http://www.cnrui.cn/blog[/url]转载 function listen(a){     getId("prolist").className=a; } function btnSty(objId,objStyle) {     getId(objId).style.display = objStyle } //提示窗口控制 function ifodis(){     btnSty("loadifo","none"); } function settime(a){     setTimeout(a,1000); } function loadtime(){     getId("loadifo").innerHTML += "." } //数据入口 function ent(urlName){     window.location.hash = urlName     var frmUrl = saveState(urlName);//写入信息到ifream     var gamestart = loadrss(urlName);//AJAX数据过程 } //XML数据绑定 var xmldoc = false; function loadrss(urlName){     var myurl = urlArrary(urlName)     if(myurl){         listen("mainbg2");     //生成随机数,同时限制刷新次数         var Num=Math.floor(Math.random()*100);     //定义往址参数         url = myurl+"?id="+Num;     //定义为异步传输模式         xmldoc = false;     //Mozill,Safari等浏览器时需要创建的XMLHttp类         if(window.XMLHttpRequest){             xmldoc = new XMLHttpRequest();             if(xmldoc.overrideMimeType){                     xmldoc.overrideMimeType('text/xml');             }         }     //IE浏览器时创建的XMLHttp类         else if(window.ActiveXObject){             try{                 xmldoc = new ActiveXObject("Msxml3.XMLHTTP");             }             catch(e){                 try{                     xmldoc = new ActiveXObject("Msxml2.XMLHTTP");                 }                 catch(e){                     try{                         xmldoc = new ActiveXObject("Microsoft.XMLHTTP");                     }                     catch(e){}                 }             }         }     //不能创建XMLHTTP类时返回         if(! xmldoc){             return false;         }     //调用CheckState函数         xmldoc.onreadystatechange = CheckState;         xmldoc.open('GET',url,true);         xmldoc.send(null);     }else{         getId("listnum").innerHTML = "您输入的地址错误,请重试!"     } } //状态检测 function CheckState(){     var response = xmldoc.responseXML.documentElement;     btnSty("loadifo","block") //收到完整的服务器响应     if(xmldoc.readyState == 1){         getId("loadifo").innerHTML = "连接服务器"         }     else if(xmldoc.readyState == 2){         getId("loadifo").innerHTML = "开始加载数据"         }     else if(xmldoc.readyState == 3){         getId("loadifo").innerHTML = "正在加载数据"         settime(loadtime)         }     else if(xmldoc.readyState == 4){ //HTTP服务器响应值成功         if(xmldoc.status == 200){ //将服务器返回的字符串写到页面中ID为showdiv的区域      getId("loadifo").innerHTML = "加载完成"          settime(ifodis)          num(response)         }         else{             getId("loadifo").innerHTML = "错误"+xmldoc.status+"点这里刷新";         }     } } //检查数据合法性 function trydata(nodeName,nodeName2){     try{         var nodeV = nodeName.firstChild.nodeValue;     }catch(e){         try{             var nodeV = nodeName2.firstChild.nodeValue;         }catch(e){             var nodeV = "没有可用信息"         }     }     return nodeV; } //记录集总数 function num(b){     try{         var titleNode = b.selectNodes("//rss/channel/title");         var a = b.getElementsByTagName("item").length         titleV = trydata(titleNode(0));         getId("listnum").innerHTML = "共有"+a+"篇文章 来源于:"+titleV;         setlist(a,b);     }catch(e){} } if (top.location != self.location)top.location=self.location; //节目列表显示 //定义接收指向各个元素的节点信息的变量 var titleNode,linkNode,categoryNameNode,authorNode,pubDateNode,descriptionNode //定义接收元素值的变量 var titleV,linkV,categoryNameV,authorV,pubDateV,descriptionV //分类聚合 function setlist(a,b) {     var prograNode = b.getElementsByTagName("item");     var adminlinkNode = b.selectNodes("//rss/channel/link");     var titleNode = b.selectNodes("//rss/channel/item/title");     var linkNode = b.selectNodes("//rss/channel/item/link");     var categoryNode = b.selectNodes("//rss/channel/item/category");     var authorNode = b.selectNodes("//rss/channel/item/author");     var pubDateNode = b.selectNodes("//rss/channel/item/pubDate");     var descriptionNode = b.selectNodes("//rss/channel/item/description");     var category2sNode = b.selectNodes("//rss/channel/item/dc:subject");     var author2sNode = b.selectNodes("//rss/channel/item/dc:creator");     var pubDate2sNode = b.selectNodes("//rss/channel/item/dc:date");     var listchar="" //使用for循环,产生列表信息     for (i=0; i<a; i++)     {         titleV = trydata(titleNode(i))         linkV = trydata(linkNode(i))         categoryV = trydata(categoryNode(i),category2sNode(i))         authorV = trydata(authorNode(i),author2sNode(i))         pubDateV = trydata(pubDateNode(i),pubDate2sNode(i))         descriptionV = trydata(descriptionNode(i))         adminlinkV = trydata(adminlinkNode(0))         //将得到的元素值装载到产生表格的字符串中         listchar += "<h5><a href='"+linkV+"' target='_blank'>"+titleV+"</a></h5><span>发表时间:"+pubDateV+"</span><div class='article'>"+descriptionV+"</div><div class='bottom'>文章分类:"+categoryV+" <a href='"+adminlinkV+"' target='_blank'>作者:"+authorV+"</a></div>";     }     //将生成的表格输出到页面的DIV元素     getId("prolist").innerHTML = listchar;     listen("mainbg") } //浏览器回退部分 //重写IFREAM链接,浏览器回退重点 function saveState(message) {     var hisFrm = getId("historyFrame")     hisFrm.src = "blank.html?"+message } //检测IFREAM window.dhtmlHistory = {     iframeLoaded:function(newLocation){         var hash = new String(newLocation.search)         if (hash.length >= 2 && hash.charAt(0) == "?" && hash.substring(1) !=delChar()){             hash = hash.substring(1)             window.location.hash = hash;             var hisFrmdata = loadrss(hash)         }     } } //浏览器链接指向部分 //去除符号,请注明[url=http://www.cnrui.cn/blog]http://www.cnrui.cn/blog[/url]转载 function delChar(){     var a = window.location.hash     return     a.substring(1) } window.onload = function(){     if(window.location.hash.length >= 2){         ent(delChar())     } } // -->  [url=http://www.cnrui.cn/blog/attachments/200602/21_172446_rssread.rar]点击下载[/url]
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部