2018-3-19


ArcGIS api for JavaScript 在3.4之后就已经抛弃了过时的写法,采用了AMD的写法,AMD规范即异步模块加载机制,这种规范让JS就像其它面向对象语言(比如Java)一样,通过模块去管理代码。dojo的模块有点像java的包,而我们所需要的类就是在不同的模块中。

我现在有点纠结了,公司GIS模块的代码使用的是过时的写法,同时还自己写了很多类,看起来非常复杂,而公司部署的api版本是3.2的,注意不是3.2x版本哈,这个版本是很老的了;现在官网的Demo全是用的AMD规范写的,我真还不晓得该怎么办了。

但是无非就是两种:1将公司的代码使用AMD规范重写一遍(工作量非常之大,还容易出错);

2在官方学到的内容,在自己本上用AMD规范写,之后转换成过时写法,如果公司有需要将转换过后的内容添加上去(表面上要简单些,实际上不清楚,重点是对于公司的代码该怎么加上去是个问题);


今天就第二种先在本地实际操作了一下发现的坑:

先附上代码

     //AMD规范写法
    var map;
require(["esri/map","esri/layers/ArcGISDynamicMapServiceLayer","esri/layers/FeatureLayer",
"esri/symbols/SimpleFillSymbol","esri/symbols/SimpleLineSymbol","esri/renderers/SimpleRenderer","esri/InfoTemplate","esri/graphic","dojo/on","dojo/_base/Color", "dojo/domReady!"], function(Map,ArcGISDynamicMapServiceLayer,FeatureLayer,SimpleFillSymbol,SimpleLineSymbol,SimpleRenderer,InfoTemplate,Graphic,on,Color) {
map = new Map("map", {
//basemap: "streets", //For full list of pre-defined basemaps, navigate to http://arcg.is/1JVo6Wd
//center: [-96.45, 39.75], // longitude, latitude
zoom: 4,
sliderStyle:"small",
logo:false
}); var dynamicMapLayer1 = new ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/V1/CityFeature/MapServer"); map.addLayer(dynamicMapLayer1); //map加载事件,鼠标移除清空绘制的图形(高亮)和信息框
map.on("load",function(){
map.graphics.on("mouse-out",function(evt){
map.graphics.clear();
map.infoWindow.hide();
});
}); //创建一个特征图层并选出符合条件的要素
var olderStates = new FeatureLayer("http://localhost:6080/arcgis/rest/services/V1/CityFeature/MapServer/6",{
mode:FeatureLayer.Mode_SNAPSHOT,
outFields:["OBJECTID","name","floors","BianHao"]
});
//olderStates.setDefinitionExpression("floors<=20");
//创建一个符号,用来渲染符合条件的要素
var symbol = new SimpleFillSymbol(SimpleFillSymbol.STYLE_SOLID,new SimpleLineSymbol(SimpleLineSymbol.STYLE_SOLID,new Color([255,255,255,0.35]),1),new Color([125,125,125,0.35]));
olderStates.setRenderer(new SimpleRenderer(symbol));
//将特征图层加载到地图中
map.addLayer(olderStates); //创建一个信息框
var infoTemplate = new InfoTemplate();
infoTemplate.setTitle("${OBJECTID}");
infoTemplate.setContent("<b>名称:</b>${name}<br/>"+"<b>楼层数:</b>${floors}<br/>"+"<b>编号:</b>${BianHao}");
//设置信息框的大小
map.infoWindow.resize(245,125); //创建一个高亮符号
var highlightSymbol = new SimpleFillSymbol(SimpleFillSymbol.STYLE_SOLID,
new SimpleLineSymbol(SimpleLineSymbol.STYLE_SOLID, new Color([255,0,0]), new Color([125,125,125,0.35]))); //鼠标经过事件,将目标图形(evt对象中)高亮渲染并显示信息框信息
olderStates.on("mouse-over",function(evt){
map.graphics.clear();
evt.graphic.setInfoTemplate(infoTemplate);
var content = evt.graphic.getContent();
map.infoWindow.setContent(content);
var title = evt.graphic.getTitle();
map.infoWindow.setTitle(title);
var highlightGraphic = new Graphic(evt.graphic.geometry,highlightSymbol);
map.graphics.add(highlightGraphic);
map.infoWindow.show(evt.screenPoint,map.getInfoWindowAnchor(evt.screenPoit)); //evt的中心点 }); });

然后是

           //过时的写法
dojo.require("esri/map");
dojo.require("esri/layers/ArcGISDynamicMapServiceLayer");
dojo.require("esri/layers/FeatureLayer");
dojo.require("esri/symbols/SimpleFillSymbol");
dojo.require("esri/symbols/SimpleLineSymbol");
dojo.require("esri/renderers/SimpleRenderer");
dojo.require("esri/InfoTemplate");
dojo.require("esri/graphic");
dojo.require("dojo/on");
dojo.require("dojo/_base/Color");
dojo.require("dojo/domReady!"); var map; function init(){
map = new esri.Map("map",{
zoom:4,
logo:false
}); var dynamicMapLayer1 = new esri.layers.ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/V1/CityFeature/MapServer"); map.addLayer(dynamicMapLayer1); //map加载事件,鼠标移除清空绘制的图形(高亮)和信息框
map.on("load",function(){
map.graphics.on("mouse-out",function(evt){
map.graphics.clear();
map.infoWindow.hide();
});
}); //创建一个特征图层并选出符合条件的要素
var olderStates = new esri.layers.FeatureLayer("http://localhost:6080/arcgis/rest/services/V1/CityFeature/MapServer/6",{
mode:esri.layers.FeatureLayer.Mode_SNAPSHOT,
outFields:["OBJECTID","name","floors","BianHao"]
}); //创建一个符号,用来渲染符合条件的要素
var symbol = new esri.symbol.SimpleFillSymbol(esri.symbol.SimpleFillSymbol.STYLE_SOLID,
new esri.symbol.SimpleLineSymbol(esri.symbol.SimpleLineSymbol.STYLE_SOLID,
new dojo.Color([255,255,255,0.35]),1),new dojo.Color([125,125,125,0.35]));
olderStates.setRenderer(new esri.renderer.SimpleRenderer(symbol));
//将特征图层加载到地图中
map.addLayer(olderStates); //创建一个信息框
var infoTemplate = new esri.InfoTemplate();
infoTemplate.setTitle("${OBJECTID}");
infoTemplate.setContent("<b>名称:</b>${name}<br/>"+"<b>楼层数:</b>${floors}<br/>"+"<b>编号:</b>${BianHao}");
//设置信息框的大小
map.infoWindow.resize(245,125); //创建一个高亮符号
var highlightSymbol = new esri.symbol.SimpleFillSymbol(esri.symbol.SimpleFillSymbol.STYLE_SOLID,
new esri.symbol.SimpleLineSymbol(esri.symbol.SimpleLineSymbol.STYLE_SOLID, new dojo.Color([255,0,0]), new dojo.Color([125,125,125,0.35]))); //鼠标经过事件,将目标图形(evt对象中)高亮渲染并显示信息框信息
olderStates.on("mouse-over",function(evt){
map.graphics.clear();
evt.graphic.setInfoTemplate(infoTemplate);
var content = evt.graphic.getContent();
map.infoWindow.setContent(content);
var title = evt.graphic.getTitle();
map.infoWindow.setTitle(title);
var highlightGraphic = new esri.Graphic(evt.graphic.geometry,highlightSymbol);
map.graphics.add(highlightGraphic);
map.infoWindow.show(evt.screenPoint,map.getInfoWindowAnchor(evt.screenPoit)); //evt的中心点 }); }
dojo.addOnLoad(init);

我将不同的地方用红色标出来了,可以发现,过时的写法大体上和AMD规范没得什么区别,需要注意的是require的引用,还有之后调用esri资源中的对象时要加上些东西;

坑在有些和引用的不太一样,比如说FeatureLayer 和SimpleFillSymbol 的调用就是有区别,一个是esri.layers.  一个是esri.symbol. 还有color : dojo.Color 没有资源上的_base;

这些以后还有,得注意一下。

关于ArcGIS api for JavaScript的一些内容的更多相关文章

  1. [ArcGIS API for JavaScript 4.8] Sample Code-Get Started-widgets简介

    [官方文档:https://developers.arcgis.com/javascript/latest/sample-code/intro-widgets/index.html] 一.Intro ...

  2. ArcGIS API for JavaScript 4.2学习笔记[5] 官方API大章节概述与内容转译

    内容如上,截图自ESRI官网,连接:ArcGIS API for JavaScript 4.2 [Get Started] 类似于绪论一样的东西,抽取了最需要关注的几个例子.如:加载Map和View, ...

  3. ArcGIS API for JavaScript开发环境搭建及第一个实例demo

    原文:ArcGIS API for JavaScript开发环境搭建及第一个实例demo ESRI公司截止到目前已经发布了最新的ArcGIS Server for JavaScript API v3. ...

  4. ArcGIS API for JavaScript FeatureLayer服务属性编辑

    首先说一下感想吧,刚入行时感觉深似海,掉到了GIS开发的陨石大坑里了,首先是学了小半年的Flex,用到了ArcGIS API for Flex,接着又是半年的ArcEngine开发,现在终于摸到了一点 ...

  5. ArcGIS API for JavaScript 4.2学习笔记[0] AJS4.2概述、新特性、未来产品线计划与AJS笔记目录

    放着好好的成熟的AJS 3.19不学,为什么要去碰乳臭未干的AJS 4.2? 4.2全线基础学习请点击[直达] 4.3及更高版本的补充学习请关注我的博客. ArcGIS API for JavaScr ...

  6. [ArcGIS API for JavaScript 4.8] Sample Code-Get Started-MapView,SceneView简介

    [官方文档:https://developers.arcgis.com/javascript/latest/sample-code/index.html]  一.Intro to MapView(2D ...

  7. 转:ArcGIS API For JavaScript官方文档(二十)之图形和要素图层——①Graphics概述

    原文地址:ArcGIS API For JavaScript官方文档(二十)之图形和要素图层——①Graphics概述 ArcGIS JavaScript API允许在地图上绘制graphic(图形) ...

  8. ArcGIS API for JavaScript开发初探——HelloMap

    1.前言 在开始ArcGIS API for JavaScript开发之前我们需要了解一些基本的知识: 1.开发工具选什么? 前端技术的开发工具选择是一个仁者见仁智者见智的问题,有人喜欢Hbuilde ...

  9. ArcGIS API for JavaScript开发初探——基础知识

    1.前言 在ArcGIS Web API开发体系中一共有四大类,分别为: ArcGIS API for Flex ArcGIS API for JavaScript ArcGIS API for RE ...

随机推荐

  1. c# json key转大小写

    有需求需要将json的字段转换为小写,使用正则表达式实现,代码如下 正则表达式为   \"[a-zA-Z0-9]+\"\s*: MatchCollection ms = Regex ...

  2. 获取函数的地址(三种方法,分别是@,Addr,MethodAddress)

    问题来源: http://www.cnblogs.com/del/archive/2008/07/30/1039045.html#1272783 在编译器看来, 重载函数根本就是完全不同的几个函数, ...

  3. 在Linux中如何利用backtrace信息解决问题

    在Linux中如何利用backtrace信息解决问题 一.导读 在程序调试过程中如果遇到程序崩溃死机的情况下我们通常多是通过出问题时的栈信息来找到出错的地方,这一点我们在调试一些高级编程语言程序的时候 ...

  4. python-监控服务

    最近写了一个web测试程序,因为部署在其他地方,所以想弄个监控的进程去看服务是不是还在,要是不在好发邮件,就用python简单的写了一个. 想法是这样的,单独运行一个monitor的脚本,每隔一段时间 ...

  5. HTML连载14-文字属性补充&简写

    一.字体属性(补充) 1.如果设置的字体不存在,那么系统会使用默认的字体来显示宋体. font-family:"瞎写的一个字体"; 2.如果设置的字体不存在,而我们又不想用默认的字 ...

  6. 如何使用VS Code编写Spring Boot (第二弹)

    本篇文章是续<如何使用VS Code编写Spring Boot> 之后,结合自己.net经验捣鼓的小demo,一个简单的CRUD,对于习惯了VS操作模式的.net人员非常方便,强大的智能提 ...

  7. spring 5.x 系列第9篇 —— 整合mongodb (xml配置方式)

    源码Gitub地址:https://github.com/heibaiying/spring-samples-for-all 一.说明 1.1 项目结构说明 配置文件位于resources下,项目以单 ...

  8. 【java爬虫】网络爬虫思路

    主要是针对某个单独的网站进行页面的爬取,方式有好多种,记录一下大体的思路. 方法1: a.通过http请求获取返回的静态页面. b.将返回的字符串页面进行split,切割成字符串数组. c.遍历字符串 ...

  9. 还在被大妈灵魂拷问?使用Python轻松完成垃圾分类!

    目录 0 环境 1 引言 2 思路 3 图像分类 4 总结 0 环境 Python版本:3.6.8 系统版本:macOS Mojave Python Jupyter Notebook 1 引言 七月了 ...

  10. c#基础四

    写入一个XML文件 using System; using System.Collections.Generic; using System.Linq; using System.Text; usin ...