Ext.data.JsonStore как store в форме
Добрый день,есть следующий код:
{ xtype: 'combo', fieldLabel: 'Отдел', name : 'otdel', store: new Ext.create('Ext.data.JsonStore', { proxy: { type: 'ajax', url: 'php/otdel.php', reader: { type: 'json', root: 'contatos', successProperty: 'success', } }, idIndex: 0, autoload: true, fields: [ {name: 'id'}, {name: 'otdel'} ] }), triggerAction: 'all', displayField: 'otdel', valueField: 'id' } Есть проблема,что когда я открываю форму,и изменяю другие данные,то в базу от этого поля пытается записатся его имя а не его id,а в БД данный столбец integer... В общем как сделать что бы он сбрасывался всегда на id,даже если ты не изменяешь данное поля? |
Если честно не очень понятно в чем проблема. Написано очень сумбурно. Лучше будет, если вы приведете код в песочнице, чтобы там можно разобраться.
Цитата:
Цитата:
Цитата:
|
Смотри:
Есть таблица: ![]() Добавляю отдел: ![]() В итоге такой запрос: ![]() И получаю: ![]() Что отдел есть,а должности нету. А если должность выбрать заного,то получу то что нужно,в запросе вместо имени "тестовая должность" будет 1 |
Есть мысли?
|
Какая версия Ext (не ясно откуда взялась опция idIndex: 0, но в пятой версии такой опции нет)?
Также приведите полный код, формирующий форму. |
отдел и должность являются связанными списками? Значение должности выбирается из списка вручную?
|
Ext 4 версии
Списки не связаны. Из списка который по пост забросу берется,выбирает вручную при добавлении,но после сохранения,вновь зайдя в редактирования и изменении любогог другого поля,вместе id отдела или должности посылается имя,но в БД не придёт,т.к. поля int. А вот если при редактировании выбрать заново отдел или должность,то придёт id. |
initComponent: function() { this.items = [ { xtype: 'form', padding: '5 5 0 5', border: false, style: 'background-color: #fff;', fieldDefaults: { anchor: '100%', labelAlign: 'left', allowBlank: false, combineErrors: true, msgTarget: 'side' }, items: { xtype:'tabpanel', activeTab: 0, defaults:{ bodyPadding: 10, layout: 'anchor' }, items:[{ title:'Общая информация', defaultType: 'textfield', defaults: { anchor: '100%' }, items: [ { xtype: 'textfield', name : 'id', fieldLabel: 'id', hidden:true }, { ... }, { xtype: 'combo', fieldLabel: 'Отдел', name : 'otdel', store: Ext.create('Ext.data.JsonStore', { proxy: { type: 'ajax', url: 'php/otdel.php', reader: { type: 'json', root: 'contatos', successProperty: 'success', } }, idIndex: 0, autoload: true, fields: [ {name: 'id'}, {name: 'otdel'} ] }), triggerAction: 'all', displayField: 'otdel', valueField: 'id', }, { xtype: 'combo', fieldLabel: 'Должность', name : 'rol', store: new Ext.create('Ext.data.JsonStore', { proxy: { type: 'ajax', url: 'php/rol.php', reader: { type: 'json', root: 'contatos', successProperty: 'success', totalProperty: 'totalCount' } }, idIndex: 0, autoload: true, fields: [ {name: 'id'}, {name: 'rol'} ] }), triggerAction: 'all', displayField: 'rol', valueField: 'id', {...}, ]}] }} ]; |
Конкретнее пожалуйста, какая версия? Четвертых версий очень много...
|
Форма пассивная. Приведите код, который данные забирает из формы и посылает на сервер.
|
Часовой пояс GMT +3, время: 17:10. |