weixin_33721427 2016-05-02 09:06 采纳率: 0%
浏览 11

AJAX和simpleXML

I have the following code in my 'update_xml.php' file:

$xml = simplexml_load_file('content.xml');
$name = $_POST['name'];
$xml->home->main->title = $name;
$output = $xml->asXML();
...

I'm using AJAX to post data to this file:

var name = $(this).val();
$.post("update_xml.php", {name: name}, ...

All this works fine, but I also need to be able to post the specific tag to be updated too. Eg:

var name = $(this).val();
$.post("update_xml.php", {name: name, tag: '$xml->home->main->title'}, ...

$xml = simplexml_load_file('content.xml');
$name = $_POST['name'];
$tag = $_POST['tag'];
$tag = $name;

This clearly doesn't work ($tag is now a string). I've tried using eval(), to no avail, and not the best way of going about this. Any ideas?

  • 写回答

1条回答 默认 最新

  • weixin_33724570 2016-05-03 10:28
    关注

    You could use XPath, which is a language for addressing nodes in an XML document. SimpleXML has an xpath() method.

    In your example, the XPath would be simple:

    $.post("update_xml.php", {name: name, path: '/home/main/title}, ...
    

    And you'd apply it like this:

    $xml = simplexml_load_file('content.xml');
    $xpath_results = $xml->xpath($_POST['path']);
    // $xpath_results is always an array of 0 or more objects
    if ( ! $xpath_results ) ... #HANDLE ERROR
    $tag = $xpath_results[0];
    
    评论

报告相同问题?

悬赏问题

  • ¥15 宇视监控服务器无法登录
  • ¥15 PADS Logic 原理图
  • ¥15 PADS Logic 图标
  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签天线)