arcgis for js api(2) 获取要素服务的id集合

目录

0. 前提

1. 解决方法

2. 样例图片

3. 核心扩展


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. 样例图片

        urlLA_County_Parcels (FeatureServer)  点击JSON,就是可以JSON解析的了

        

3. 核心扩展

        Promise就是异步,但是arcgis js中对于多个要素层,通用版的设置,异步不太好操作,有时需要同步,因此,可以采用async function ***(){},在函数里面await arcgis js的一些Promise操作函数!await必须在async-函数里面,如下:

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值