javascript - 基于下拉选择的 knockout 检查绑定(bind)

标签 javascript knockout.js

假设我有以下绑定(bind):

<p>blah blah<input type="checkbox" data-bind="checked: shouldShow" /></p>
 <div data-bind="visible: shouldShow ">...</div>    
 <select data-bind="options: availableCountries,
                       optionsText: 'countryName',
                       value: selectedCountry,
                       optionsCaption: 'Choose...'">
 </select>

我想做的是:

  1. 当选择某个国家/地区时,应自动选中该复选框,并应显示 div 部分。
  2. 当用户选择不同的国家/地区时,不会自动选中该复选框,但如果用户手动选中该复选框,则应显示该 div。

我有以下内容

 shouldShow = ko.computed(function() {                
                if(selectedCountry == 'UK') 
                    return true;
                else
                    return false;
             }, this);

现在这适用于 1,但如果用户选择不同的国家/地区,并且当用户选择复选框时,什么也不会发生。我该如何解决这个问题?

最佳答案

如果我正确理解了要求,手动订阅可能很适合这种情况。

您可以将 shouldShow 设为可观察对象,然后针对 selectedCountry 创建手动订阅以确定是否应该更新 shouldShow。这使得 shouldShow 能够独立于国家/地区维护一个值。

this.shouldShow = ko.observable();

this.selectedCountry = ko.observable();

this.selectedCountry.subscribe(function(newValue) {
    this.shouldShow(newValue === "UK");
}, this);

当国家/地区更改时,复选框将会更新。但是,如果用户选中该框,它仍会将其设置为 true。

关于javascript - 基于下拉选择的 knockout 检查绑定(bind),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22184917/

相关文章:

javascript - 通过预定义属性名称数组获取对象属性

javascript - createElement 函数不适用于 MAC Safari

javascript - 使用 knockoutjs 将多个 css 类与 <li> 元素绑定(bind)

javascript - 确定数值是否在非特定整数的某个范围内

javascript - 如何在客户端 Javascript 中调用 Node/Express API key (.env)?

javascript - 在 Javascript 中克隆元素 [div] [script]

asp.net-mvc - asp.net mvc5 web api 2,如何通过 Razor 语法获取我的 web api url?

javascript - onclick 切换开关

javascript - RequireJS:如何向路径添加前缀

javascript - 如何从 .computed() 可观察对象中使用 knockout 的 $parent/$root 伪变量?