繁体   English   中英

Knockout.js - 传递参数

[英]Knockout.js - passing parameters

我有一个Knockout.js的问题。 我想将用户名传递给一个函数并在警报时显示它。 发生了一些奇怪的事情。 每当我用正确的用户名刷新页面时,我都会收到警报,但是在我点击它之后我没有得到任何回复。 这有什么不对? 这是我的代码:

<ul data-bind="foreach: contacts">
   <li class="user-box"><span class="user-box-name" data-bind="text: username, click: $root.userClick(username)"></span>
   </li>
</ul>

self.userClick = function (x) {
    alert(x);
}

click绑定接受在click控件时要调用的回调函数。

但是在您的示例中,您将调用该函数。 所以每次加载页面时都会发生这种情况,加载绑定并在编写函数时调用它。 你需要将它包装在一个函数中,这样它就不会被调用。

<span class="user-box-name"
      data-bind="text: username, click: function () { $root.userClick(username); }">
</span>

Knockout将正确的对象传递给事件处理程序。 就这样做:

<ul data-bind="foreach: contacts">
   <li class="user-box">
     <span 
       class="user-box-name" 
       data-bind="text: username, click: $root.userClick"
     ></span>
   </li>
</ul>

self.userClick: function (obj, event) {
    alert(obj.username);
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM