已淘汰的复选框列表的已检查属性

时间:2016-07-26 14:14:00

标签: javascript checkbox knockout.js data-binding checked

enter image description here我有两个数组应该显示并显示为复选框列表。 主要想法是单击第一个列表的元素,将元素添加到第二个列表。 html代码看起来像这样

   <div class="tab-pane" id="ColumnHeading">
             <div class="row">
                 <div class="form-group span4">
                     <h4>Column Headings</h4>
                     <ul class="icons-ul" data-bind="foreach: staticItem.ColumnHeadingList.ColumnHeadingListItem" >
                         <li>
                             <div class="span2">
                                 <input class="selectedHeading" type="checkbox" data-bind=" click: $parent.myCheck, checkedInArray: $parent.Params.Item.ColumnHeadingList.ColumnHeadingListItem, attr: { value: Value }" />
                                 <span data-bind="text: Name"></span>
                             </div>
                         </li>
                     </ul>
                 </div>
                 <div class="form-group span4" style="margin-left: -90px; margin-top: 15px">
                     <div class="icons-ul" data-bind="foreach: Params.Item.ColumnHeadingList.ColumnHeadingListItem" >
                             <div class="span4">
                                 <input  type="checkbox" data-bind="customcheck: IntOnly" />

                             </div>
                     </div>
                 </div>
                 <div class="span6">
                     <p class="validationMessage" data-bind="validationMessage: Params.Item.ColumnHeadingList.ColumnHeadingListItem"></p>
                 </div>
             </div>

价值&#34; IntOnly&#34;是两个复选框列表中每个对象的属性。

我在第一个复选框列表中点击事件的功能如下所示

  self.myCheck = (function(e) {
                    var index = self.staticItem.ColumnHeadingList.ColumnHeadingListItem().map(function(e) { return e.Value(); }).indexOf(this.Value());

                    if (self.staticItem.ColumnHeadingList.ColumnHeadingListItem()[index].IntOnly() !== "Y") {
                        self.staticItem.ColumnHeadingList.ColumnHeadingListItem()[index].IntOnly("Y");
                        var o = self.staticItem.ColumnHeadingList.ColumnHeadingListItem()[index];
                        var flag = false;
                        for (i = 0; i < self.Params.Item.ColumnHeadingList.ColumnHeadingListItem().length; i++) {

                            if (this.Value() == self.Params.Item.ColumnHeadingList.ColumnHeadingListItem()[i].Value()) {
                                flag = true;
                            }
                        }
                        if (flag == false || self.Params.Item.ColumnHeadingList.ColumnHeadingListItem().length == 0) {
                            var newObject = jQuery.extend(true, {}, this);
                            self.Params.Item.ColumnHeadingList.ColumnHeadingListItem.push(newObject);

                        }
                    } else { //checked==true

                        self.staticItem.ColumnHeadingList.ColumnHeadingListItem()[index].IntOnly("N");
                        for (i = 0; i < self.Params.Item.ColumnHeadingList.ColumnHeadingListItem().length; i++) {

                            if (this.Value() == self.Params.Item.ColumnHeadingList.ColumnHeadingListItem()[i].Value()) {
                                self.Params.Item.ColumnHeadingList.ColumnHeadingListItem.splice(i, 1);
                            }
                        }
                    }
                    return true;

                });

代码工作正常,可以将元素添加到第二个列表并将值保存在IntOnly cuz customcheck函数中,检查IntOnly的值是否为&#39; Y&#39;选择复选框但我可以保存第一个列表的属性,即使获取该值并在表单发送到服务器并选中它们以进行编辑后选中这些复选框。

有些人建议,对不起语法。

1 个答案:

答案 0 :(得分:1)

我做了一个非常简单的例子,列出了另一个复选框。我认为你想要的关键是subscribe到checked变量,这样你就可以在值改变时(当它被选中或取消选中时)采取行动。

我的函数只检查值是true还是false,push es或remove是第二个列表中的列表元素。方便的是,我可以为两个列表使用相同的数据项;我只是将复选框绑定到另一个成员变量,因此第二个列表复选框独立于第一个列表中的相应复选框。

let vm = {
  list1: [1, 2, 3].map((n) => {
    const result = {
      label: `op${n}`,
      intOnly: ko.observable(false),
      anotherCheckValue: ko.observable(false)
    };

    result.intOnly.subscribe((isChecked) => {
      if (isChecked) {
        vm.list2.push(result);
      } else {
        vm.list2.remove(result);
      }
    });

    return result;
  }),
  list2: ko.observableArray()
};

ko.applyBindings(vm);
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script>
<div data-bind="foreach:list1">
  <label>
    <input type="checkbox" data-bind="checked: intOnly" />
    <span data-bind="text: label"></span>
  </label>
</div>
<div data-bind="foreach:list2">
  <label>
    <input type="checkbox" data-bind="checked: anotherCheckValue" />
    <span data-bind="text: label"></span>
  </label>
</div>