标签:function load item 获取 FeatureLayer js arcgis api var
0. 前提
采用PotalItem访问各种服务,对于FeatureLayer,需要进行search,缓冲区分析;假如做通用的要素服务操作,每个要素服务包含的FeatureLayer数量也是不同的,因此,需要动态获取;
1. 解决方法
//首先获取PotalItem库,然后再操作
var item = PortalItem({
id: arcgisFeatureLayerID,
});
//不像FeatureLayer.when()那样获取,对于不太确定要加载的,可以使用.load(),item.load()也是Promise异步
item.load().then(function () {
var serviceUrl = item.url + "?f=pjson"; // 详见下图片
layerIDs = getJSON(serviceUrl);
// 遍历读取FeatureLayer集合
var featureLayers = [];
for (let i=0; i<layerIDs.length; i++){
featureLayers.push(
new FeatureLayer({
portalItem: {id: arcgisFeatureLayerID},
outFields: ["*"],
layerId: layerIDs[i]
});
);
}
// 如果你想获取FeatureLayer的字段集合,可以逐个layer.when()获取
// 也可以在item.url后面+"/{layerIDs[i]}"+"?f=pjson",采用getJSON获取
});
// 从服务里获取json数据
function getJSON(url){
var ids;
$.ajaxSettings.async = false; //$代表JQuery,设置同步
$.getJSON(url, function(data){
ids = data.layers.map(function(w){
return w.id;
});
});
$.ajaxSettings.async = true; //恢复异步
return ids;
}
2. 样例图片
url:LA_County_Parcels (FeatureServer) 点击JSON,就是可以JSON解析的了
3. 搜索-缓冲区分析功能(通用版)
前面讲了获取FeatureLayer集合字段的方法,将这个保存至变量里面;继续在item.load().then()中操作,首先将Sketch部件和Search部件放在外面(item前面),然后在item里面将字段写入对应的里面去,即可;
4. 核心扩展
Promise就是异步,但是arcgis js中对于多个要素层,通用版的设置,异步不太好操作,有时需要同步,因此,可以采用async function ***(){},再await,将arcgis js的一些异步的操作放到function里面,再对其结果进行同步的操作;
eg: 获取FeatureLayer字段,可以layer.when()获取,但是它是Promise;不如getJSON(url)的那样获取方便,可以这样操作:
// 有些问题-待修改
async function getFields(layer){
var fields = layer.when(function(){
return layer.fields;
});
}
var fields = await getFields(featureLayer);
标签:function,load,item,获取,FeatureLayer,js,arcgis,api,var 来源: https://blog.csdn.net/LEILEI18A/article/details/121848354
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。