在组合MVC4, SignalR, knockoutJS时发生了onclick挑战



我有一个简单的MVC4应用程序,但是我想结合knockoutJSSignalR,我得到了一个挑战,这似乎是由于我试图在同一按钮上分配2个onclick事件:使用knockoutJS和SignalR。请让我知道这里出了什么问题。代码如下:

这是我的viewModel:

var viewModel = {
  searchString: ko.observable("Monique"),
  search: function () {
    $.ajax({
      url: "@Url.Action("Search")",
      type: "post",
      data: ko.toJSON(this),
      contentType: "application/json",
      success: function (result) {
        $('#info').append(result.message);
      }
    });
  },
  searchClient: function () {
    //do sth
  },
  showAll: function () {
    //do sth 
  }
};
ko.applyBindings(viewModel);

这部分与signalR有关:

这是我在服务器上的hub:

[HubName("send")]
public class DataHub: Hub
{
    public void Send(string text)
    {
        Clients.All.addMessage(text);
    }
}

,这是一个signalR js部分:

$(function () {
  var hub = $.connection.send;
  hub.client.addMessage = function (text) {
    alert(text);
    $('#info').append(text);
  };
  $.connection.hub.start().done(function () {
    $('#btnServer').click(function () {
      alert('btn server clicked');
      hub.server.send("something");
    });
  });
});

所以你可以看到,knockoutJS有onclick事件处理这里search: function () { }信号r中也有$('#btnServer').click(function() {

因此,与knockoutJS相关的工作,但与signalR相关的部分不工作…

在使用knockout绑定click事件的函数中,返回true。默认情况下,Knockout将阻止click事件采取任何默认操作。

相关内容

最新更新