Arcgis api for js实现服务端地图的增删改查
< !DOCTYPE html >
<html xmlns = "http://www.w3.org/1999/xhtml" >
<head >
meta http - equiv = "Content-Type"content = "text/html; charset=utf-8" / >
<title > WebGIS < /title>
<link rel="stylesheet" type="text/css " href="https: //js.arcgis.com/3.21/dijit/themes/tundra/tundra.css"/>
< link rel = "stylesheet"type = "text/css"href = "https://js.arcgis.com/3.21/esri/css/esri.css" / >
<script type = "text/Javascript"src = "https://js.arcgis.com/3.21/init.js" > </script>
<style type="text/css ">
.MapClass{
width:100%;
height:500px;
border:1px solid #000;
}
</style>
<script type="text / javascript ">
require(["esri / map ",
"dojo / on ",
"dojo / query ",
"esri / layers / ArcGISDynamicMapServiceLayer ",
"esri / toolbars / draw ",
"esri / layers / FeatureLayer ",
"esri / graphic ", "esri / dijit / editing / Add ",
"esri / dijit / editing / Delete ","esri / dijit / editing / Update ","esri / tasks / query ","dojo / json ","dojo / domReady ! "],
function (Map,on,query, ArcGISDynamicMapServiceLayer, Draw,FeatureLayer,Graphic,Add,Delete,Update,Query,jsonUtil) {
var map = new esri.Map("MyMapDiv ");
var layer = new ArcGISDynamicMapServiceLayer("http: //localhoust:6080/arcgis/rest/services/2000/MapServer");
map.addLayer(layer);
//用于操作的要素图层
var featureLayer = new FeatureLayer("http://localhoust:6080/arcgis/rest/services/2000/FeatureServer/13",
{
mode: FeatureLayer.MODE_SNAPSHOT,
outFields: ["*"]
});
//在添加要素时,利用Draw工具获得geometry对象
var d = new Draw(map, {
showTooltips: true
});
//要操作的graphic
var g;
query("button").on("click",
function(event) {
var value = this.innerHTML;
switch (value) {
case "添加要素":
d.activate(Draw.POLYGON);
break;
case "删除要素":
//创建Graphic对象,删除OBJECTID为34的元素,
//因为OBJECTID是主键,所以只需要指定主键即可
g = new Graphic("", "", {
"OBJECTID": 34
});
//创建删除对象
var de = new Delete({
"featureLayer": featureLayer,
"deletedGraphics": [g]
});
//执行删除结果
de.performRedo();
//刷新图层
layer.refresh();
break;
case "修改要素":
//用于修改要素的函数,查询更新为36的要素
updateFeature(223614);
break;
case "查询要素":
//用于查询要素的函数,查询主键为36的要素
searchFeather(1);
break;
}
});
//当画图完毕时,添加要素
on(d, "draw-complete",
function(result) {
//要素只赋予了geometry,属性信息为空
var graphic = new Graphic(result.geometry, null, {});
graphic.attributes.add("");
var add = new Add({
"featureLayer": featureLayer,
//给哪一个要素图层添加要素
"addedGraphics": [graphic] //用于添加的要素
})
//执行添加函数
add.performRedo();
//刷新视图
layer.refresh();
//关闭绘图对象
d.deactivate();
});
//根据id修改要素
function updateFeature(id) {
//注意:(第二个参数)这里传入一个回调函数,用于处理查询出来的数据
searchFeather(id,
function(result) {
//获得旧的要素
var oldgraphic = result[0];
//新的要素
var newgraphic = new Graphic(oldgraphic.toJson());
//此处可以Draw重新画图
//var newgraphic=new Graphic(newGeometry,null,newAttributes);
var newAttributes = newgraphic.attributes;
newAttributes.MAINPERSON = "Wxz"newgraphic.attributes = newAttributes;
//创建更新对象
var update = new Update({
"featureLayer": featureLayer,
"postUpdatedGraphics": [newgraphic],
//修改之后的要素
"preUpdatedGraphics": [oldgraphic] //修改之前的要素
})
//执行刷新操作
update.performRedo();
//刷新视图
layer.refresh();
alert("修改成功");
})
}
//根据id查询要素
function searchFeather(id, callback) {
//得到要素图层的主键属性
var idProperty = featureLayer.objectIdField;
//定义查询参数
var query = new Query();
//是否返回几何形状
query.returnGeometry = false;
//图层的主键名称(根据自己要求修改)
query.objectIds = [id];
//查询条件1=1意思是:只根据主键查询,忽略where子句
query.where = "1=1";
//进行查询
featureLayer.selectFeatures(query, FeatureLayer.SELECTION_NEW,
function(result) {
//如果callback不存在,说明仅仅是查询操作
if (!callback) {
//因为我们根据主键查询,一定只有一个元素
var graphic = result[0];
//获得属性
var attributes = graphic.attributes;
//得到该属性信息转换成字符串
var result = jsonUtil.stringify(attributes)
//将结果弹出一下
alert(result);
} else //如果callback存在,说明是更新操作
{
callback(result);
}
});
}
});
< /script>
</head > <body > <div id = "MyMapDiv"class = "MapClass" > </div>
<button class="btn">添加要素</button > <button class = "btn" > 删除要素 < /button>
<button class="btn">修改要素</button > <button class = "btn" > 查询要素 < /button>
</body > </html>
Arcgis api for js实现服务端地图的增删改查的更多相关文章
- springboot+layui实现PC端用户的增删改查 & 整合mui实现app端的自动登录和用户的上拉加载 & HBuilder打包app并在手机端下载安装
springboot整合web开发的各个组件在前面已经有详细的介绍,下面是用springboot整合layui实现了基本的增删改查. 同时在学习mui开发app,也就用mui实现了一个简单的自动登录和 ...
- JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(三):两个Viewmodel搞定增删改查
前言:之前博主分享过knockoutJS和BootstrapTable的一些基础用法,都是写基础应用,根本谈不上封装,仅仅是避免了html控件的取值和赋值,远远没有将MVVM的精妙展现出来.最近项目打 ...
- JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(二)
前言:上篇 JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(一) 介绍了下knockout.js的一些基础用法,由于篇幅的关系,所以只能分成两篇,望见谅!昨天就 ...
- JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(一)
前言:出于某种原因,需要学习下Knockout.js,这个组件很早前听说过,但一直没尝试使用,这两天学习了下,觉得它真心不错,双向绑定的机制简直太爽了.今天打算结合bootstrapTable和Kno ...
- JS组件系列——BootstrapTable+KnockoutJS实现增删改查解决方案(四):自定义T4模板快速生成页面
前言:上篇介绍了下ko增删改查的封装,确实节省了大量的js代码.博主是一个喜欢偷懒的人,总觉得这些基础的增删改查效果能不能通过一个什么工具直接生成页面效果,啥代码都不用写了,那该多爽.于是研究了下T4 ...
- WCFRESTFul服务搭建及实现增删改查
WCFRESTFul服务搭建及实现增删改查 RESTful Wcf是一种基于Http协议的服务架构风格, RESTful 的服务通常是架构层面上的考虑. 因为它天生就具有很好的跨平台跨语言的集成能力 ...
- JQuery Easyui/TopJUI 用JS创建数据表格并实现增删改查功能
JQuery Easyui/TopJUI 用JS创建数据表格并实现增删改查功能 html <table id="productDg"></table> &l ...
- 页面循环绑定(变量污染问题),js面向对象编程(对象属性增删改查),js字符串操作,js数组操作
页面循环绑定(变量污染问题) var lis = document.querySelectorAll(".ul li") for ( var i = 0 ; i < lis. ...
- vue.js+element ui Table+spring boot增删改查
小白初学,不懂的还是太多了,找了好多资料才做出来的先记录一下 1.先用Spring boot创建一个包含了增删改查的项目 2.创建vue.js项目 3.安装Element UI (1)进入项目文件夹下 ...
随机推荐
- linux服务器安装宝塔以及一些坑
首先在linux 下运行这一步命令yum install -y wget && wget -O install.sh http://download.bt.cn/install/ins ...
- Linux性能优化思路
性能测试的核心,就是找出性能瓶颈并进行性能优化,解决"慢"的问题,最终满足客户业务需求. [性能需求来源及性能问题现象] 性能需求的来源,主要分为以下几类: 项目组提出性能需求: ...
- docker镜像瘦身思路
docker镜像瘦身思路 一.简介 docker镜像太大,带来了以下几个问题: 存储开销 这块影响其实不算很大,因为对服务器磁盘来说,15GB的存储空间并不算大,除非用户服务器的磁盘空间很紧张 部署时 ...
- Hystrix总结
Hystrix 能使你的系统在出现依赖服务失效的时候,通过隔离系统所依赖的服务,防止服务级联失败,同时提供失败回退机制,更优雅地应对失效,并使你的系统能更快地从异常中恢复. Hystrix能做什么? ...
- 尚硅谷maven视频教程笔记
07.尚硅谷_Maven_部署Maven核心程序.avi 第一步先安装jdk 第二步下载maven 特别需要注意的是maven不能存储在有中文和空格的目录下面 3.调试是否安装成功,在cmd中输入 m ...
- SpringMVC 学习笔记(7)异常操作
如何使用HandleException 在程序中,异常是最常见的,我们需要捕捉异常并处理它,才能保证程序不被终止. 最常见的异常处理方法就是用try catch来捕捉异常.这次我们使用springmv ...
- Redis:rdb和aof
由于redis的数据都直接存储在内存里,在服务器发生宕机时内存的数据会瞬间清空,那么必须要有重启时恢复数据的方法. redis通过持久化机制将数据存储到磁盘中从而在服务器重启时恢复数据,这篇文章主要简 ...
- python的常用魔法方法详细总结
构造和初始化 __init__我们很熟悉了,它在对象初始化的时候调用,我们一般将它理解为"构造函数". 实际上, 当我们调用x = SomeClass()的时候调用,__init_ ...
- Docker部署Python项目
简介 软件开发最大的麻烦事之一就是环境配置,操作系统设置,各种库和组件的安装.只有它们都正确,软件才能运行.如果从一种操作系统里面运行另一种操作系统,通常我们采取的策略就是引入虚拟机,比如在 Wind ...
- 设计模式--Builder生成器模式
如果文章中哪里有问题,希望各位大哥大姐指出,小弟十分感激. 正文 什么是生成器模式? 生成器模式就是把生产对象的过程进一步抽取.细化.独立.以往我们生产对象,可能就是在一个小作坊里面从头做到尾.现在用 ...