首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基因敲除及其绑定

基因敲除及其绑定
EN

Stack Overflow用户
提问于 2014-04-25 18:52:27
回答 1查看 42关注 0票数 0

我有两个复选框,我希望这两个复选框的值相互依赖。当我选中第一个复选框时,第二个复选框被取消选中,当我取消选中第一个复选框时,第二个复选框被选中,反之亦然。我可以用jQuery:example做到这一点。

代码语言:javascript
复制
$('input').on('change', 
     function() {         
         var anotherId = $(this).attr('id') == 'first' ? 'second' : 'first';        
         if($(this).is(':checked'))
             $('[id="' + anotherId + '"]').removeAttr('checked');
         else 
             $('[id="' + anotherId + '"]').attr('checked', 'true');
     });

但我认为这不是最好的方式。我知道我可以用knockout.js做到这一点,但我不知道怎么做到。你能帮我解决这个问题吗?

EN

回答 1

Stack Overflow用户

发布于 2014-04-25 19:21:05

您是否考虑过使用单选按钮?;-)

你没有给出太多的实际背景;有很多方法可以解决这个问题,哪种方法最好取决于具体情况。无论如何,这里有一种方法可以做到这一点。

为该值创建“私有”可观测对象,并让“公共”计算可观测对象在write位内具有一些额外的逻辑(类似于C#中具有复杂设置器的属性):

代码语言:javascript
复制
var ViewModel = function() {
    var self = this;

    var _first = ko.observable(true);
    var _second = ko.observable(false);

    self.first = ko.computed({
        read: _first,
        write: function(val) {
            _first(val);
            _second(!val);
        }});

    self.second = ko.computed({
        read: _second,
        write: function(val) {
            _second(val);
            _first(!val);
        }});
};

ko.applyBindings(new ViewModel());

查看this fiddle中的工作演示。同样,请注意复选框现在的行为就像它们是单选按钮一样……

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23291021

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档