一、为什么说ArcGIS API for JavaScript是构建于Dojo之上的?
1. 编写ArcGIS API for JavaScript的ESRI开发者使用Dojo来简化他们的开发过程,同时确保所开发的应用程序在不同的浏览器中表现一致。
2. 在JavaScript API实现的地图窗口中的缩放杆便是Dojo微件(dijits)。
二、使用ArcGIS API for JavaScript开发时,需要对Dojo知道多少?
对Dojo了解的深度取决于你的需要,但是以下这些是你必须了解的:
dojo.require:类似于HTML页面的<script>包含标签,实现在页面中引用相关资源。如:
- dojo.require("esri.map");
常用的资源如下表
资源 | 用途 |
---|---|
esri.map | Map, geometry, graphics, and symbols |
esri.layers.agsdynamic | ArcGISDynamicMapServiceLayer |
esri.layers.agstiled | ArcGISTiledMapServiceLayer |
esri.tasks.find | Find Task |
esri.tasks.geometry | Geometry task |
esri.tasks.gp | Geoprocessing task |
esri.tasks.identify | Identify task |
esri.tasks.locator | Locator task |
esri.tasks.query | Query task |
esri.toolbars.draw | Draw |
esri.toolbars.navigation | Navigation |
- dojo.ready (或 dojo.addOnLoad):类似于<body onload="">,用于页面加载完成后注册初始块。
- dojo.ready(init);
-
dojo.connect: 类似于Element.addEventListener 和Element.attachEvent,用于注册监听器以监听页面上对象或元素的某个事件,返回执行结果。
- dojo.connect(myMap, "onLoad", myLoadHandler);
- dojo.byId: 类似于document.getElementById(id) ,用于搜索与返回页面上参数ID对应的第一个HTML元素。
- dojo.byId("myInputField").value = myMap.id;
-
dojo array extras:参考Arrays Made Easy tutorial on dojotoolkit.org
当你编写ArcGIS JavaScript应用程序时,你可以充分使用Dojo工具箱,包括Button、Grid、TreeView、Chart等微件。这些工具归纳为三类:
- Core-基础核心控件
- Dijit -如Tree、Menu、Button等主题微件
- DojoX-开发不同阶段使用的扩展项目,如 Graphic, Grid, and Chart
如前所述,在开始开发时,你仅需要少量的Dojo知识,但是对此你了解的越多,将越有利于你编程。具体可参考Dojotoolkit.org's的向导与文档。