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

您的位置: 首頁 > 技術(shù)文檔 > 多媒體制作 > Flash & Ajax 操作 XML
Flash中的顏色矩陣 回到列表 學習As2.0與AS3.0的尷尬
 Flash & Ajax 操作 XML

作者:alphat 時間: 2006-07-18 文檔類型:原創(chuàng) 來自:藍色理想

Flash & Ajax 操作 XML 實例:無刷新分頁

效果預覽

其實標題只是一個噱頭罷了,只是想談一下,Javascript 與 Actionscript 是如何操作XML的。
希望能幫助一些只用 Javascript  或 只懂 Actionscript 的朋友,了解兩者的相同與不同之處。

Flash 與 后臺連接有許多種,Actionscript 調(diào)用 XML() 算是比較簡單的一種了,
而Javascript 調(diào)用 xmlHttp ,便形成了現(xiàn)在很流行的Ajax了。

現(xiàn)在就用一個網(wǎng)上常出現(xiàn)的分頁效果來對 Flash 和 Ajax 做個入門學習。 

實際運用中一般是通過后臺腳本生成XML文件,再對其產(chǎn)生的數(shù)據(jù)進行操作
由于篇幅關(guān)系在本文中將用1.xml 2.xml 3.xml代替。后臺腳本不做說明

首先了解一個XML的結(jié)構(gòu):

CODE:
<data>
  <movie id="1" type="愛情">幸福終點站</movie>
  <movie id="2" type="恐怖">絕命終結(jié)站</movie>
  <movie id="3" type="喜劇">恐怖電影</movie>
  …
  ….
</data>

從簡單的Flash開始吧

CODE:
function setxml(page){
  pageXml = new XML();  //申明XML對象
  pageXml.ignoreWhite = true;  //允許空白
  pageXml.load(page+".xml?rid="+Math.random());  //讀取XML文件
  pageXml.onLoad = function(success)
  {
    if (success)
      {
      parseXml(pageXml);  //如果讀取成功,分析XML文件
    }
  }
}
function parseXml(pageXml){
  xmlroot = ageXml.firstChild;  //定義XML根目錄
  for (i=0;i<xmlroot.childNodes.length;i++)
  {
    attachMovie("tr","tr_"+i,i);  //生成行
    this["tr_"+i]._x = 13;
    this["tr_"+i]._y = 25*i+33;
    this["tr_"+i].no = xmlroot.childNodes[i].attributes.id;  //取得一條記錄的ID
    this["tr_"+i].name = xmlroot.childNodes[i].firstChild;  //片名
    this["tr_"+i].type = xmlroot.childNodes[i].attributes.type;  //類型
    page = pageXml.firstChild.attributes.page;  //獲取當前頁
  }
}
if (!page)  //初始頁碼為第一頁 page=1;
  setxml(page);  //初始第一頁內(nèi)容
presetxmlbtn.onRelease = function()
{
  setxml(page*1-1);  //向前翻頁,讀取內(nèi)容
}         
nextbtn.onRelease = function()
{
  setxml(page*1+1);  //向后翻頁,讀取內(nèi)容
}

接下來是Ajax了

CODE:

var xmlHttp

/*
第一部分是有關(guān)xmlHttp的申明,因為IE和其它一些瀏覽生成xmlHttp的對象有一點兩樣,所以申明時比較麻煩
其它主要功能相當于Flash方式中的 "new XML()" 當然還包函其它功能
*/
function GetXmlHttpObject(handler)
{
  var objXmlHttp=null;
  if (navigator.userAgent.indexOf("MSIE")>=0)
  {
    var strName="Msxml2.XMLHTTP";
    if (navigator.appVersion.indexOf("MSIE 5.5")>=0)  //既使是IE都有兩種申明方式
    {
      strName="Microsoft.XMLHTTP";
    }
    try
    {
      objXmlHttp=new ActiveXObject(strName);
      objXmlHttp.onreadystatechange=handler;
      return objXmlHttp;
    }
    catch(e)
    {
      alert("Error. Scripting for ActiveX might be disabled");
      return;
    }
  }
  else
  {
    objXmlHttp=new XMLHttpRequest();  //Firefox、Opera等都是用這種
    objXmlHttp.onload=handler;
    objXmlHttp.onerror=handler;
    return objXmlHttp;
  }
}

//首先要被調(diào)用的函數(shù),可看作上面Flash中的 setxml()函數(shù),
function showpage(no)
{
  document.getElementById("loadstatus").innerHTML = "Lading…";
  var url = no+".xml?rid="+Math.random();
  //stateChanged_showplist是下面的函數(shù)名,注意的是不要加括號
  xmlHttp=GetXmlHttpObject(stateChanged_showplist);
  //傳遞方式是GET,也可以選擇POST方式,有時傳遞變量是中文要記得設置文件頭                  
  xmlHttp.open("GET", url , true);
  xmlHttp.send(null);
}

//分析XML函數(shù)
function stateChanged_showplist()
{
  if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete") //xmlHttp.readyState==4  4表示讀取結(jié)束
  {
    document.getElementById("loadstatus").innerHTML = " ";
    table = document.getElementById("pagebody");//生成TALBE Element
    for (i = table.rows.length-1; i >= 0; i–)   //要刪除原來有的行,不然表格會無限延伸
      table.deleteRow(i);
    xmlroot = xmlHttp.responseXML.getElementsByTagName("movie");  //取得XML所需要的根
   
    for (i=0;i<xmlroot.length;i++)
    {
      //簡單的DOM,生成表格。
      tr = table.insertRow(-1);
      td = tr.insertCell(-1);
      td.align = "center";
      td.innerHTML = ‘<span class="warntxt">’+xmlroot[i].getAttribute(’id’)+’</span>’;
      td = tr.insertCell(-1);
      td.innerHTML = xmlroot[i].firstChild.data;
      td = tr.insertCell(-1);
      td.innerHTML = xmlroot[i].getAttribute(’type’);
    }

    //定義翻頁鏈接
    page = xmlHttp.responseXML.getElementsByTagName("data")[0].getAttribute(’page’)
    if (page >1)
    {
      prepage = page*1-1;
      var changpage = "<a href=’javascript:showpage("+ prepage +")’>上一頁</a> ";
    }
    else
    {
      changpage = "上一頁 ";
    }
    if (page <3)
    {
      nextpage = page*1+1;
      changpage += "<a href=’javascript:showpage("+ nextpage +")’>下一頁</a> ";
    }
    else{
      changpage += "下一頁 ";
    }
    document.getElementById("changpage").innerHTML = changpage;
  }
}

經(jīng)典論壇討論:
http://bbs.blueidea.com/viewthread.php?tid=2548170

出處:藍色理想
責任編輯:moby

◎進入論壇Flash專欄版塊參加討論

相關(guān)文章 更多相關(guān)鏈接
Flash中的顏色矩陣
AJAX初體驗之上手篇
XML+XSL+CSS+ASP打造留言簿
AJAX應用之注冊用戶即時檢測
[FLASH]爽快使用XML
作者文章
一實用的Javascript類庫
十分鐘學會 xajax
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設計大賽開啟
國際體驗設計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

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

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

特別注意:本站所提供的攝影照片,插畫,設計作品,如需使用,請與原作者聯(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ī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權(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 設計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2