PHP+AJAX 投票器功能
終于到AJAX,翻譯過(guò)來(lái)就是”異步Javascript和XML”,他可以實(shí)現(xiàn)網(wǎng)頁(yè)內(nèi)容的部分加載,可提高用戶體驗(yàn)?,F(xiàn)在有很多網(wǎng)站都有用這技術(shù),反正你知道他能實(shí)現(xiàn)網(wǎng)頁(yè)的異步更新就差不多了。當(dāng)然下面的例子都相對(duì)簡(jiǎn)單,并沒(méi)有體現(xiàn)它這一特點(diǎn)~
投票器
新建文件【 AJAX投票.html】
<html>
<head>
<script type="text/javascript">
// 這里是js代碼
function getVote(int) {
if (window.XMLHttpRequest) {
// 創(chuàng)建 XMLHttpRequest 對(duì)象
// IE7+, Firefox, Chrome, Opera, Safari 瀏覽器執(zhí)行的代碼
xmlhttp = new XMLHttpRequest();
} else {
//IE6, IE5 瀏覽器執(zhí)行的代碼
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
// 監(jiān)聽(tīng)響應(yīng)
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState ==4 && xmlhttp.status == 200) {
// 找到 id 為 poll 的控件
document.getElementById('poll').innerHTML = xmlhttp.responseText;
}
}
// 向PHP腳本傳遞主要參數(shù)q
xmlhttp.open("GET", "poll_vote.php?q=" + int, true);
xmlhttp.send();
}
</script>
</head>
<body>
<div id="poll">
<h3>你喜歡吃嗎?</h3>
<form>
是:<input type="radio" name="vote" value="0" onclick="getVote(this.value)"><br>
否:<input type="radio" name="vote" value="1" onclick="getVote(this.value)">
</form>
</div>
</body>
</html>
創(chuàng)建【poll_vote.php】腳本文件
<?php
// 接收參數(shù)q
$vote = htmlspecialchars($_REQUEST['q']);
// 獲取文件中存儲(chǔ)的數(shù)據(jù)(這里需要在同一目錄下新建一個(gè)poll_result.txt文件)
$filename = "poll_result.txt";
$conn = file($filename);
// 將數(shù)據(jù)分割到數(shù)組
$array = explode("||", $conn[0]);
$yes = $array[0];
$no = $array[1];
$count = $array[2];
if ($vote == 0) {
$yes += 1;
$count += 1;
}
if ($vote == 1) {
$no += 1;
$count += 1;
}
// 將投票數(shù)據(jù)保存到文檔
$insertvote = $yes . '||' . $no . '||' . $count;
$fp = fopen($filename, "w");
fputs($fp, $insertvote);
fclose($fp);
?>
<h2>結(jié)果:</h2>
<table>
<tr>
<td>是:</td>
<td>
<span style="display: inline-block; background-color: green; width: <?php echo 100 * round($yes / ($yes + $no), 2);?>px; height: 20px;"></span><?php echo 100 * round($yes / ($yes + $no), 2); ?>%
</td>
</tr>
<tr>
<td>否:</td>
<td>
<span style="display: inline-block; background-color: red; width: <?php echo 100 * round($no / ($yes + $no), 2);?>px; height: 20px;"></span><?php echo 100 * round($no / ($yes + $no), 2); ?>%
</td>
</tr>
</table>
<p><?php echo "參與人數(shù):" . $count; ?></p>
新建一個(gè)空白的文檔 【poll_result.txt】
此時(shí)目錄:
|-AJAX投票.html
|-poll_vote.php
|-poll_result.txt
如果不同則需修改上面相應(yīng)的代碼
效果:

總結(jié)
以上所述是小編給大家介紹的PHP+AJAX 投票器功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
Zend Framework框架db類的分頁(yè)示例分享
這篇文章主要介紹了Zend Framework框架db類的分頁(yè)示例,代碼很簡(jiǎn)單,大家看一下注釋就可以使用了2014-03-03
php 算法之實(shí)現(xiàn)相對(duì)路徑的實(shí)例
這篇文章主要介紹了php 算法之實(shí)現(xiàn)相對(duì)路徑的實(shí)例的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10
PHP擴(kuò)展開(kāi)發(fā)教程(總結(jié))
這篇文章主要介紹了PHP擴(kuò)展開(kāi)發(fā)教程的相關(guān)資料,需要的朋友可以參考下2015-11-11
Laravel執(zhí)行migrate命令提示:No such file or directory的解決方法
這篇文章主要介紹了Laravel執(zhí)行migrate命令提示:No such file or directory的解決方法,分析了執(zhí)行migrate命令出現(xiàn)錯(cuò)誤的原因與相關(guān)的解決方法,需要的朋友可以參考下2016-03-03
php通過(guò)字符串調(diào)用函數(shù)示例
這篇文章主要介紹了php通過(guò)字符串調(diào)用函數(shù),需要的朋友可以參考下2014-03-03
Laravel路由研究之domain解決多域名問(wèn)題的方法示例
這篇文章主要介紹了Laravel 路由研究之domain解決多域名問(wèn)題的方法示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-04-04
Laravel Validator自定義錯(cuò)誤返回提示消息并在前端展示
這篇文章主要給大家介紹了關(guān)于Laravel Validator自定義錯(cuò)誤返回提示消息并在前端展示的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Laravel具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05

