我想知道是否有人可以帮助我。首先,我很抱歉,这是一个非常基本的问题,我对使用 XML 很陌生,所以请耐心等待。
我正在使用这部分代码从MySQL数据库成功加载标记数据,并将它们放置在Google地图上。
downloadUrl("loadallmyfinds.php", function(data) {
var xml = parseXml(data);
var markers = xml.documentElement.getElementsByTagName("marker");
for (var i = 0; i < markers.length; i++) {
// obtain the attribues of each marker
var lat = parseFloat(markers[i].getAttribute("findosgb36lat"));
var lng = parseFloat(markers[i].getAttribute("findosgb36lon"));
var point = new google.maps.LatLng(lat,lng);
var locationname = markers[i].getAttribute("locationname");
var finddescription = markers[i].getAttribute("finddescription");
var html = "<b>" + 'Description: ' + "</b>" + finddescription;
var findcategory = markers[i].getAttribute("findcategory");
// create the marker
var marker = createMarker(point,html,locationname,finddescription,findcategory);
}
XML 输出
<markers>
<marker userid="27" findid="1" locationname="Test Location 1" findosgb36lat="53.0000" findosgb36lon="-1.00000" osgridref="" dateoftrip="21/06/2012" findcategory="Artefact" finddescription="A rare Roman vase."/>
</markers>
我遇到的问题是,在当前状态下,无论用户是谁,都会检索所有记录,但是我需要使该用户特定,更准确地说,如果userid
元素值与我在表单上的变量匹配,则$idnum
。
我想我可以通过上面加载的 PHP 查询来做到这一点,即 loadallmyfinds
使用GET
子句,但遗憾的是这不起作用。
我对此做了一些研究,我相信,根据我有限的知识,我可以通过XML做到这一点,但我真的不确定如何实现它。
我只是想知道是否有人可以看看这个,并提供一些指导,告诉我如何去做,以便过滤记录。
非常感谢和亲切的问候
您在 as $idnum
中有用户 ID 。因此,请从中更改您的 ajax 请求:
downloadUrl("loadallmyfinds.php", function(data) {
对此:
downloadUrl("loadallmyfinds.php?id=<?php echo $idnum?>", function(data) {
并在loadallmyfinds.php
文件中:
旧评论
我想您可以将用户ID存储在会话中($_SESSION['uid']=$userId;
)
。并在loadallmyfinds.php
文件中,读取此会话变量并仅返回该用户相关内容。