Не удается получить и установить значение в выпадающем списке внутри панели сетки ext.net
У меня много проблем с выпадающими списками внутри панели сетки ext.net. Мне нужно установить значение по умолчанию, когда я вставляю новую запись. На самом деле я делаю это:
Код Javascript:
function insertRecordTestesVerif(grid) {
var store = grid.store,
row = store.indexOf(store.insert(0, {
Hora: new Date(),
n_saco: 0,
solda_status : "NA",
peso: 0,
peso_status: "NA",
detector_metais: "NA",
impressora: "NA",
cola: "NA",
qualidade: "NA",
})[0]);
Ext.defer(function () {
grid.editingPlugin.startEditByPosition({ row: row, column: 0 });
}, 100);
}
И мои комбо-боксы такие:
<ext:ComponentColumn
runat="server"
Text="Status"
DataIndex="peso_status"
Flex="1">
<Component>
<ext:ComboBox runat="server" Editable="false">
<Items>
<ext:ListItem Text="NA" Value="NA" />
<ext:ListItem Text="OK" Value="OK" />
<ext:ListItem Text="NC" Value="NC" />
</Items>
</ext:ComboBox>
</Component>
</ext:ComponentColumn>
Значения, которые я установил, не отображаются по умолчанию в выпадающих списках, и когда я синхронизирую сетку, отправляемое значение всегда равно "NA".
Любая помощь приветствуется. Спасибо вам всем.
1 ответ
Решение
Добавьте прослушиватель Bind в ComponentColumn. Посмотрите на этот пример:
<%@ Page Language="C#" %>
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<ext:ResourceManager ID="ResourceManager1" runat="server" ScriptMode="Debug" />
<script runat="server">
protected void Page_Load(object sender, EventArgs e)
{
if (!X.IsAjaxRequest)
{
this.Store1.DataSource = this.Data;
this.Store1.DataBind();
}
}
private object[] Data
{
get
{
return new object[]
{
new object[] { 1, "OK"},
new object[] { 2, "NC"},
new object[] { 3, "NA"},
new object[] { 4, "NC"},
new object[] { 5, "OK"},
new object[] { 6, "NC"}
};
}
}
</script>
<ext:GridPanel ID="Grid1" runat="server" Width="400" Height="300">
<Store>
<ext:Store ID="Store1" runat="server">
<Model>
<ext:Model runat="server" IDProperty="id">
<Fields>
<ext:ModelField Name="id" Type="Int" />
<ext:ModelField Name="peso_status" />
</Fields>
</ext:Model>
</Model>
<Reader>
<ext:ArrayReader IDProperty="id" />
</Reader>
</ext:Store>
</Store>
<ColumnModel runat="server">
<Columns>
<ext:Column runat="server" DataIndex="id" />
<ext:ComponentColumn runat="server" Text="Status" DataIndex="peso_status" Flex="1">
<Component>
<ext:ComboBox runat="server" Editable="false">
<Items>
<ext:ListItem Text="NA" Value="NA" />
<ext:ListItem Text="OK" Value="OK" />
<ext:ListItem Text="NC" Value="NC" />
</Items>
</ext:ComboBox>
</Component>
<Listeners>
<Bind Handler="
cmp.setValue(record.get('peso_status'));
if(!cmp.keyValue){
cmp.keyValue = record.get('id');
cmp.on('change',function(item,newValue,oldValue){
var rec = #{Store1}.getAt(#{Store1}.findExact('id',item.keyValue));
Ext.defer(function() {
rec.set('peso_status', newValue);
#{Store1}.sync();
}, 10);
});
}
" />
</Listeners>
</ext:ComponentColumn>
</Columns>
</ColumnModel>
</ext:GridPanel>
</body>
</html>