arcgis for js实现FeatureLayer图层弹窗展示所有field字段

效果和说明

feature图层中的矢量要素包含很多的属性,在点击要素时popupTemplate弹窗显示所有field字段值

在这里插入图片描述

实现代码

<!DOCTYPE html>
<html lang="zn">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>

    <style>
      body {
        margin: 0;
      }
      #mapview {
        position: absolute;
        width: 100%;
        height: 100%;
      }
    </style>

    <link rel="stylesheet" href="https://js.arcgis.com/4.23/esri/themes/light/main.css" />
    <script src="https://js.arcgis.com/4.23/"></script>
  </head>
  <body>
    <div id="mapview"></div>

    <script>
      require(['esri/Map', 'esri/views/MapView', 'esri/layers/FeatureLayer'], function (
        Map,
        MapView,
        FeatureLayer
      ) {
        // 初始化底图
        window.map = new Map({
          basemap: 'dark-gray-vector'
        })

        // 创建2维视图
        let view = new MapView({
          container: 'mapview',
          map: map,
          zoom: 11,
          center: [104.783916597735, 32.55699155692144] // 设置地图的初始化中心点坐标
        })

        let layer = new FeatureLayer({
          url: 'http://xxxxxxxx/MapServer', // 这里替换成自己的图层
          spatialReference: view.spatialReference,
          outFields: ['*'],
          hasM: true,
          hasZ: true
        })
        console.log(layer)

        map.add(layer)

        // 字段名称解析字典
        const keyMap = new Map()
        keyMap.set('XIAN', '县')
        keyMap.set('XIANG', '乡')

        // 图层加载完成后
        view.whenLayerView(layer).then(function (layerView) {
          const fields = layerView.layer.fields // 获取所有的字段对象
          // console.log(fields)

          const fieldInfos = []
          for (const { name } of fields) {
            // 排除不要的属性
            if (['FID', 'OID_'].includes(name)) {
              continue
            }
            fieldInfos.push({
              fieldName: name,
              label: name,
              // label: keyMap.get(name), // 如果字段名称需要转义
              isEditable: false,
              tooltip: '',
              visible: true,
              format: null,
              stringFieldOption: 'text-box'
            })
          }
          // console.log(fieldInfos)

          // 为图层绑定弹窗
          layer.popupTemplate = {
            title: '图层弹窗Title',
            content: [{ type: 'fields', fieldInfos: fieldInfos }]
          }
        })
      })
    </script>
  </body>
</html>

在这里插入图片描述

如果要对字段弹窗字段值进行转义, 就必须通过其他方式来做了, 后续更新

您好!对于使用C#和ArcGIS Engine来获取图层字段信息,可以按照以下步骤进行操作: 1. 首先,确保您已经安装了ArcGIS Engine并在项目中添加了相应的引用。 2. 创建一个ArcGIS Engine的地图控件对象,用于加载和显示地图数据。 3. 加载您需要获取字段信息的地图数据。可以使用AxMapControl对象的LoadMxFile方法加载地图文档文件,或者使用Open方法加载地图文件。 4. 获取要操作的图层对象。可以使用AxMapControl对象的get_Layer方法获取指定名称或索引的图层对象。 5. 通过强制转换图层对象为IFeatureLayer接口,以便访问图层的要素类信息。 6. 通过IFeatureLayer接口的FeatureClass属性获取图层的要素类对象。 7. 通过IFeatureClass接口的Fields属性获取要素类的字段集合。 8. 遍历字段集合,获取每个字段的相关信息,比如字段名、类型等。 下面是一个示例代码片段,展示了如何实现上述步骤: ```csharp using ESRI.ArcGIS.Carto; using ESRI.ArcGIS.Geodatabase; // 加载地图数据 axMapControl1.LoadMxFile("path_to_mx_file"); // 获取目标图层 ILayer layer = axMapControl1.get_Layer(layerIndex); IFeatureLayer featureLayer = (IFeatureLayer)layer; // 获取要素类对象 IFeatureClass featureClass = featureLayer.FeatureClass; // 获取字段集合 IFields fields = featureClass.Fields; // 遍历字段集合 for (int i = 0; i < fields.FieldCount; i++) { IField field = fields.get_Field(i); string fieldName = field.Name; esriFieldType fieldType = field.Type; // 打印字段信息 Console.WriteLine("字段名称:{0},字段类型:{1}", fieldName, fieldType); } ``` 请注意,以上代码仅为示例,您需要根据您的具体需求进行相应的修改和适配。 希望对您有帮助!如有任何问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值