I build a simple cart.
First I have an array of items called vouchers - like:
"[{"id":"108","name":"Gourmet Tasting Menu for Two","price":"85.00","photo":"1102/KtOdtlg.jpg"},{"id":"109","name":"Sampler Menu for Two","price":"60.00","photo":"1102/YrLaHlg.jpg"},{"id":"127","name":"£100 Gift Voucher","price":"100.00","photo":"1102/qexxflg.jpg"}]"
and cart = [];
Now I have a function to add items to CART array:
//with this function based on ID I find object into vouchers array and push that into CART array
    function addItemToCart (id) {
        qty = $('#qty').val();
        var data = $.grep(vouchers, function(e){ return e.id == id; });
        data = data[0];
        data.voucher_id = id;
        data.to = $('#to').val();
        data.from = $('#from').val();
        data.isGift = 0;
        data.recipient_email = $('#recipient_email').val();
        if (data.recipient_email != '') {
            data.isGift = 1;
        }
        data.message = $('#message').val();
        data.qty = qty;
        data.total = qty*data.price;
        cart.push(data);
    };
and this works good and add Item into the CART but also change values in vouchers array. Why? WHy data.total is added into the object in vouchers array...
I need vouchers array to be with unchangeable values... Why when I change values this way it binds values into vouchers array.
 
    