【问题标题】:Bind datepicker on dynamic textbox with knockout js binding使用淘汰赛js绑定在动态文本框上绑定日期选择器
【发布时间】:2017-12-17 20:35:04
【问题描述】:

您好,我在我的内部项目中使用 ASP.NET MVC 的淘汰赛。

我有一个表单页面(交易页面),其中没有。网格中的客户端数量并基于单击我在敲除中创建 arrayobject 并相应地绑定表行。

在表格中,我在第一列有一个字段日期,并且希望在焦点位于该列时打开日期选择器。

但是我现在面临的问题是,每当我更改客户端选择时,它都会更新表格事务列表,并且 datepicker 不会出现在我想要的文本框中。

HTML 中的敲除绑定:

<table id="idTblTranItems" class="table table-striped table-bordered table-hover table-green dataTable" aria-describedby="dtAllClients_info">
                                    <thead>
                                        <tr class="btn-primary">
                                            <th style="text-align:center">Date<br /> (MM/dd/YYYY)</th>
                                            <th style="text-align:center">Column2</th>
                                            <th style="text-align:center">Column3</th>
                                            <th colspan="2" style="text-align:center">Column4($)</th>
                                            <th style="text-align:center">Tax Column5</th>
                                            <th style="text-align:center">Tax Column6($)</th>
                                            <th style="text-align:center">Net Column7($)</th>
                                            <th style="text-align:center">Notes</th>
                                            <th style="text-align:center">More</th>
                                            <th style="text-align:center">Delete</th>
                                        </tr>
                                    </thead>
                                    <tbody data-bind="foreach: TransactionList" id="tbodyTransactionsNew">
                                        <tr>
                                            <td>
                                                <input class="form-control TransactionDate" type="text" data-bind="value: TransactionDate}" />
                                            </td>
                                            <td>
                                                <input type="text" class="form-control" data-bind="value: column2" />
</td>
                                            <td>
                                                <input type="text" class="form-control" data-bind="value: column3" />
                                            </td>
                                            <td>
                                                <input type="text" class="form-control" data-bind="value: column4" />

                                            </td>
                                            <td style="width:40px; border-left:none">
                                               <input type="text" class="form-control" data-bind="value: column5" />
                                            </td>
                                            <td>
                                                <input type="text" class="form-control" data-bind="value: column6" />
                                            </td>
                                            <td>
                                                <input type="text" class="form-control" data-bind="value: column7" />
                                            </td>
                                            <td>
                                                <input type="text" class="form-control NetAmount" data-bind="value: column8" />
                                            </td>
                                            <td>
                                                <textarea style="height:34px" class="form-control" data-bind="value: column9"></textarea>
                                            </td>
                                            <td>
                                                <textarea style="height:34px" class="form-control" data-bind="value: column10"></textarea>
                                            </td>
                                            <td>
                                                <textarea style="height:34px" class="form-control" data-bind="value: column11"></textarea>
                                            </td>
                                        </tr>
                                </table>

我的 js:

function TransactionVM(vm) {
            var self = this;
            self.TransactionList = ko.observableArray([]);
            self.Transactionclone = ko.observable();
            self.AccountId = ko.observable();

if (vm.TransList().length > 0) { for (var i = 0; i

            $('.TransactionDate').datepicker({
                    autoclose: true,
                    format: 'mm/dd/yyyy',
                    startDate: date
                });
}

ko.applyBindings(new TransactionVM(ko.mapping.fromJS(transactionlist)));

你可以看到我有 TransactionDate 类绑定 datepicker 但是当我点击文本框时 datepicker 没有出现,在上面的 datepicker 初始化中我有 for 循环,我实际上创建了 TransactionObj viewmodel 的新对象。

不知道该怎么做,这对我来说是个大问题我也尝试过this article,但没有帮助.

创建jsfiddle的请求很谦虚,所以我很容易理解,因为我刚刚开始淘汰js,谢谢。

【问题讨论】:

    标签: javascript jquery knockout.js datepicker knockout-mapping-plugin


    【解决方案1】:

    您可以为日期选择器创建一个custom ko binding,当控件被数据绑定时将被调用。

    例如

    ko.bindingHandlers.datePicker = {
      init: function(element, valueAccessor) {
        var $element = $(element);
        $element
          .datepicker({
            autoclose: true,
            format: 'mm/dd/yyyy'
          });
      },
      update: function(element, valueAccessor) {
        var value = ko.utils.unwrapObservable(valueAccessor());
        var $element = $(element);
        $element.datepicker("setDate", value);
      }
    };
    
    function TransactionVM(vm) {
      var self = this;
      self.TransactionList = ko.observableArray([]);
    
      self.loadList = function(transactions) {
        self.TransactionList([]);
        transactions.forEach(function(transaction) {
          self.TransactionList.push(transaction);
        });
      };
    }
    
    var vm = new TransactionVM();
    ko.applyBindings(vm);
    
    var iteration = 1;
    function addData() {
      var transactions = [];
      for (var i = 0; i < 10; i++) {
        transactions.push({
          TransactionDate: new Date(),
          column2: "testing round " + iteration + " item " + i
        });
      }
      vm.loadList(transactions);
      iteration++;
    }
    
    $("#add").click(addData);
    <link href="https://code.jquery.com/ui/1.12.0/themes/smoothness/jquery-ui.css" rel="stylesheet" />
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.4.2/knockout-min.js"></script>
    <script src="https://code.jquery.com/ui/1.12.0/jquery-ui.min.js"></script>
    
    <table id="idTblTranItems" class="table table-striped table-bordered table-hover table-green dataTable" aria-describedby="dtAllClients_info">
      <thead>
        <tr class="btn-primary">
          <th style="text-align:center">Date<br /> (MM/dd/YYYY)</th>
          <th style="text-align:center">Column2</th>
        </tr>
      </thead>
      <tbody data-bind="foreach: TransactionList" id="tbodyTransactionsNew">
        <tr>
          <td>
            <input class="form-control TransactionDate" type="text" data-bind="datePicker: TransactionDate" />
          </td>
          <td>
            <input type="text" class="form-control" data-bind="value: column2" />
          </td>
        </tr>
    </table>
    <button id="add">Add</button>

    【讨论】:

    • 感谢您的回答,但它不起作用先生,我实际上调用了 ko.applyBindings(new TransactionVM());每当我获取新的数据列表并基于该数据时,我的表将通过每次调用 applybindings 来根据列表数据相应地生成列。每次调用绑定都可以吗?
    • 你应该调用一次applybindings。当你有一个新的交易列表时,你可以更新 vm 中的列表。检查更新的代码。
    • 感谢它适用于成功添加的新对象,但如何清除 arrayobject 并基于此清除 html?
    • 可以清除observable数组重新加载。我已更新以显示此内容。
    • 不,我的意思是如果我找到任何现有的对象列表并且如果它是 0,那么我想清除 HTML 并在清除数组对象时。 jsfiddle.net/MVDotNet/s8xhuk1k 我在按钮上创建的小提琴我想在单击按钮时通过创建新的对象数组来清除整个 html。你能更新一下吗?
    猜你喜欢
    • 1970-01-01
    • 2015-08-31
    • 2013-05-04
    • 2015-09-22
    • 1970-01-01
    • 2021-04-28
    • 2013-08-14
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多