我想将 DOM 操作和交互 (jQuery) 分开,让我们从我的客户端应用程序逻辑 (socket.io) 中将其称为 VIEW,让我们将其称为控制器。沟通需要有两种方式:
- 当用户与 DOM 交互时查看到 CONTROLLER,例如单击按钮
- 当服务器发送要在 DOM 中显示的更新时,控制器可以查看,例如新的聊天消息
我无法在这两个 JavaScript 对象之间进行通信。我如何以有效的方式在两者之间进行沟通?下面的简单例子。
// CONTROLLER LOGIC (socket.io stuff)
function socketController() {}
socketController.prototype = {
constructor: function() {
// define socket listners
this.socket.on('chatMessage', this.chatUpdate.bind(this));
}
chatUpdate: function(data) {
// somehow call a "render" function on the "view" object
// this.view.renderChatDOM(data.username, data.message);
}
}
// VIEW LOGIC (jQuery stuff)
function jqueryView() {}
jqueryView.prototype = {
onDOMReady: function() {
// bind event handlers
$('#send-message').bind('click', this.sendMessage.bind(this));
}
sendMessage: function(event) {
// manipulate DOM
var $messageNode = $('#message-input'),
$buttonNode = $('#send-message'),
message = $messageNode.val();
$messageNode.val(''); // clear input
// somehow call the socketController and send data
// this.socketController.chatSend(message);
}
}