此例子是基于 React Hooks、TS 以及 arcgis api for js 的例子;该项目还在完善中;
github地址:https://github.com/jiegiser/arcgis3.x_examples 觉得不错的话可以给个 star
;
已完成下面内容:
加载 osm 地图(√)
data:image/s3,"s3://crabby-images/155df/155df8751d61e148ac9e35bf75e2d2842932ed0c" alt="在这里插入图片描述"
加载天地图(√)
data:image/s3,"s3://crabby-images/adb41/adb41f90a38f31e38176d66575e4075adcba454f" alt="在这里插入图片描述"
加载高德地图(√)
data:image/s3,"s3://crabby-images/7fdbb/7fdbb68c81a461f0a3787dc9cdeab643f24bea78" alt="在这里插入图片描述"
加载百度地图(√)
data:image/s3,"s3://crabby-images/6b306/6b306be56f73802c50b5b4301844470cccb691fe" alt="在这里插入图片描述"
人员定位(√)
data:image/s3,"s3://crabby-images/adf63/adf63379fd410d1df83f6eaf80ed7825c5855ebe" alt="在这里插入图片描述"
线标注(√)
data:image/s3,"s3://crabby-images/06dd0/06dd0bb4d0be918f3ba5d2459e59dd316812c60a" alt="在这里插入图片描述"
加载热力图(√)
data:image/s3,"s3://crabby-images/cc8d6/cc8d68d7556d8cace8311c7692bcd5edb17b9e77" alt="在这里插入图片描述"
自定义绘制箭头路线(√)
data:image/s3,"s3://crabby-images/e3605/e3605aa2f9f635b9deaf20a4a9e310ce73279ff7" alt="在这里插入图片描述"
项目存在的问题
- 没有充分发挥 ts 的作用;后续完善 arcgis api 的 ts 支持。
通过查资料发现 esri 发布的 @types/arcgis-js-api 虽然是有 3.x 的版本,但是只支持 4 的版本导出 __esri 命名空间以及直接使用:
import Map from 'esri/map'
const map = new Map()
- 解决方法
可以通过下面的方法来进行类型注释:
import React, { useEffect } from 'react';
import * as esriLoader from 'esri-loader';
import IMap from 'esri/map';
import IPoint from 'esri/geometry/Point'
import ISpatialReference from 'esri/SpatialReference'
const options = {
url: 'http://localhost/arcgis/init.js',
}
//加载脚本
esriLoader.loadScript(options)
esriLoader.loadCss(`http://localhost/arcgis/esri/css/esri.css`)
const PathReplay: React.FC = () => {
useEffect(() => {
initMap()
}, [])
const initMap = () => {
esriLoader.loadModules([
'esri/map',
'esri/geometry/Point',
'esri/SpatialReference'
])
.then(([Map, Point, SpatialReference]) => {
const map: IMap = new Map('mapCon', {
basemap: 'osm',
center: [0, 0],
zoom: 0
})
const spatialRe: ISpatialReference = new SpatialReference({
wkid: 4326
})
// 矢量注记图层
const PointObj: IPoint = new Point({
x: 114.41703647375107,
y: 23.10750961303711,
spatialReference: spatialRe
})
map.centerAndZoom(PointObj, 11)
})
.catch(err => {
console.error(err)
})
}
return (
<div id="mapCon">
</div>
)
}
export default PathReplay;
这样写 arcgis API 就会有对应的提示:
data:image/s3,"s3://crabby-images/f0dac/f0dacaef339c8df95c9db8133d87fb83ac3d9bcd" alt="在这里插入图片描述"
更新
react hooks 中 ts 类型注释
// 可以推断 age 是 number类型
const [age, setAge] = useState(20);
// 初始化值为 null 或者 undefined时,需要显示指定 name 的类型,
// name 为 string 或者 undefined
const [name, setName] = useState<string>();
// 初始化值为一个对象时
interface People {
name: string;
age: number;
country?: string;
}
const [owner, setOwner] = useState<People>({name: 'jiegiser', age: 18});
// 初始化值是一个数组时
const [members, setMembers] = useState<People[]>([]);