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, время: 14:54. |