data 及其子资源提供了对数据的查询和操作的功能,本文的例子将介绍往数据集里添加一个要素(Feature)的过程。
查 REST API 可知,往数据集里添加要素要对 features 资源执行 POST 请求。往 China_Capital_P 数据集里添加要素,要对 URI:http://localhost:8090/iserver/services/components-rest/rest/data/datasources/name/World/datasets/name/Capitals/features.json 执行 POST 请求,请求体中要包含要素信息集合,单个要素的结构如下:
名称 | 类型 | 含义 |
ID | int | 要素的 ID。 |
fieldNames | String[] | 要素的属性字段名集合。 |
fieldValues | String[] | 要素的属性字段值集合。 |
geometry | Geometry | 要素对应的几何对象。 |
通过 Capitals 数据集资源的表述可知,Capitals 数据集类型为 POINT,所以添加的要素对应的几何对象(geometry)类型也应该为 POINT。
通过 Capitals 资源的 fields 子资源可知,Capitals 数据集中的字段名有:SMID、SMX、SMY、SMLIBTILEID、SMUSERID、CAPITAL、COUNTRY、CAP_POP。
添加要素的 SMUSERID 定为 5000,构建 json 格式的单个要素信息如下(需要说明的是,其中的 ID、SMID、geometry.id 一致,传入的值无效,服务器会在原有数据集 ID 的基础上往后加;SMLIBTILEID 的值是固定的,传入的值也无效):
[{
"ID": 5000,
"fieldNames": [
"SMID",
"SMX",
"SMY",
"SMLIBTILEID",
"SMUSERID",
"CAPITAL",
"COUNTRY",
"CAP_POP"
],
"fieldValues": [
"5000",
"100.56",
"100.55",
"5001",
"5014",
"示例首都",
"示例国家",
"582000.0"
],
"geometry": {
"id": 5000,
"parts": null,
"points": [{
"x": 100.56,
"y": 100.55
}],
"style": null,
"type": "POINT"
}
}]
对 URI:http://localhost:8090/iserver/services/components-rest/rest/data/datasources/name/World/datasets/name/Capitals/features.json?returnContent=true 执行 POST 请求,returnContent=true 表示直接返回创建要素的 ID,请求体中包含以上述要素信息作为一个元素的要素信息集,创建要素如下:
//往 Capitals 数据集中添加要素
function AddFeature()
{
var commit=getcommit();
var uri="http://localhost:8090/iserver/services/components-rest/rest/data/datasources/name/World/datasets/name/Capitals/features.rjson";
//欲增加的要素信息。
var NewFeature={
"ID": 5000,
"fieldNames": [
"SMID",
"SMX",
"SMY",
"SMLIBTILEID",
"SMUSERID",
"CAPITAL",
"COUNTRY",
"CAP_POP"
],
"fieldValues": [
"5000",
"100.56",
"100.55",
"5001",
"5014",
"示例首都",
"示例国家",
"582000.0"
],
"geometry": {
"id": 5000,
"parts": null,
"points": [{
"x": 100.56,
"y": 100.55
}],
"style": null,
"type": "POINT"
}
}
//欲增加的要素信息集合(包含1个要素)
var entity=[NewFeature];
commit.open("POST",encodeURI(uri)+"?returnContent=true",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="";
if (response.length>0)
{
container.innerHTML+='<p>创建要素成功。</p>';
container.innerHTML+='<p>添加的要素资源的 ID 为:'+response[0]+'</p>';
}else{
container.innerHTML+='<p>创建要素失败。</p>';
}
}
结果如下:
访问创建的要素资源的 URI:http://localhost:8090/iserver/services/components-rest/rest/data/datasources/name/World/datasets/name/Capitals/features/169.rjson,即可得到新创建的要素资源的 rjson 表述。