无法使用AJAX + Wordpress解析xml数据

时间:2018-10-30 13:28:01

标签: javascript php jquery xml wordpress

好吧,我被正式困住了。我一直在尝试找出为什么我对PubMed xml数据文件中的特定项目的调用无法正常工作的原因...我可以使用当前的代码执行此操作:

$test = (string)$id_json->PubmedArticle->MedlineCitation->PMID;

但是,如果我尝试获取位于较深数组中的变量,则不会返回值。我什至用console.log(data)进行了测试,但我得到的PMID返回,但没有返回XML文件中其他更深的值。例如;

$test = (string)$id_json->PubmedArticle->MedlineCitation->Article->Journal->ISSN;

console.log(data)中的数据不返回任何内容

这是我在wordpress中的功能:

function get_abstract(){
$id = $_POST['abstractid'];

$pubmed_api_call = 'https://eutils.ncbi.nlm.nih.gov/entrez/eutils/efetch.fcgi?db=pubmed&retmode=xml&rettype=abstract&id='.$id;

$id_wpget = wp_remote_get($pubmed_api_call, array('timeout' => 20));
if( is_wp_error( $id_wpget ) ) {
    echo "Error Contacting PubMed, please refresh page and try again";
 die();
}
$id_xml = wp_remote_retrieve_body($id_wpget);
$id_json = simplexml_load_string($id_xml);
$test = (string)$id_json->PubmedArticle->MedlineCitation->Article->Journal->ISSN;
if($test === ""){
echo "NOTHING";
die();
}

echo $test;
die();
}

这是我的javascript AJAX调用:

jQuery(document).ready(function() {

  jQuery('.reference_header').click(function(e) {
    jQuery(this).find("i").toggleClass("arrow-down arrow-up");
    jQuery(this).nextUntil('.reference_header').slideToggle('fast');
    var abstractid = jQuery(this).data("id");
    e.preventDefault();
        jQuery.ajax({
            url: get_abstract.ajaxurl,
            type: 'POST',
            dataType: 'json',
            data: {
        abstractid: jQuery(this).data("id"),
        action: 'get_abstract'
        },
            success : function(data){
                    jQuery('.'+abstractid).html("TESTING: "+data);
                    console.log(data);
                }

        });
  });

});

我不知道为什么它不起作用...非常感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

所以我想出了解决这个问题的方法...您需要将字符串文本作为json对象传递给AJAX,以使其能够正确读取...

工作代码:

PHP:

echo json_encode(array("result" => "$test"));
die();

AJAX:

        success : function(data){
                jQuery('.'+abstractid).html("TESTING: "+data.result);
                console.log(data.result);
            }