Javascript, 網頁設計

jQuery教學-jQuery讀取XML整合與應用

梅干 2010/11/03
梅問題-jQuery教學-jQuery讀取XML檔
  使用jQuery已有好一段時間,透過jQueyr除了可跨瀏覽器外,再來就是透過它就可輕鬆的製作出各種的酷炫的特效,一點也不輸給Flash,這也是讓梅干喜歡jQuery的地方,再加上也不用什麼開發工具,記事本就很好用了,但梅干平常在寫時總是習慣把素材資訊寫在網頁中,雖然說這樣子簡單易懂,但每次若遇到要更新時,就得開啟網頁找到相關區塊再作修改,實在有些不便,所以梅干就在想,以前用Flash時最常使用xml來餵資料,若jQuery也可以話,那日後更新不就更加的方便,所以梅干今天花了點時間,研究了一下jQuery讀取xml檔的方式,把讀取出來的資訊寫到網頁中,這樣以後更新時,那只要改xml就好囉!

Step1
首先得先準備好一份XML檔,這邊梅干將這xml命名為source.xml。
source.xml
<?xml version="1.0" encoding="UTF-8"?>
<photolist>
	<photo>
        <adsrc>images/ad03.jpg</adsrc>
        <adurl>http://buy.minwt.com/index.php?route=product/product&product_id=56</adurl>
    </photo>
	 <photo>
        <adsrc>images/ad02.jpg</adsrc>
        <adurl>http://buy.minwt.com/index.php?route=product/product&product_id=57</adurl>
    </photo>
    <photo>
        <adsrc>images/ad01.jpg</adsrc>
        <adurl>http://buy.minwt.com/index.php?route=product/product&product_id=55</adurl>
    </photo>
</photolist>

