【问题标题】:Knockout title not updating with observable淘汰赛标题不更新可观察
【发布时间】:2021-09-19 22:50:13
【问题描述】:

我有一个带有函数的淘汰赛绑定,该函数应该根据页面是否处于编辑模式来更新标题。该函数似乎按预期工作,在编辑模式下返回一个空字符串,如果不是,则返回标题。但是,使用开发工具我可以看到由于某种原因标题没有在 HTML 中更新。任何帮助都会很棒,谢谢。

KO 模板

// View Model
var self = this;
var isEditMode = self.isEditMode;

var myModel = function(data) {
  ko.mapping.fromJS(data, {}, this);
  var self = this;

  self.getTitle = ko.computed(function() {
    var str = '';

    if (!isEditMode()) {
      str = 'my title';
    }
    return str;
  });
};

var mapping = {
  create: function(options) {
    return new myModel(options.data);
  }
}

var model = ko.mapping.fromJS(self.data(), mapping);
ko.applyBindings(model);
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.4.2/knockout-min.js"></script>
<table>
  <tbody data-bind="template: { name: 'myTemplate', foreach: $data }"></tbody>
</table>

<script type="text/html" id="myTemplate">
  <tr data-bind="title: setTitle">
    <td>
      <span data-bind: "text: name()"></span>
    </td>
  </tr>
</script>

【问题讨论】:

    标签: javascript html knockout.js knockout-mapping-plugin


    【解决方案1】:

    为什么不直接将 ko.observable 绑定到 span 元素? 喜欢:

    self.name = ko.observable('test');
    

    在 HTML 中:

    <span data-bind: "text: $data.name"></span>
    

    【讨论】:

      猜你喜欢
      • 2015-01-25
      • 2018-03-30
      • 2013-05-01
      • 1970-01-01
      • 2014-11-05
      • 2012-09-08
      • 2012-07-07
      • 2014-05-13
      相关资源
      最近更新 更多