本篇內容主要講解“如何理解ajax完整功能框架”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何理解ajax完整功能框架”吧!
目前創(chuàng)新互聯(lián)已為1000+的企業(yè)提供了網(wǎng)站建設、域名、網(wǎng)絡空間、網(wǎng)站托管、企業(yè)網(wǎng)站設計、大興網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。記得有篇文章數(shù)落AJAX的"七宗罪"中說到,AJAX在瀏覽頁面的時候不能使用鏈接收藏,也就是瀏覽器的標簽功能,更不更使用瀏覽器的后退.然后也有篇文章翻譯了一個老外的AJAX組件,實現(xiàn)了歷史記錄和后退功能,但是語義有點看不懂,所以在分析了那個組件之后,找出了精華部分,然后重寫了這個AJAX RSS應用,并給出所有功能實現(xiàn)的方法注釋.
目前在火狐下這個應用還不能使用,不過應該很快就可以解決這個問題.
源代碼:
頁面部分,保存為 index.html:
程序代碼
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<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 />
<h5><a href="#">LT</a></h5>
-- 至今為止,之所以我可以做我自己認為喜歡的事情,完全是因為LT對我的強力后臺支持。所以讓我可以強烈藐視一切不公平現(xiàn)象,因為導致出現(xiàn)不公平現(xiàn)象的起因永遠是人,而這個人通常是那種過于自以為是的垃圾。<br />
<br />
<h5><a href="http://www.ryanxia.com" target="_blank">夏銳</a></h5>
-- 是他帶我走進了網(wǎng)頁設計這個神奇的領域,并讓我認識到了CSS,從此讓我進入到一個充滿奇跡的世界。雖然他因為某種原因不能在與我們一起共事,但是他的對我的啟蒙將永遠銘記于心!<br />
<br />
<h5><a href="#">張?zhí)禅Q</a></h5>
-- 假如有一天我成為一個優(yōu)秀的程序設計師,那么他的功勞應該是較大的,始終不厭其煩地給我解釋一些很弱智的問題,但是就因為這樣的精神,把我領進了程序設計的大門,讓我受益終生!AJAX的概念就是他傳達給我的。<br />
</div>
</div>
<div class="main" id="main">
<div class="maintit" id="listnum"></div>
<div class="nonetab"></div>
<div class="mainbg" id="prolist">
<h6><a href="#">使用幫助信息</a></h6>
<span>發(fā)表時間:2006.02.21</span>
<div class="article"> 如果你看到這些文字,我想你可能遇到麻煩了!看看下面給出的一些幫助信息是否有你需要的!</div>
<div class="bottom"> <a href="#">作者:胡東平</a> </div>
<h6><a href="#">幫助</a></h6>
<span>發(fā)表時間:2005.02.21</span>
<div class="article"> 本范例為個人原創(chuàng),如需轉載請聯(lián)系作者QQ:100829912<br />
<br />
1、假如你一直看到的是這個頁面,沒有任何內容出現(xiàn):<br />
<br />
請照步驟(工具 - Internet 選項 - 安全 - 自定義級別 - 通過域訪問數(shù)據(jù)資源 - 啟用)!<br />
因為這個作品是為了讓大家熟悉AJAX重點功能,所以會出現(xiàn)這個問題。<br />
<br />
假如還是不行,那么你需要檢查一下你的瀏覽器,因為時間的原故,本人只在IE6 sp1上測試,其他瀏覽沒有試過,不過估計在其他瀏覽器上肯定會出現(xiàn)一些問題,畢竟新技術還需要時間來支持。<br />
<br />
2、希望當你看到這個代碼的時候,你會喜歡上ajax技術,這個范例只是一個很基本的應用,但是作者也付出了一定的時間和精力,希望你能夠尊重作者的勞動成果,需要的話你可以免費拿去使用,但是好不要用于商業(yè)用途,并且能夠注明轉載出處,謝謝!</div>
<div class="bottom"> <a href="#">作者:胡東平</a> </div>
</div>
</div>
</div>
<div class="footer"> 胡東平個人空間 © 轉載須注明出處<br />
<a href="http://blog.cnrui.cn" target="_blank">CopyRight By Clear Online Space</a> </div>
<!--提示窗口 -->
<div id="loadifo" onclick="ent(delChar());"></div>
<iframe id="historyFrame" src="blank.html"></iframe>
</body>
</html>
隱藏Ifream部分:
保存為 blank.html:
程序代碼
<html>
<script language="JavaScript">
function pageLoaded() {
window.parent.dhtmlHistory.iframeLoaded(window.location);
}
</script>
<body onLoad="pageLoaded()">
<h2>blank.html - 這個東西很重要的,兄弟!</h2>
</body>
</html>
css部分:
保存為 read.css :
程序代碼
body {
margin: 0px;
padding: 0px;
font-size: 9pt;
}
h5 {
font-size: 9pt;
display: inline;
}
h6 {
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 :
程序代碼
<!--
//控制ID
function getId(objId){
return document.getElementById(objId)
}
//鏈接對應數(shù)組,請注明轉載自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 "http://www.awflasher.com/blog/feed.asp"
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
}
}
//側邊欄控制,請注明自http://www.cnrui.cn/blog轉載
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 = "開啟側邊欄"
}
}
}
//加載變灰,注明自http://www.cnrui.cn/blog轉載
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");
//生成隨機數(shù),同時限制刷新次數(shù)
var Num=Math.floor(Math.random()*100);
//定義往址參數(shù)
url = myurl+"?id="+Num;
//定義為異步傳輸模式
xmldoc = false;
//Mozill,Safari等瀏覽器時需要創(chuàng)建的XMLHttp類
if(window.XMLHttpRequest){
xmldoc = new XMLHttpRequest();
if(xmldoc.overrideMimeType){
xmldoc.overrideMimeType('text/xml');
}
}
//IE瀏覽器時創(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類時返回
if(! xmldoc){
return false;
}
//調用CheckState函數(shù)
xmldoc.onreadystatechange = CheckState;
xmldoc.open('GET',url,true);
xmldoc.send(null);
}else{
getId("listnum").innerHTML = "您輸入的地址錯誤,請重試!"
}
}
//狀態(tài)檢測
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 = "開始加載數(shù)據(jù)"
}
else if(xmldoc.readyState == 3){
getId("loadifo").innerHTML = "正在加載數(shù)據(jù)"
settime(loadtime)
}
else if(xmldoc.readyState == 4){
//HTTP服務器響應值成功
if(xmldoc.status == 200){
//將服務器返回的字符串寫到頁面中ID為showdiv的區(qū)域
getId("loadifo").innerHTML = "加載完成"
settime(ifodis)
num(response)
}
else{
getId("loadifo").innerHTML = "錯誤"+xmldoc.status+"點這里刷新";
}
}
}
//檢查數(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é)目列表顯示
//定義接收指向各個元素的節(jié)點信息的變量
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),產生列表信息
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 += "<h6><a href='"+linkV+"' target='_blank'>"+titleV+"</a></h6><span>發(fā)表時間:"+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)
}
}
}
//瀏覽器鏈接指向部分
//去除符號,請注明http://www.cnrui.cn/blog轉載
function delChar(){
var a = window.location.hash
return a.substring(1)
}
window.onload = function(){
if(window.location.hash.length >= 2){
ent(delChar())
}
}
// -->
到此,相信大家對“如何理解ajax完整功能框架”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續(xù)學習!
網(wǎng)站欄目:如何理解ajax完整功能框架-創(chuàng)新互聯(lián)
地址分享:http://m.rwnh.cn/article4/ddsgoe.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供Google、移動網(wǎng)站建設、ChatGPT、動態(tài)網(wǎng)站、企業(yè)網(wǎng)站制作、網(wǎng)站設計公司
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內容