zoukankan      html  css  js  c++  java
  • Arcgis api for javascript学习笔记(3.2X版本)-初步尝试

    Arcgis api for javascript(3.22版本)官方地址 :https://developers.arcgis.com/javascript/3/

    1. 根据官方示例实现一个简单地图展示功能。

           示例代码:

     1 <!DOCTYPE html>
     2 <html>
     3 <head>
     4     <link rel="stylesheet" href="https://js.arcgis.com/3.22/esri/css/esri.css">
     5     <style type="text/css">
     6         html, body { margin: 0; padding: 0; height: 100%; width: 100%; }
     7         #viewDiv{ width:100%;height:100%; }
     8     </style>
     9     <script src="https://js.arcgis.com/3.22/"></script>
    10 </head>
    11 <body>
    12     <div id="viewDiv"></div>
    13     <script type="text/javascript">
    14         require(["esri/map", "dojo/domReady!"], function(Map) {
    15             var map = new Map("viewDiv", {
    16                 "basemap": "streets"
    17             });
    18         });
    19     </script>
    20 </body>
    21 </html>

    示例截图:

    2. Arcgis api for javascript离线部署

    引用官网上的资源文件通常请求和加载比较慢,所以离线部署在本地会更好。

    第一步:下载 arcgis js api压缩包并解压,有需要的也可以将arcgis js sdk也下载一份。api是我们开发需要的库,sdk是说明文档和例子;

    第二步:替换域名 [HOSTNAME_AND_PATH_TO_JSAPI];

    找到下面这两个文件,并将文件里面的“[HOSTNAME_AND_PATH_TO_JSAPI]”内容替换成相应的域名(ip地址:端口)

    D:arcgis_js_apiarcgis_js_v320_apilibrary3.203.20init.js
    D:arcgis_js_apiarcgis_js_v320_apilibrary3.203.20dojodojo.js

    第三部:将该文件夹作为部署包在IIS或其他服务器进行发布,具体部署方法网上有很多教程;

    部署成功后,只需将原来的css和js文件引用改成本地地址就可以了,如下图所示:

     1 <!DOCTYPE html>
     2 <html>
     3 <head>
     4     <link rel="stylesheet" href="http://localhost:8003/arcgis_js_v320_api/library/3.20/3.20/esri/css/esri.css">
     5     <style type="text/css">
     6         html, body { margin: 0; padding: 0; height: 100%; width: 100%; }
     7         #viewDiv{ width:100%;height:100%; }
     8     </style>
     9 </head>
    10 <body>
    11     <div id="viewDiv"></div>
    12     <script src="http://localhost:8003/arcgis_js_v320_api/library/3.20/3.20/init.js"></script>
    13     <script type="text/javascript">
    14         require(["esri/map", "dojo/domReady!"], function(Map) {
    15             var map = new Map("viewDiv", {
    16                 "basemap": "streets"
    17             });
    18         });
    19     </script>
    20 </body>
    21 </html>

    3. 示例代码分析

    • 创建一个id为"viewDiv"的div作为map对象渲染地图的容器
      <div id="viewDiv"></div>
    • js在执行过程中可能会用到其他js文件,但是不需要自定义引入相应的js文件。所以如果api中缺少相关文件,可能会出现异常。我们把require那一段代码注释掉,发现引入init.js文件后,会自动动态引入其他js文件。如下图所示:

    客户端发送的请求资源信息

      

      浏览器加载后的dom结构:

    • arcgis js 依赖 dojo,所以有必要了解一些常用dojo基本操作。这里先简单说一下require

      在老版本中的写法中,对require的作用可能更好理解一点。可以理解为:要new 一个esri.Map对象需要先引入其所在的包 esri.map  

        <script type="text/javascript">
            dojo.require("esri.map");        
            function init() {
                var map = new esri.Map("viewDiv", {
                    "basemap": "oceans"
                });
            }
            dojo.addOnLoad(init);
        </script>

      而示例中可以看作是老版本的简写。require([],function(){})函数中第一个参数可以看作是要引入的包数组,第二个参数function函数中的参数就是引入包(按顺序)的别名,引入包成功后就会执行该函数。

    • basemap参数,即为该地图的底图,可以在此底图上叠加其他图层。basemap官方提供有很多种:

      

  • 相关阅读:
    HTML页面空格记录&nbsp;&ensp; &emsp; (小计)
    JS对象、构造器函数和原型对象之间的关系
    情人节,送女友一桶代码可否?
    JavaScript中的BOM和DOM
    js中字符替换函数String.replace()使用技巧
    XML DOM 节点类型(Node Types)
    node 基础
    npm脚本命令npm run script的使用
    Node.js学习笔记六,获取get/post请求的参数
    querystring模块详解
  • 原文地址:https://www.cnblogs.com/tracine0513/p/7792542.html
Copyright © 2011-2022 走看看