开发ArcGIS Online应用程序模板之前,需要了解怎么使用ArcGIS API for JavaScript。
在ArcGIS Online当中如何构架自己的应用程序模板,我们得先要了解ArcGIS Online如何解析这个web地图的。
做过程序开发的,都清楚,每一个item都对应着数据库的一个id值。而ArcGIS Online这个Id名称是webmap。
这就简单了,我们有了这个webmap的值,然后查询数据库或其他文件就能得到这个webmap。
第一步,我们就需要进行对这个webmap参数值解析。
var queryString = function(key) { return (document.location.search.match(new RegExp("(?:^\\?|&)"+key+"=(.*?)(?=&|$)"))||['',null])[1]; }
function init() { var WEBMAP_ID = queryString("webmap")||"ceac2dfaea0449119724e8b78e99013a";//默认值 }其实ArcGIS API for JavaScript有这么一个类似的函数。
function init() { var urlObject = esri.urlToObject(document.location.href); if(urlObject.query && typeof (urlObject.query.webmap) != "undefined") { var WEBMAP_ID = urlObject.query.webmap; } else { var WEBMAP_ID = "ceac2dfaea0449119724e8b78e99013a" } }
第二步,有了webmap值,我们就可以根据这个ID值,就可以来创建我们的地图。
function init() { var urlObject = esri.urlToObject(document.location.href); if(urlObject.query && typeof (urlObject.query.webmap) != "undefined") { var WEBMAP_ID = urlObject.query.webmap; } else { var WEBMAP_ID = "ceac2dfaea0449119724e8b78e99013a" } var mapDeferred = esri.arcgis.utils.createMap(WEBMAP_ID, "map", { mapOptions : { slider : true }, ignorePopups : false, bingMapsKey : "" }); mapDeferred.addCallback(function(response) { console.log(response); _map = response.map; dojo.connect(dijit.byId('map'), 'resize', _map,_map.resize); }) }
esri.arcgis.utils.createMap参数。
返回值,是一个dojo.Deferred对象,关于这个对象具体怎么使用可以观看
这篇文章。addCallback,很明显就是添加一个回调函数,等得到item对象数据之后,然后调用这些回调函数。
这样简单的,几句代码就可以很容易显示出ArcGIS Online上的web 地图。
原文链接: http://blog.csdn.net/arcgis_all/article/details/8200220