У меня есть улучшенная сетка, я хочу отредактировать содержимое сетки и однажды щелкнув по ссылке «Обновление», мне нужно передать новые типизированные значения в контроллер пружины java, где у меня есть логика для сохранения обновленных значений в базе данных. Но проблема заключается в том, что после того, как я наберу значение в расширенной сетке, мне нужно щелкнуть где-нибудь в сетке или сделать фокус на другом поле, чтобы новое типизированное значение передавалось контроллеру пружины. Если я набираю новое значение, и ячейка находится в режиме редактирования и непосредственно нажимает на ссылку UPDATE, присутствующую в столбце4 сетки, старое значение передается контроллеру пружины. Пожалуйста, представьте, какие изменения необходимо внести, чтобы, когда мышь вышла из фокуса ячейки, новое типизированное значение должно сохранить в памяти, и это значение должно быть отправлено контроллеру весны, когда на ссылку UPDATE щелкнуть по столбцу4 сетки.обновленное значение в сетке не показано на контроллере java весны
Пожалуйста найти скрипку: http://jsfiddle.net/740L0y43/7/
расширенный код сетки:
require(['dojo/_base/lang', 'dojox/grid/EnhancedGrid', 'dojo/data/ItemFileWriteStore', 'dijit/form/Button', 'dojo/dom', 'dojo/aspect', 'dojo/domReady!'],
function (lang, EnhancedGrid, ItemFileWriteStore, Button, dom, aspect) {
/*set up data store*/
var data = {
identifier: "id",
items: [{
id : 1,
col2 : "aa",
col3 : "bb",
col4 : "cC"
}]
};
var store = new ItemFileWriteStore({
data: data
});
/*set up layout*/
var layout = [
[{
'name': 'Column 1',singleClickEdit:'true', editable:'true',
'field': 'id',
'width': '100px'
}, {
'name': 'Column 2',singleClickEdit:'true', editable:'true',
'field': 'col2',
'width': '100px'
}, {
'name': 'Column 3',singleClickEdit:'true', editable:'true',
'field': 'col3',
'width': '200px'
}, {
'name': 'Column 4',formatter: updateDetails,
'field': 'col4',
'width': '150px'
}]
];
/*create a new grid*/
var grid = new EnhancedGrid({
id: 'grid',
store: store,
structure: layout,
sortInfo: -1,
});
/*append the new grid to the div*/
grid.placeAt("gridDiv");
/*Call startup() to render the grid*/
grid.startup();
aspect.after(grid, 'renderRow', grid.sort);
var id = 2;
var button = new Button({
onClick: function() {
console.log(arguments);
store.newItem({
id: id,
col2: "col2-" + id,
col3: "col3-" + id,
col4: "col4-" + id
});
id++;
}
}, "addRow");
});
var updateDetails = function(value, rowIndex) {
var col2 = this.grid.getItem(rowIndex).col2;
alert("col2 updated value : " + col2);
return "<a href=\"<%=request.getContextPath()%>/updateInfo.htm?col2="+col2 +"\">" + "UPDATE";
};
пружинный код контроллера:
@RequestMapping(value = "/updateInfo", method = RequestMethod.GET)
public ModelAndView updateInfo(HttpServletRequest request,
HttpServletResponse response, @ModelAttribute MyDTO myDto,
@RequestParam("col2") String col2, @RequestParam("col2") String col2){
System.out.println("col2 value: " + col2);
System.out.println("col3 value: " + col3);
//when i type some value in COlumn2/Column3 of enhanced grid and column is still in edit mode then on click of UPDATE , new value is not passed to spring controller, its passing the old value.
...
...
//logic to save in DB
}
/updateInfo.htm?col2dummy="+col2 + "\"> где col2 обновил значение, можно увидеть в этой скрипте http: // jsfiddle .net/740L0y43/7 /. Когда col2 обновляется и нажимает на ссылку UPDATE, новое обновленное значение отображается в поле предупреждения. И я сделал так, как вы предлагали, я не могу использовать ajax в этом методе, так как при загрузке сетки мне нужно показать значок обновления, и это делается с использованием ссылки href, за которой следует изображение, как показано на скрипке. Пожалуйста, предложите какие-либо другие возможные способы достижения этого. @dubhov – user3684675
Правильно, поэтому у вас есть javscript, предупреждающий вас о новом значении. Но важная часть здесь - это то, что делает ваш тег , правильно? Так что атрибут href никогда не обновляется ни на что. Здесь нет привязки данных или чего-то интересного; значение href тега содержит значение col2, когда таблица _rendered_. Это означает, что на странице есть то, что находится на странице, пока вы ее не измените. – wholevinski
Кроме того, в ответ на «Я не могу использовать ajax»: вы определенно можете. Вы можете сделать ajax выполнить запрос GET так же, как это делает ваш , и он даст вам тот же результат, что и щелчок по ссылке UPDATE. Ваши 2 варианта (IMO ... может быть больше): 1. Используйте ajax для выполнения запроса на получение с тем же URL-адресом, что и ссылки UPDATE, или 2. Повторно отрисуйте UPDATE , чтобы указать на новое значение (которое я делаю Я рекомендую, и я чувствую, что это слишком сложно. Я с удовольствием помогу с вариантом 1, если у вас возникнут проблемы с ним. – wholevinski