jsviews 中的辅助函数

Helper functions in jsviews

我正在浏览 JsViews 站点中按钮的以下示例 http://www.jsviews.com/#link-button。当我修改代码以获取输入并在单击按钮时在警告框中显示相同内容时,辅助函数将在加载时执行。此外,不是单击按钮,而是在输入值更改时执行该函数。我猜想因为视图中的模型值发生了变化,函数被调用了更新后的模型值,但为什么它在单击按钮时不起作用。我对 jsviews 很陌生,无法理解正在发生的事情。谁能告诉我我的方法有什么问题。下面是更新后的代码。

<div id="topLinked">
<input type="text" data-link="test"/>
 <button data-link="{on ~doSomething(test)}">Do something</button>
<input type="button" data-link="{on ~doSomething(test)}" value="Do something" />
           </div>  

  var person = {};

var helpers = {
  doSomething: function(val) {
    alert(val);
  }
}

$.link(true, "#topLinked", person, helpers); // Data-link top-level content

你犯了这个错误:data-link="{on ~doSomething(test)}"。 参数通过一个或多个空格传递,如下所示:data-link="{on ~doSomething test test2 ...}".

我把 example 改成了这样:

html

<div id="result"></div>

<script id="tmpl" type="text/x-jsrender">
  <input type="text" data-link="test" value="Do something" />
  {^{on ~doSomething test}}Do something{{/on}}
  <button data-link="{on ~doSomething test}">Do something</button>
  <input type="button" data-link="{on ~doSomething test}" value="Do something" />
</script>

js

var person = {
    test : "start value"
};

var helpers = {
    doSomething : function (val) {
        alert(val);
        return false;
    }
}

var tmpl = $.templates("#tmpl");
tmpl.link("#result", person, helpers);

jsfiddle

上的示例