深入浅出 Javascript API(五)--Query Find 查询
??? 作者:Flyingis
??? 本文嚴禁擅自轉載或用于商業目的,如有需要請事先聯系作者:dev.vip#gmail.com
?
??? 查詢是webgis常用功能之一,基于地圖的查詢經歷了多種形式的演變,現在用什么形式來展現查詢已經沒有固定模式,在適合webgis范圍內,什么形式能夠滿足應用,就用什么形式的查詢。舉例描述一個最經典的場景,鼠標點擊地圖顯示一個TIP小窗口,顯示查詢對象的簡單信息,小窗口中提供一個"詳細信息"鏈接,點擊后彈出網頁顯示資料卡片。還有這樣的形式,如拉框選擇點要素,同時在地圖下方的DIV顯示出選擇點的屬性信息,這個在《ArcGIS Server 開發系列(五)--自定義 Toolbar 工具》通過ADF已經實現。Ags Javascript API如何完成這些功能呢?
?
??? 內容目錄:
1.Query查詢屬性數據(無地圖)
2.鼠標移動顯示Query查詢結果
3.Find查詢地圖,并在頁面下方顯示相應屬性數據
1.僅用Query查詢屬性,不返回地圖信息,此時就不再需要創建esri.layers.ArcGISMapServiceLayer對象來處理地圖,但是需要引入"esri.tasks.query",并創建QueryTask對象:
queryTask?=?new?esri.tasks.QueryTask("http://sampleserver1.arcgisonline.com/ArcGIS/rest/services/Demographics/ESRI_Census_USA/MapServer/5");??? webgis查詢一般涉決定返回結果的參數,包括是否返回幾何圖形,查詢的屬性字段,查詢方式(默認"SPATIAL_REL_INTERSECTS"),查詢Where語句等,例如:
query?=?new?esri.tasks.Query();
query.returnGeometry?=?false;
query.outFields?=?["SQMI","STATE_NAME","SUB_REGION","POP2000","POP2007","MALES","FEMALES"];
??? 執行查詢,并將結果寫入回調函數showResults:
function?execute(stateName)?{
????query.text?=?stateName;
????queryTask.execute(query,showResults);
}
??? 所有的結果都會寫入到showResults參數Featureset對象中,遍歷該對象得到我們想要的屬性結果。
??? 查詢方式:
?
2.鼠標移動顯示Query查詢結果是常用的查詢方式之一,最重要的就是利用了Ajax異步傳輸,將少量的信息顯示在一個Tip中,訪問效率高,體驗較好。這里我們可以決定,是默認指定一圖層區域要素進行hover查詢,還是鼠標點擊要查詢的要素后,再hover查詢,以實現前者為例,其他方式以此類推。
??? 查詢功能主要是這幾行代碼完成:
var?queryTask?=?new?esri.tasks.QueryTask("http://sampleserver1.arcgisonline.com/ArcGIS/rest/services/Demographics/ESRI_Census_USA/MapServer/3");
var?query?=?new?esri.tasks.Query();
query.returnGeometry?=?true;
query.outFields?=?["NAME",?"POP2000",?"POP2007",?"POP00_SQMI",?"POP07_SQMI"];
query.where?=?"STATE_NAME?=?'South?Carolina'";
??? "query.text"和"query.where"區別在于,前者是通過"like"方式執行where查詢,后者是直接寫SQL語句。
??? TIP UI是一個InfoWindow
var?infoTemplate?=?new?esri.InfoTemplate();
infoTemplate.title?=?"${NAME}";
infoTemplate.content?=?"<b>2000?Population:?</b>${POP2000}<br/>"
?+?"<b>2000?Population?per?Sq.?Mi.:?</b>${POP00_SQMI}<br/>"
?+?"<b>2007?Population:?</b>${POP2007}<br/>"
?+?"<b>2007?Population?per?Sq.?Mi.:?</b>${POP07_SQMI}";
map.infoWindow.resize(205,125);
??? 鼠標移動到指定區域后,通過對鼠標onmousemove和onmouseout事件來顯示或隱藏查詢TIPs
dojo.connect(map.graphics,?"onMouseOver",?function(evt)?{
????var?content?=?evt.graphic.getContent();
????map.infoWindow.setContent(content);
????var?title?=?evt.graphic.getTitle();
????map.infoWindow.setTitle(title);
????evt.graphic.setSymbol(highlightSymbol);
????map.infoWindow.show(evt.screenPoint,map.getInfoWindowAnchor(evt.screenPoint));
});
dojo.connect(map.graphics,?"onMouseOut",?function(evt)?{
????map.infoWindow.hide();
????evt.graphic.setSymbol(symbol);
});
?
?
3.Find 查詢,和Query功能類似,但使用的REST服務不同,Query需要指定具體的REST圖層服務,如"http://sampleserver1.arcgisonline.com/ArcGIS/rest/services /Demographics/ESRI_Census_USA/MapServer/3",而Find僅需提供當前地圖服務"http: //sampleserver1.arcgisonline.com/ArcGIS/rest/services/Specialty /ESRI_StatesCitiesRivers_USA/MapServer",然后通過屬性來控制對哪個圖層進行查找。
findTask?=?new?esri.tasks.FindTask("http://sampleserver1.arcgisonline.com/ArcGIS/rest/services/Specialty/ESRI_StatesCitiesRivers_USA/MapServer");findParams?=?new?esri.tasks.FindParameters();
findParams.returnGeometry?=?true;
findParams.layerIds?=?[0,1,2];
findParams.searchFields?=?["CITY_NAME","NAME","SYSTEM","STATE_ABBR","STATE_NAME"];
?
??? 這樣做的好處是,可以方便的對多個圖層進行查詢,js代碼只需要設置layerIds,在此之前添加"dojo.require("esri.tasks.find");"。頁面下方顯示查詢結果,通過Ajax刷新,這里可以利用dojox.grid 完成這個過程,Find搜索只能用like方式,并且不區分大小寫,這是和Query另外一個區別。
?
轉載于:https://www.cnblogs.com/flyingis/archive/2008/07/29/1255373.html
總結
以上是生活随笔為你收集整理的深入浅出 Javascript API(五)--Query Find 查询的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: FusionCharts Free(3)
- 下一篇: JS收集:限制输入格式