data 及其子资源提供了对数据的查询和操作的功能,本文的例子将介绍查询要素的过程,可以进行跨数据源的要素查询。
查 REST API 可知,查询要素可通过对 featureResults 资源执行 POST 请求来进行,请参见 REST API 中 featureResults 资源页面。
本示例中,对数据集“World:Countries”,即 World 数据源(前一个)的 Countries 数据集(后一个)执行缓冲区查询操作,目标对象为点(102.00, 22.50),缓冲区距离为 1 度。
构建缓冲区查询的参数,即 POST 请求的请求体内容(JSON 格式)如下:
//查询的目标数据集名称
var datasetNames=["World:Countries"];
//查询模式,这里为缓冲区查询
var getFeatureMode="BUFFER";
//缓冲区查询所需的几何对象
var BufferPoint={
"id": 5000,
"parts": [1],
"points": [{
"x": 102.00,
"y": 22.50
}],
"style": null,
"type": "POINT"
}
//缓冲区距离
var bufferDistance=1;
//构建缓冲区查询所需的请求体
var entity={
"datasetNames":datasetNames,
"getFeatureMode":getFeatureMode,
"geometry":BufferPoint,
"bufferDistance":bufferDistance
}
对如下 URI(即 featureResults 资源)执行 POST 请求:
var uri="http://localhost:8090/iserver/services/components-rest/rest/data/featureResults.json";
得到的响应中的 newResourceLocation 即为查询结果(featureResult 资源),对查询结果的 featureUriList 字段进行解析(参见 featureResult 资源页面),即得到具体每个要素的表述,对于具体要素资源的表述结构请参见 feature 资源页面。
缓冲区查询的示例代码如下:
//往对 World:World 数据集进行缓冲区查询
function QueryFeature()
{
var commit=getcommit();
var uri="http://localhost:8090/iserver/services/components-rest/rest/data/featureResults.json";
//查询的目标数据集名称
var datasetNames=["World:Countries"];
//查询模式,这里为缓冲区查询
var getFeatureMode="BUFFER";
//缓冲区查询所需的几何对象
var BufferPoint={
"id": 5000,
"parts": [1],
"points": [{
"x": 102.00,
"y": 22.50
}],
"style": null,
"type": "POINT"
}
//缓冲区距离
var bufferDistance=100000;
//构建缓冲区查询所需的请求体
var entity={
"datasetNames":datasetNames,
"getFeatureMode":getFeatureMode,
"geometry":BufferPoint,
"bufferDistance":bufferDistance
}
commit.open("POST",encodeURI(uri),false,"","");
commit.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
commit.send(toJSON(entity));
//解析从服务器端返回的 json 字符串,解析为一个 JavaScript 对象。
var response = json_parse(commit.responseText, null);
//获取用作显示的 Div 容器。
var container = document.getElementById('container');
//输出结果
container.innerHTML="";
var str="";
if (response.succeed==true)
{
//获取查询结果集内容。
commit.open("GET",encodeURI(response.newResourceLocation),false,"","");
commit.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
commit.send(null);
var features=json_parse(commit.responseText, null);
str+='<p>查询成功。</p>';
str+='<p>查询结果中共有'+features.featureCount+'个要素,查询结果的 URI 为:</p><p>'+response.newResourceLocation+'</p>';
str+="示例查询的目标数据集为 World:Countries,该数据集有 SMID、COUNTRY 字段,列出结果要素的 SMID、COUNTRY 字段的值如下所示:"
str+="<ol>"
//获取单个结果要素的内容。
for (var i=0;i<features.featureCount;i++ )
{
commit.open("GET",encodeURI(features.featureUriList[i]+".json?hasGeometry=false"),false,"","");
commit.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
commit.send(null);
var feature = json_parse(commit.responseText, null);
str+="<li>";
for(var j=0;j<feature.fieldNames.length;j++){
if(feature.fieldNames[j]=="SMID"){
str+="SMID:"+feature.fieldValues[j]+",";
continue;
}else if(feature.fieldNames[j]=="COUNTRY"){
str+="COUNTRY:"+feature.fieldValues[j];
continue;
}
}
str+="</li>";
}
str+="</ol>"
}else{
str+='<p>查询失败。</p>';
}
container.innerHTML+=str;
}
结果如下:
对数据集进行其他类型查询的过程,跟缓冲区查询类似,只是所使用的查询参数,即 POST 请求的请求体内容不同,具体请参见 featureResults 资源页面 中关于 POST 请求参数的描述。