Заменить старое значение новым значением в сетке данных - PullRequest
0 голосов
/ 13 декабря 2011

Моя таблица данных состоит из 3 столбцов. Если пользователь отредактирует первую ячейку в столбце «Кол-во» (например, от 1 до 2), то первая ячейка столбца «Цена» увеличится вдвое (например, от 5 до 10). Как мне это сделать?

    Qty | Description | Price

    1   |   apple     |  5
    1   |   cherry    |  2
    1   |   orange    |  4 

Вот код, который я использую:

var dp:DataProvider = new DataProvider();
var tempValue:Number;

var col1:DataGridColumn = new DataGridColumn("Qty");
grid.addColumn(col1);
col1.dataField = "Qty";
col1.editable = true;
var col2:DataGridColumn = new DataGridColumn("Denumire");
grid.addColumn(col2);
col2.dataField = "Denumire";
col2.editable = false;
var col3:DataGridColumn = new DataGridColumn("Gramaj");
grid.addColumn(col3);
col3.dataField = "Gramaj";
col3.editable = false;
var col4:DataGridColumn = new DataGridColumn("Pret");
grid.addColumn(col4);
col4.dataField = "Pret";
col4.editable = false;

grid.dataProvider = dp;
grid.editable = true;

var loader:URLLoader = new URLLoader(new URLRequest("meniu.xml"));
loader.addEventListener(Event.COMPLETE, onComplete);
function onComplete(e:Event):void
{
    var xml:XML = new XML(loader.data);
    var itemList:XMLList = xml..item;
    var len:int = itemList.length();
    for (var i:int=0; i < len; i++)
    {
        dp.addItem({Qty:"1",
         Denumire:itemList[i].denumire,
         Gramaj:itemList[i].gramaj,
         Pret:itemList[i].pret});
    }
    grid.addEventListener(DataGridEvent.ITEM_EDIT_END, itemEditPreEnd, false, 100);
    grid.addEventListener(DataGridEvent.ITEM_EDIT_END, itemEditPostEnd, false, -100);

    calculateTotal();
}

function itemEditPreEnd(e:DataGridEvent):void
{
    var myGrid:DataGrid = e.target as DataGrid;
    var field:String = e.dataField;
    var row:Number = Number(e.rowIndex);
    if (myGrid != null)
    {
        if (field == "Qty")
        {
            tempValue = myGrid.dataProvider.getItemAt(row)[field];
        }
    }
}

function itemEditPostEnd(e:DataGridEvent):void
{
    var myGrid:DataGrid = e.target as DataGrid;
    var field:String = e.dataField;
    var row:Number = Number(e.rowIndex);
    if (myGrid != null)
    {
        if (field == "Qty")
        {
            var newValue:Number = myGrid.dataProvider.getItemAt(row)[field];
            var prevValue = myGrid.dataProvider.getItemAt(row).Pret;
            if (newValue != tempValue)
            {
                var replacedValue:Number =  prevValue * newValue;
                //trace(replacedValue)
                //code will go here
                calculateTotal();
            }
        }
    }
}

function calculateTotal():void
{
    var result:Number = 0;
    var len:Number = dp.length;
    for (var i:Number = 0; i < len; i++)
    {
        result +=  Number(dp.getItemAt(i).Pret);
    }
    total.text = result.toString();

1 Ответ

0 голосов
/ 14 декабря 2011

Где-то вам нужно отследить, какова цена за единицу. Может быть, добавить еще один (редактируемый?) Столбец для этого. Каждый раз, когда вы меняете количество, оно должно умножать количество на цену за единицу и переводить это значение в цену. Затем всякий раз, когда изменяется количество, он также вычисляет сумму для этого элемента на основе цены за единицу, а затем обновляет сумму для всех элементов.

Я не знаком с классом DataGrid, который вы используете, но я бы изменил вашу функцию, чтобы получить значение Qty и цену за единицу.

Там, где находится ваша строка // code goes here, вам нужно умножить Qty * PricePerUnit и присвоить это значение PriceTotal для той же строки.

Если вы хотите сделать это хакерским, задом наперед, чтобы избежать добавления столбца Цена за единицу ...

price = (price / prevValue) * newValue;

... даст вам номер, если цена будет правильной с самого начала.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...