我很感激地设法将XML文件的内容加载到我的php文档中,如下所示:
$(document).ready(function () {
$.ajax({
type: "GET",
url: "abstimmer.xml",
dataType: "xml",
success: function (xml) {
var $lis = $(".abstimmer li");
$(xml).find('klick').each(function (index) {
if (index < $lis.length) {
$lis.eq(index).html($(this).text());
}
});
}
})
})
由此,这些节点的内容被推送到父类ul元素的li元素中,该元素可以通过类##; abstimmer&#34;识别。
我现在也希望将php文件中的数据推送回xml文件。 我想通过计算li元素的点击数来做到这一点,我以这种方式做的事情:
$(".abstimmer li").click(function(){
this.clicked=this.clicked?this.clicked+1:1;
$(this).html(this.clicked)
var klick_neu = $(this).html(this.clicked);
// Where would I need to go from here?
});
我知道,我现在需要将var klick_neu发送到一个php文件,该文件以某种方式解析var klick_neu并将其推送到该xml文件中。但我不知道该怎么做。有人可以帮我吗?
而且我不确定,如果这对于stackoverflows&#39;规则,但我只是对同一问题中的另一件事感到好奇:如果我在准备功能中添加了一个onClick-Event,我可以&#34;无缝地&#34;将更新的xml文件内容加载到我的列表中 - 对吧?
非常感谢。
我的XML文件会或多或少,看起来像这样:
<?xml version="1.0" encoding="UTF-8"?>
<abstimmer>
<seite id="2">
<klick>3</klick>
<klick>5</klick>
<klick>9</klick>
<klick>12</klick>
<klick>1</klick>
<klick>0</klick>
</seite>
答案 0 :(得分:0)
这是我写的一种方法。你需要熟练掌握它。我真的不知道你的xml文件的标记。我从您提交的代码中推断出来。这是做什么的。每当有人点击LI
时,都会向服务器发出AJAX呼叫。在那里更新xml并将其发布回响应中。页面中的HTML将使用新数据进行更新。这种方法的一个缺点是它一次只支持一个动作。如果两个人写入同一文件,则会导致数据丢失。更好的解决方案是使用数据库跟踪这一情况。
$(".abstimmer li").click(function(){
var klick_neu = parseInt($(this).html())+1;
var index = Array.prototype.slice.call($(".abstimmer li")).indexOf(this);
//create an ajax call that posts the new click count to the server.
$.ajax({
type: "POST",
url: "abstimmer.php",
dataType : "xml",
data : {clicks : klick_neu, element : index},
success: function (data) {
var $lis = $(".abstimmer li");
$(data).find('klick').each(function (index) {
if (index < $lis.length) {
$lis.eq(index).html($(this).text());
}
});
}
})
});
新的 abstimmer.php 文件
<?php
$clicks = $_POST['clicks'];
$index = $_POST['element'];
$doc = new DOMDocument();
$doc->load("abstimmer.xml");
$elements = $doc->getElementsByTagName("klick");
$elements->item($index)->nodeValue = $clicks;
$xml = $doc->saveXML();
if($handle = fopen("abstimmer.xml", "w"))
{
if (!fwrite($handle, $xml))
{
fclose($handle);
}
fclose($handle);
}
header('Content-Type: text/xml; charset=utf-8');
echo $xml;
?>