0

viewModel への変更後に UI を更新しようとしていますが、うまくいきません。 http://jsfiddle.net/rdZjb/1/

  viewModel = {
        firstName : ko.observable("adrian") 
    }

    $("#button1").click(
        function ()
        {
            viewModel.firstName = "Paul";
            alert(viewModel.firstName);
        }
        )

    ko.applyBindings(viewModel);
4

2 に答える 2

4

あなたはobservables間違った方法で働いています。それぞれobservableが関数であるため、値を設定または取得するときに使用する必要があります()

        viewModel.firstName("Paul");
        alert(viewModel.firstName());

また、jQuery のクリック イベントを使用することもお勧めできません。代わりにノックアウトclickバインディングを使用します。

<input type="button" value ="click" id="button1" data-bind="click: OnClick"/>

viewModel = {
    firstName: ko.observable("adrian"),
    OnClick: function() {
        this.firstName("Paul");
        alert(this.firstName());
    }
};

ここにフィドルが働いています:http://jsfiddle.net/vyshniakov/rdZjb/2/

于 2012-10-22T16:05:09.417 に答える
2

オブザーバブルを (初期化後に) Javascript で変更するには、次のような関数として呼び出す必要があります。

viewModel.firstName("Paul");
于 2012-10-22T16:05:19.290 に答える