好吧,我被正式困住了。我一直在尝试找出为什么我对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);
}
});
});
});
我不知道为什么它不起作用...非常感谢您的帮助。
答案 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);
}