php+xml結(jié)合Ajax實(shí)現(xiàn)點(diǎn)贊功能完整實(shí)例
本文實(shí)例講述了php+xml結(jié)合Ajax實(shí)現(xiàn)點(diǎn)贊功能的方法。分享給大家供大家參考。具體如下:
使用xml、php和Ajax實(shí)現(xiàn)點(diǎn)贊功能,不需要鏈接數(shù)據(jù)庫,使用php來修改xml的內(nèi)容,使用Ajax直接或許xml的內(nèi)容。
一、準(zhǔn)備好xml:
<?xml version="1.0"?> <goodtree> <goodnode> <id>0</id> <count>17</count> </goodnode> <goodnode> <id>1</id> <count>37</count> </goodnode> <goodnode> <id>2</id> <count>67</count> </goodnode> </goodtree>
其中ID只是用來看清楚排序的,沒有實(shí)際的調(diào)用作用。
二、準(zhǔn)備好HTML
<div id="goodcount"> <span>0</span><button onclick="goodplus(0);">good+1</button> <span>0</span><button onclick="goodplus(1);">good+1</button> <span>0</span><button onclick="goodplus(2);">good+1</button> <span>0</span><button onclick="goodplus(3);">good+1</button> </div>
三、JAVASCRIPT 包括Ajax在內(nèi),還添加了判斷cookie的功能
var span = document.getElementsByTagName('span'); var num; var flag = 0; for(var i = 1; i < span.length + 1; i++){ senddata(i); } function goodplus(gindex){ flag = 1; num = parseInt(span.item(gindex).innerHTML); if(checkcookie(gindex) == true){ num = num + 1; senddata(gindex); }else{ alert("你已經(jīng)點(diǎn)過贊咯!") } } function senddata(aindex){ var xmlhttp; var txt; if(window.XMLHttpRequest){ xmlhttp=new XMLHttpRequest(); }else{ xmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function(){ if(xmlhttp.readyState == 4 && xmlhttp.status == 200){ if(flag == 0){ xmldoc = xmlhttp.responseXML; var count = xmldoc.getElementsByTagName('count'); var span2 = document.getElementsByTagName('span'); for(var j = 0; j < count.length; j++){ span2.item(j).innerHTML = count[j].childNodes[0].nodeValue; } }else if(flag == 1){ xmldoc2 = xmlhttp.responseText; var span3 = document.getElementsByTagName('span'); span3.item(aindex).innerHTML = xmldoc2; } } } if(flag == 0){ xmlhttp.open("GET","/ajax/foodmap/index.xml"); }else{ xmlhttp.open("GET","/ajax/foodmap/index.php?num=" + num + "&aindex=" + aindex,true); } xmlhttp.send(); } //判斷是否已經(jīng)存在了cookie function checkcookie(gindex){ var thiscookie = 'sdcity_foodmap_goodplus' + gindex; var mapcookie = getCookie(thiscookie) if (mapcookie!=null && mapcookie!=""){ return false; }else { setCookie(thiscookie,thiscookie,365); return true; } } //獲取cookie function getCookie(c_name){ //獲取cookie,參數(shù)是名稱。 if (document.cookie.length > 0){ //當(dāng)cookie不為空的時(shí)候就開始查找名稱 c_start = document.cookie.indexOf(c_name + "="); if (c_start != -1){ //如果開始的位置不為-1就是找到了、找到了之后就要確定結(jié)束的位置 c_start = c_start + c_name.length + 1 ; //cookie的值存在名稱和等號(hào)的后面,所以內(nèi)容的開始位置應(yīng)該是加上長度和1 c_end = document.cookie.indexOf(";" , c_start); if (c_end == -1) { c_end = document.cookie.length; } return unescape(document.cookie.substring(c_start , c_end)); //返回內(nèi)容,解碼。 } } return ""; } //設(shè)置cookie function setCookie(c_name,value,expiredays){ //存入名稱,值,有效期。有效期到期事件是今天+有效天數(shù)。然后存儲(chǔ)cookie, var exdate=new Date(); exdate.setDate( exdate.getDate() + expiredays ) document.cookie = c_name + "=" + escape(value) + ((expiredays==null) ? "" : "; expires=" + exdate.toGMTString()) }
四、通過php來修改xml的數(shù)據(jù),一開始調(diào)用xml的數(shù)據(jù)的時(shí)候不需要php文件。
<?php $num = $_GET['num']; echo $_GET['num']; $aindex = $_GET['aindex']; $dom=new DOMDocument('1.0'); $dom->load('index.xml'); $goodnode=$dom->getElementsByTagName('goodnode'); $goodnode = $goodnode->item($aindex); $items = $goodnode->getElementsByTagName('count'); foreach($items as $a){ $a->nodeValue = $_GET['num']; } $dom->save('index.xml'); ?>
完成。
希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP實(shí)現(xiàn)將Word文件保存到SQL Server數(shù)據(jù)庫
這篇文章主要介紹了如何利用PHP實(shí)現(xiàn)將上傳的Word文件保存到SQL Server數(shù)據(jù)庫,文中的示例代碼講解詳細(xì),需要的可以參考一下2022-02-02PHP中explode函數(shù)和split函數(shù)的區(qū)別小結(jié)
相信大家都知道,explode和split在php中都是可以通過特定字符把字符串轉(zhuǎn)換成數(shù)組的,那么explode和split既然是一樣的為什么會(huì)有兩個(gè)函數(shù)呢,那么explode和split的區(qū)別在哪里呢,下面跟著小編我們一起來看看。2016-08-08檢查url鏈接是否已經(jīng)有參數(shù)的php代碼 添加 ? 或 &
有時(shí)候我們需要檢查 URL 鏈接是否已經(jīng)有參數(shù),然后根據(jù)需要判斷是添加 ? 還是添加 & 在結(jié)尾,這只是一個(gè)很小的技巧,但是在做分頁或者頁面跳轉(zhuǎn)時(shí)還是有些用處的。2010-02-02php設(shè)計(jì)模式 Chain Of Responsibility (職責(zé)鏈模式)
為解除請(qǐng)求的發(fā)送者和接收者之間的耦合,而使用多個(gè)對(duì)象都用機(jī)會(huì)處理這個(gè)請(qǐng)求,將這些對(duì)象連成一條鏈,并沿著這條鏈傳遞該請(qǐng)求,直到有一個(gè)對(duì)象處理它2011-06-06PHP獲得當(dāng)日零點(diǎn)時(shí)間戳的方法分析
這篇文章主要介紹了PHP獲得當(dāng)日零點(diǎn)時(shí)間戳的方法,結(jié)合實(shí)例形式分析了php常見時(shí)間戳轉(zhuǎn)換與運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2018-03-03PHP進(jìn)階學(xué)習(xí)之Geo的地圖定位算法詳解
這篇文章主要介紹了PHP進(jìn)階學(xué)習(xí)之Geo的地圖定位算法,結(jié)合實(shí)例形式詳細(xì)分析了php Geo的地圖定位算法相關(guān)概念、原理、實(shí)現(xiàn)方法與操作注意事項(xiàng),需要的朋友可以參考下2019-06-06