Step2
接下來先來看一下jQuery讀取xml檔的基本語法。
	$.ajax({
    url:'source.xml',
    type: 'GET',
    dataType: 'xml',//資料型態可以不設定,且此型態不可是text或html
    timeout: 1000,
    error: function(xml){
        alert('讀取xml錯誤'+xml); //當xml讀取失敗
    },
    success: function(xml){
      $(xml).find("photo").each(function(i){  //取得xml父節點       
        var total=$(xml).find("photo").length;//xml的總筆數
		var photosrc=$(this).children("adsrc").text(); //取得子節點中的src資料
		var photourl=$(this).children("adurl").text(); //取得子節點中的url資料
		alert(total+"|"+photosrc+"|"+photourl); //秀出總筆數與xml檔與抓到的欄位


Step3
其實這樣就已經大告成了,接下來梅干就整合運用了一下好友男丁的【[jQ]用 jQuery 做畫廊 – 圖片展示之左右隱藏箭頭】範例,讓裡面的資料是抓外部的xml,這樣以後更新就方便許多囉~
放到<head>~</head>之間:
<script type="text/javascript" src="https://code.jquery.com/jquery-latest.pack.js"></script>
<style type="text/css"> 
	.abgne_product_arrow_silder {
		width: 450px;
		height: 250px;
		position: relative;
		border: 1px solid #ccc;
		overflow: hidden;
	}
	.abgne_product_arrow_silder ul, .abgne_product_arrow_silder ul li {
		margin: 0;
		padding: 0;
		list-style: none;
	}
	.prev {
		background:url(images/prev.gif) no-repeat;
		width: 38px;
		height: 48px;
		position: absolute;
		left: -48px;	/* 先藏在左邊 */
		top: 101px;		/* (區塊高-圖片高) / 2 */
		z-index: 100;
	}
	.next {
		background:url(images/next.gif) no-repeat;
		width: 38px;
		height: 48px;
		position: absolute;
		right: -48px;	/* 先藏在右邊 */
		top: 101px;		/* (區塊高-圖片高) / 2 */
		z-index:100;
	}
	.abgne_product_arrow_silder ul li {
		position: absolute;
		z-index: 1;
	}
	.abgne_product_arrow_silder ul li.selected {
		z-index: 99;
	}
	a img {
		border: none;
	}
</style> 
<script type="text/javascript"> 
	/* 讀取xml 開始 ------------------------------------------------------------------------------ */
	$.ajax({
    url:'source.xml',
    type: 'GET',
    dataType: 'xml',//資料型態可以不設定,且此型態不可是text或html
    timeout: 1000,
    error: function(xml){
        alert('讀取xml錯誤'+xml); //當xml讀取失敗
    },
    success: function(xml){
        $(xml).find("photo").each(function(i){  //取得xml父節點       
            var total=$(xml).find("photo").length;//xml的總筆數
			var photosrc=$(this).children("adsrc").text(); //取得子節點中的src
			var photourl=$(this).children("adurl").text(); //取得子節點中的url
			
			if(i==0){	  
			   	$('.abgne_product_arrow_silder ul').append('<li class=selected><a href='+photourl+' target=blank><img src='+photosrc+' /></a></li>');
			}else{
				$('.abgne_product_arrow_silder ul').append('<li><a href='+photourl+' target=blank><img src='+photosrc+' /></a></li>');
			}
	
	/* 讀取xml結束 ------------------------------------------------------------------------------ */		
		//當xml讀取完畢時,就載入男丁大的特效【http://abgne.tw/jquery/apply-jquery/hide-left-right-arrow-gallery.html】
		if(i == total-1){
			// 先取得必要的元素並用 jQuery 包裝
			// 並設定箭頭圖片的寬度及其透明度
			// 接著產生兩個放置箭頭用的空白超連結
			var $silder = $('.abgne_product_arrow_silder'), 
				$li = $('ul li', $silder).not(':first').css('opacity', 0).end(),
				arrowWidth = 48 * -1, 
				arrowOpacity = .3, 
				$arrows = $('<a href="#" class="prev"></a><a href="#" class="next"></a>').css('opacity', arrowOpacity),
				$prev = $arrows.filter('.prev'), 
				$next = $arrows.filter('.next'), 
				fadeSpeed = 400;
			
			// 把箭頭超連結加到 $silder 中
			// 並幫 $silder 加上 hover 事件
			$silder.append($arrows).hover(function(){
				var no = $li.filter('.selected').index();
				arrowAction(no > 0 ? 0 : arrowWidth, no < $li.length - 1 ? 0 : arrowWidth);
		
			}, function(){
				arrowAction(arrowWidth, arrowWidth);
				
			});
			
			// 當滑鼠點擊左右箭頭時
			$arrows.click(function(){
				// 先取出目前顯示的 li 及其排行
				var $selected = $li.filter('.selected'),
					no = $selected.index();
				
				// 判斷是要上一張還是下一張
				no = this.className=='prev' ? no - 1 : no + 1;
				$li.eq(no).stop().fadeTo(fadeSpeed + 100, 1, function(){
					arrowAction(no > 0 ? 0 : arrowWidth, no < $li.length - 1 ? 0 : arrowWidth);
				}).addClass('selected').siblings().fadeTo(fadeSpeed, 0).removeClass('selected');
	 
				return false;
			}).focus(function(){
				this.blur();
			});
			
			// 控制左右箭頭顯示或隱藏
			function arrowAction(l, r){
				$prev.stop().animate({ left: l });
				$next.stop().animate({ right: r });
			}
		}
	});
  }
	});
</script>

放到<body>~</body>之間:
<div class="abgne_product_arrow_silder"> <ul></ul> </div>

  透過讀取外部的xml方便多多,這樣就算一般的空間就可使用,除此之外若日後也可透過server端程式,固定產生xml檔,一來也可減少對主機的負擔,二來也可加快網頁的執行速度,從上方的碼中,可看到其實透過jQuery讀取XML檔相當的簡單喔!若有時常需要更新的朋友們,不坊可試試xml喔!
[範例預覽] [範例下載]