中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)絡(luò)編程 > 用DHTML與XML制作Ajax幻燈片
ASP.NET高級教程—實戰(zhàn)篇 回到列表 寫出高質(zhì)量軟件的75條體會
 用DHTML與XML制作Ajax幻燈片

作者:Jack Herrington 時間: 2006-05-26 文檔類型:轉(zhuǎn)載 來自:IBM developerWorks

第 1 頁 用DHTML與XML制作Ajax幻燈片 [1]
第 2 頁 用DHTML與XML制作Ajax幻燈片 [2]
第 3 頁 用DHTML與XML制作Ajax幻燈片 [3]
第 4 頁 用DHTML與XML制作Ajax幻燈片 [4]
第 5 頁 用DHTML與XML制作Ajax幻燈片 [5]
第 6 頁 用DHTML與XML制作Ajax幻燈片 [6]
第 7 頁 用DHTML與XML制作Ajax幻燈片 [7]

創(chuàng)建 Ajax 幻燈片放映

最后一步是創(chuàng)建 Ajax 版本的幻燈片放映。這意味著要使用從 slides.php 服務(wù)獲得的內(nèi)容代替硬編碼的圖像列表。

Ajax 版本的幻燈片放映代碼如 清單 8 所示。

清單 8. Ajax 幻燈片代碼

<html>
<head>
<style type="text/css">
body { background: black; margin: 0px; padding: 0px; }
</style>
<script src="KenBurnsAnimations.js">
</script>
<script src="Animation.js">
</script>
<script src="ImageInfo.js">
</script>
<script src="SlideShow.js">
</script>
</head>
<body>

<div style="position:relative;width:100%;height:100%;overflow:hidden;"
  id="imgContainer">
</div>

<script>
function processReqChange()
{
  if (req.readyState == 4 && req.status == 200
      && req.responseXML != null)
  {
    var items = [];
    var nl = req.responseXML.getElementsByTagName( 'slide' );
    for( var i = 0; i < nl.length; i++ )
    {
      var nli = nl.item( i );
      var src = nli.getAttribute( 'src' ).toString();
      var width = parseInt( nli.getAttribute( 'width' ).toString() );
      var height = parseInt( nli.getAttribute( 'height' ).toString() );
      items.push( { src: src, width: width, height: height } );
    }
    load_slides( items );
    start_slides();
  }
}

function loadXMLDoc( url )
{
  req = false;
  if(window.XMLHttpRequest) {
    try {
      req = new XMLHttpRequest();
    } catch(e) {
      req = false;
    }
  }
  else if(window.ActiveXObject)
  {
    try {
      req = new ActiveXObject("Msxml2.XMLHTTP");
    } catch(e) {
    try {
      req = new ActiveXObject("Microsoft.XMLHTTP");
    } catch(e) {
      req = false;
    }
  }
  }
  if(req) {
    req.onreadystatechange = processReqChange;
    req.open("GET", url, true);
    req.send("");
  }
}

loadXMLDoc( "http://localhost/kenburns/slides.php" );
</script>

</body>
</html>

我把 start_slides 和 load_slides 函數(shù)移到了外部 JavaScript 文件 SlidesShow.js 中,以免該文件過大。代碼的其他部分和 清單 2 中的 Ajax 測試頁類似。只不過這些代碼沒有插入警告窗口,也沒有把數(shù)據(jù)插入一個表格,而是創(chuàng)建了一個幻燈片信息數(shù)組,然后調(diào)用 load_slides 和 start_slides。

如此而已!這樣就可以使用 Ken Burns Effect 動態(tài)地移動、縮放和漸變圖像的 Ajax 幻燈片。

結(jié)束語

本文中盡可能地使用了面向?qū)ο蟮?JavaScript 代碼。JavaScript 是一種完全面向?qū)ο蟮恼Z言,雖然可能不使用 class 和 interface 關(guān)鍵字,但仍然可以保持代碼的清晰性和可維護性。如果可以的話,我建議您使用 Ajax 框架。這里沒有使用框架是因為我想介紹一種輕型的 Ajax 解決方案。但現(xiàn)在的框架(有很多)更容易編寫更具可移植性的 Ajax 和 DHTML 代碼。

除了本文中介紹的之外,關(guān)于 Ajax 幻燈片我還有以下建議:

1、使用基于時間的動畫。用 setInterval 代碼實現(xiàn)基于步驟的動畫看起來有些抖動。

2、對可視化元素用 DHTML 建立代碼原型,然后再增加 Ajax 內(nèi)容。這意味著可以離線編寫 DHTML 代碼。

3、將連接到服務(wù)器的 Ajax 代碼和呈現(xiàn)數(shù)據(jù)的 DHTML 用戶界面(UI)組件分開。這樣即便不使用 Ajax 獲取數(shù)據(jù),也仍然能夠使用那些界面組件。

4、使用 createElement 和 appendChild 函數(shù)而不是 innerHTML 來改變頁面內(nèi)容。

5、一定要針對所有希望支持的瀏覽器檢查客戶端代碼。此外,還要記錄下您所遇到的兼容性問題以及解決這些問題的方法。盡量將固定的客戶端代碼封裝成可重用的 JavaScript helper 函數(shù)和類。

6、對于復(fù)雜的界面(包括多重動畫),編碼之前應(yīng)首先使用情節(jié)串連板與客戶一起確定他們所需要的效果。情節(jié)串連板是代碼規(guī)范的動畫版本。JavaScript 動畫寫起來很快,因此在編碼之前明確目標(biāo)是值得的,否則可能走不少冤枉路。

7、從職業(yè)的角度來看,僅關(guān)注數(shù)據(jù)庫和業(yè)務(wù)邏輯的 Web V1.0 時代的 “后端工程師”,在 Web V2.0 時代中作用是有限的。必須認(rèn)識到并非所有對服務(wù)器的請求都要借助于 HTML。Ajax 和 DHTML 對那些愿意花錢提高其技能的真正的工程師來說是現(xiàn)實的工具。前端不僅僅是設(shè)計人員的前端。

過去,通常需要 Flash 或者類似的應(yīng)用程序才能實現(xiàn)本文這樣的動態(tài)幻燈片放映。現(xiàn)代化的瀏覽器為 DHTML 提供了不透明性這類豐富的特效支持(Internet Explorer 甚至支持旋轉(zhuǎn)、模糊等),再加上 Ajax,僅僅在瀏覽器中就能實現(xiàn)令人眩目的效果。這意味著客戶不再需要下載奇怪的擴展或者運行有可能不安全的應(yīng)用程序。他們可能偶爾看到了您的網(wǎng)頁,令人震驚的圖像效果會讓他們經(jīng)常來光顧。

下載:Code and file samples

出處:IBM developerWorks
責(zé)任編輯:moby

上一頁 用DHTML與XML制作Ajax幻燈片 [6] 下一頁

◎進入論壇網(wǎng)絡(luò)編程版塊參加討論

相關(guān)文章 更多相關(guān)鏈接
理性思考Flash與Ajax相關(guān)問題
掌握 Ajax
[組件]AsPT1.0.0 圖片幻燈片
用FSO操作 xml
js版幻燈片效果
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻(xiàn),送禮標(biāo)配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:7/71個記錄/頁 轉(zhuǎn)到 頁 共7個記錄

藍(lán)色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2