SuperMap iServer 中有子图层的概念,图层和子图层都是 layer 资源。
对 layer 资源执行 GET 请求,可以获取图层的表述,GET 请求无参数。服务器端返回的响应结构中包含子图层的信息(请参见 REST API 中 layer 资源页面),subLayers 字段表示该图层包含哪些子图层。
在上一节,已经获取了 China 地图中的图层列表,其中有 China 图层,要想获取 China 图层的子图层,可以对 China 图层资源执行 GET 请求,layer 资源的 URI 为 layers 资源的 URI 后加上“/”,再加上图层名,例如 China 图层的 URI 如下:http://localhost:8090/iserver/services/map-china400/rest/maps/China/layers/China.json
获取 China 图层子图层的代码如下:
//获取 China 图层的子图层列表
function getSubLayers()
{
var commit=getcommit();
var uri="http://localhost:8090/iserver/services/map-china400/rest/maps/China/layers/China.json";
commit.open("GET",encodeURI(uri),false,"","");
commit.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
commit.send(null);
//解析从服务器端返回的 json 字符串,解析为一个 JavaScript 对象。
var response = json_parse(commit.responseText, null);
//获取用作显示的 Div 容器。
var container = document.getElementById('container');
container.innerHTML="";
//判断该图层有没有子图层
if(toJSON(response.subLayers)==="{}")
{
//当响应中的 subLayers 字段为{}时,该图层没有子图层。
container.innerHTML +='<br><p>图层'+response.name+'没有子图层。</p>'
}else
{
container.innerHTML +='<br><p>图层'+response.name+'的子图层有:</p>'
//子图层的数目
var len=response.subLayers.layers.length;
for(var j=0;j<len;j++)
{
container.innerHTML += '<li>图层名:'+response.subLayers.layers[j].name+",标题:"+response.subLayers.layers[j].caption+'</li>' ;
}
}
}
在 SuperMap iServer 中,专题图也作为一个 layer 资源而存在。
子图层的 URI 命名规则:【layers 资源的 URI】+‘/’+【子图层名】+‘@@’+【父图层名】+【URI 后缀】,例如 China_Province_R@China400 为图层 "China" 的一个子图层,则它的 URI 就是:
http://localhost:8090/iserver/services/map-china400/rest/maps/China/layers/China_Province_R@China400@@China.json
对该 URI 执行 GET 请求就可以获得子图层 China_Province_R@China400的表述。