Недавно где-то
я слышал историю про одного незаменимого
специалиста, программиста, который
очень быстро осваивал всякие новые
технологии. Типа, не успели еще толком
раскрутить, например, некий фреймворк,
а он на нем уже что-то делает. Видимо
этим и был ценен. Проходит месяц, другой,
этот парень уже на новом проекте, а то,
что он наваял — допиливают типа простые
смертные.
Ну слышал, ну
и что? А дело в том, что на днях я закончил
(не то чтобы закончил, но, во всяком
случае, то что должно работать — работает)
вот такое допиливание, а если точнее —
почти полную переделку проекта
feature-service-editor-js,
накаляканного вот таким вот специалистом.
Познакомься, Алиса, это Пудинг
Andy Gup
(https://github.com/andygup).
Та версия,
что он опубликовал в репозитории
Esri просто не работает. После третьего
клика по функциональным кнопкам
начинаются чудеса, обычные для программы
полной багов. Чтобы от этих багов
избавиться, пришлось процентов 30 кода
переписать заново, потратив более трех
недель времени на отладку. К сожалению,
ключевую концепцию дизайна программы
(ошибочную и даже вредную) так просто
не переделаешь. И этот Энди работает
«Developer Evangelist for Esri»! Упаси бог от таких
евангелистов.
Короче, если
вам вдруг нужно приделать к карте
таблицу, в которой можно еще и редактировать
данные Feature
Layer, то берите таблицу у меня
(https://github.com/vasnake/feature-service-editor-js)
или делайте сами,
благо это не так трудно как кажется.
Но ни в коем
разе не пытайтесь использовать это
угробище: https://github.com/Esri/feature-service-editor-js
Собственно,
пост этот я хотел посвятить немного
другому, но увлекся нытьем, простите
грешного.
Я хотел показать,
ибо народ часто спрашивает а ответа не
находит, как обновлять/reload/reset/rebuild/recreate
таблицу dojo/dgrid.
Обычно советуют
сбросить коллекцию полей и подключить
новый storage. Это все сложно. Показываю
как проще (три куска кода из рабочего
проекта):
// destroy grid // освободить хандлеры событий if(featureEditor.dgridRowClickListener != null) featureEditor.dgridRowClickListener.remove(); if(featureEditor.dgridCellDblClickListener != null) featureEditor.dgridCellDblClickListener.remove(); featureEditor.dgridRowClickListener = null; featureEditor.dgridCellDblClickListener = null; // грохнуть грид. Пичалька, но тут пропадает DOM элемент, поэтому приходится его пересоздавать if(featureEditor.grid) { featureEditor.loadingIcon.destroy(); featureEditor.grid.revert(); featureEditor.grid.destroy(); featureEditor.grid = null; dojo.place('<div id="grid" class="grid1"></div>', 'grid-legend-parent', 'before'); } ... // когда надо, создаем грид featureEditor.store = new Memory({ data: [], idProperty: fields[0].field // OBJECTID probably }); // Dojo's dGrid var DataGrid = declare([OnDemandGrid, Selection, CellSelection, Keyboard]); featureEditor.grid = new DataGrid({ store: featureEditor.store, columns: fields, selectionMode: 'single' /*, noDataMessage:'Nothing found.' */ }, 'grid'); featureEditor.grid.startup(); featureEditor.utils._setListeners(); ... // и когда надо, обновляем данные в гриде featureEditor.grid.set("store", featureEditor.store); featureEditor.grid.refresh(); |
Этот фокус
прекрасно работает в моем варианте
https://github.com/vasnake/feature-service-editor-js
Вот как-то так.
original post http://vasnake.blogspot.com/2013/12/blog-post_19.html
Комментариев нет:
Отправить комментарий