0

タイトルが示すように、オブザーバブルから別のオブザーバブルに値を追加しようとしています。奇妙な結果が得られており、正しい方法で行っているかどうか疑問に思っています。

一番下のフィドル

HTML:

<div id="wrapper">
    <ul class="empiriHelp" data-bind="foreach: empiriHelp"><li data-bind="text: title"></li></ul>
        <ul class="empiricount" data-bind="foreach: $data.empiriLines">
            <li data-bind='event: {mouseover: $root.empiriMouseOver, mouseleave: $root.empiriMouseLeave}'>
                <input class="empiri_amount" data-bind="value: $data.amount"/>
                <select data-bind="options: $root.measurements, value: $data.unit = $root.selectedUnit"></select>
                <input class="empiri_ingredient" type="text" data-bind="value: $data.ingredient, returnKey: $root.empiriAddLine.bind($data, $index())" />
                <div class="empiri_fader">
                    <div class="empiri_add" data-bind="click: $root.empiriAddLine.bind($data, $index())"></div>
                    <div class="empiri_delete" data-bind="click: $root.empiriRemoveLine.bind($data, $index())"></div>
                </div>
            </li>
        </ul>
    </ul>
</div>

Javascript:

$(document).ready(function()
{
    var viewModel = function(){
    var self = this;

    self.selectedUnit = ko.observable();

    self.selectedUnit.subscribe(function(value) {
        console.log(value);
    });

    self.measurements = ko.observableArray([
                                            ko.observable('Kg'),
                                            ko.observable('g'),
                                            ko.observable('L'),
                                            ko.observable('dl'),
                                            ko.observable('cl'),
                                            ko.observable('tbps'),
                                            ko.observable('tsp'),
                                            ko.observable('cl')
                                            ]);

    self.empiriHelp = [{title: "amount"}, {title: "unit"}, {title: "ingredient"}];
    self.empiriLines = ko.observableArray([{ amount: ko.observable(''), unit: ko.observable(self.measurements[0]),  ingredient: ko.observable('') }]);


    self.empiriAddLine = function(index){
        self.empiriLines.splice(index+1,0,{ amount: ko.observable(''), unit: ko.observable(self.measurements[0]), ingredient: ko.observable('') });
    }

    self.empiriRemoveLine = function(index){
        if(self.empiriLines().length!=1){
            self.empiriLines.splice(index,1);
        }
    }

    self.empiriMouseOver = function(data, event){
        $(event.currentTarget).find(".empiri_fader").stop(true, true).fadeIn(200);
    }

    self.empiriMouseLeave = function(data, event){
        $(event.currentTarget).find(".empiri_fader").stop(true, true).fadeOut(200);
    }
}

ko.applyBindings(new viewModel);

問題は、選択値が変更されると、理解できないすべてのエンピリラインの値が変更されることです... $data は状況依存であり、foreach から現在のループ項目のみを参照するべきではありませんか? 私の推測では、オブザーバブルを間違った方法でバインドしていると思います。私はこれに対してあまりにも長い間頭を悩ませてきました。私の脳はどろどろです。

私は今日、頭がよくありません。

ここにフィドルがあります: http://jsfiddle.net/Y9Caw/

4

1 に答える 1

1

実際には、を削除するだけで、あなたが望むことができる= $root.selectedUnit ようです:

value: $data.unit = $root.selectedUnit

http://jsfiddle.net/bman654/Y9Caw/2/

于 2013-06-18T21:57:13.410 に答える