将值分配给由字符串名称动态确定的knockout observable

时间:2012-01-18 04:08:36

标签: knockout.js variable-assignment observable

我有两个问题:

我正在使用淘汰赛(我是KO noob sry)并且我想在点击事件中为特定的淘汰赛观察分配一个值,但这应该仅在点击事件本身(和值I)上确定将传递给data-bind = click)...可以这样做吗...我可以获取基于其名称(字符串值)的敲除可观察变量,而不必知道我将成为哪个可观察者事先分配一个值?

并且,其次不那么重要,如果存在这样的函数ko.ObservableByName(stringName),就可以以某种方式使用它并在页面加载时分配多个选择项的预选择...以及如何请?

我尝试过这样做...我使用了 data-bind =“click:loadData.bind($ data,' param1 ',' param2 ')“然后我就可以通过在我的knockout viewmodel中构建一个事件处理程序来获取那些 param1 param2 字符串值沿着这条线的东西:

self.loadData = function (src, dest) {
    //dest is 'param1', src is 'param2', both are stings
    if (src == 'param1')
       self.p1observable($('#' + dest).val());
    else
       self.p2observable($('#' + dest).val());
}

我最大的问题是我必须用已经指定的p1 / p2 observable构造函数并在其中进行硬编码,但实际上我想让param1和param2按名称用作名称或引用我可以随意传递的一些可观察对象(除了要分配的值,或者更好的另一个可观察对象,我想将值复制到第一个),因此我可以分配传入的值在click函数中直接调用我选择的一个observable(并没有大量这样的小函数)......

也许我会以错误的方式去做?也许我根本不应该传递字符串值...也许我应该尝试传入一个可观察对象,但是如何在数据绑定中做到这一点,你只是编写myViewModel.myObservable或类似的东西吗?

1 个答案:

答案 0 :(得分:15)

如果您有父对象,则可以使用以下语法访问observable:

viewModel[observableName]

并将值设置为:

viewModel[observableName](newValue)

下面是一个示例,您可以从下拉列表中选择属性名称,然后相应地设置值,另一个按钮直接绑定到设置可观察/值的值:http://jsfiddle.net/rniemeyer/CTnUQ/