這篇文章主要介紹AJAX如何實(shí)現(xiàn)RSS無刷新聚合器,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
站在用戶的角度思考問題,與客戶深入溝通,找到明水網(wǎng)站設(shè)計(jì)與明水網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站建設(shè)、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、主機(jī)域名、雅安服務(wù)器托管、企業(yè)郵箱。業(yè)務(wù)覆蓋明水地區(qū)。rss.js
代碼如下:
<!--
//控制ID
function getId(objId){
return document.getElementById(objId)
}
//鏈接對(duì)應(yīng)數(shù)組,請(qǐng)注明轉(zhuǎn)載自http://www.cnrui.cn/blog
function urlArrary(urlName){
switch(urlName){
case "clear":
return "http://www.cnrui.cn/blog/feed.asp"
case "a-fei":
return "http://www.a-fei.net/blog/rss.xml"
case "ryanxia":
return "http://www.ryanxia.com/blog/feedrss2.asp"
case "awflasher":
return "/tupian/20230522/
case "seles":
return "http://www.cnrui.cn/seles/feedrss2.asp"
case "wawa":
return "http://a-fei.net/wawa/blog/rss2.php"
case "dreammx":
return "http://www.dreammx.com/xhyl/feed.asp"
default:
return false
}
}
//側(cè)邊欄控制,請(qǐng)注明自http://www.cnrui.cn/blog轉(zhuǎn)載
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 = "關(guān)閉側(cè)邊欄"
}else{
target.style.display = "none";
main.style.width = "100%";
objsty.innerHTML = "開啟側(cè)邊欄"
}
}
}
//加載變灰,注明自http://www.cnrui.cn/blog轉(zhuǎn)載
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 += "."
}
//數(shù)據(jù)入口
function ent(urlName){
window.location.hash = urlName
var frmUrl = saveState(urlName);//寫入信息到ifream
var gamestart = loadrss(urlName);//AJAX數(shù)據(jù)過程
}
//XML數(shù)據(jù)綁定
var xmldoc = false;
function loadrss(urlName){
var myurl = urlArrary(urlName)
if(myurl){
listen("mainbg2");
//生成隨機(jī)數(shù),同時(shí)限制刷新次數(shù)
var Num=Math.floor(Math.random()*100);
//定義往址參數(shù)
url = myurl+"?id="+Num;
//定義為異步傳輸模式
xmldoc = false;
//Mozill,Safari等瀏覽器時(shí)需要?jiǎng)?chuàng)建的XMLHttp類
if(window.XMLHttpRequest){
xmldoc = new XMLHttpRequest();
if(xmldoc.overrideMimeType){
xmldoc.overrideMimeType('text/xml');
}
}
//IE瀏覽器時(shí)創(chuàng)建的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){}
}
}
}
//不能創(chuàng)建XMLHTTP類時(shí)返回
if(! xmldoc){
return false;
}
//調(diào)用CheckState函數(shù)
xmldoc.onreadystatechange = CheckState;
xmldoc.open('GET',url,true);
xmldoc.send(null);
}else{
getId("listnum").innerHTML = "您輸入的地址錯(cuò)誤,請(qǐng)重試!"
}
}
//狀態(tài)檢測(cè)
function CheckState(){
var response = xmldoc.responseXML.documentElement;
btnSty("loadifo","block")
//收到完整的服務(wù)器響應(yīng)
if(xmldoc.readyState == 1){
getId("loadifo").innerHTML = "連接服務(wù)器"
}
else if(xmldoc.readyState == 2){
getId("loadifo").innerHTML = "開始加載數(shù)據(jù)"
}
else if(xmldoc.readyState == 3){
getId("loadifo").innerHTML = "正在加載數(shù)據(jù)"
settime(loadtime)
}
else if(xmldoc.readyState == 4){
//HTTP服務(wù)器響應(yīng)值成功
if(xmldoc.status == 200){
//將服務(wù)器返回的字符串寫到頁面中ID為showdiv的區(qū)域
getId("loadifo").innerHTML = "加載完成"
settime(ifodis)
num(response)
}
else{
getId("loadifo").innerHTML = "錯(cuò)誤"+xmldoc.status+"點(diǎn)這里刷新";
}
}
}
//檢查數(shù)據(jù)合法性
function trydata(nodeName,nodeName2){
try{
var nodeV = nodeName.firstChild.nodeValue;
}catch(e){
try{
var nodeV = nodeName2.firstChild.nodeValue;
}catch(e){
var nodeV = "沒有可用信息"
}
}
return nodeV;
}
//記錄集總數(shù)
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;
//節(jié)目列表顯示
//定義接收指向各個(gè)元素的節(jié)點(diǎn)信息的變量
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循環(huán),產(chǎn)生列表信息
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))
//將得到的元素值裝載到產(chǎn)生表格的字符串中
listchar += "<h6><a href='"+linkV+"' target='_blank'>"+titleV+"</a></h6><span>發(fā)表時(shí)間:"+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鏈接,瀏覽器回退重點(diǎn)
function saveState(message) {
var hisFrm = getId("historyFrame")
hisFrm.src = "blank.html?"+message
}
//檢測(cè)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)
}
}
}
//瀏覽器鏈接指向部分
//去除符號(hào),請(qǐng)注明http://www.cnrui.cn/blog轉(zhuǎn)載
function delChar(){
var a = window.location.hash
return a.substring(1)
}
window.onload = function(){
if(window.location.hash.length >= 2){
ent(delChar())
}
}
// -->
以上是“AJAX如何實(shí)現(xiàn)RSS無刷新聚合器”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
新聞名稱:AJAX如何實(shí)現(xiàn)RSS無刷新聚合器-創(chuàng)新互聯(lián)
文章分享:http://aaarwkj.com/article8/dppgop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供虛擬主機(jī)、網(wǎng)站排名、企業(yè)建站、網(wǎng)站營(yíng)銷、網(wǎng)站維護(hù)、網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容