将我的内容更新为XML文件

时间:2015-01-19 19:00:00

标签: javascript php jquery xml

我很感激地设法将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>

1 个答案:

答案 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;

?>