html5 - express4 + socket.io 如何在connection的回調(diào)外邊使用socket.emit方法
問題描述
app.js
var sockect = require(’./socket/server’) var users = require(’../router/users’)app.use(’/users’, users); //路由var server = app.listen(9000, function () {console.log(’server start’); });sockect(server); //啟動(dòng)socket
server.js
’use strict’;module.exports = function(server) { var io = require(’socket.io’).listen(server); io.sockets.on(’connection’, function (socket) {//如何將這里的socket暴露給其他地方的js方法里使用socket.emit ? }); return io;};
上面是我目前的結(jié)構(gòu),希望在users里面的邏輯里觸發(fā)emit方法,google了很多,也沒有找到有什么辦法可以將參數(shù)socket傳遞出去,不然的話所有邏輯只要涉及到socket.emit的都要寫在connection的回調(diào)里..
問題解答
回答1:server.js文件中:
var users = require(’../router/users’)module.exports = function(server) { var io = require(’socket.io’).listen(server); io.sockets.on(’connection’, function (socket) {//如何將這里的socket暴露給其他地方的js方法里使用socket.emit ?users.doSomething(socket); }); return io;};
然后在users.js寫業(yè)務(wù)邏輯
回答2:我也遇到這個(gè)問題,求解
回答3:我也覺得外部調(diào)用socket沒什么意義。。而且express和socket兩者走的協(xié)議都不一樣,你可以把user的身份信息保存在 局部變量socket的作用域內(nèi)通過標(biāo)識(shí)信息來執(zhí)行相應(yīng)用戶的操作
回答4:同求解,怎么把那個(gè)socket對(duì)象暴露出去????
回答5:<table border='0' cellpadding='0' cellspacing='0'><tr> <td height='32'><img src='http://www.gepszalag.com/wenda/images/tell_top.gif' border='0'></td> </tr> <tr> <td background='images/tell_center.gif'> <?php include_once('function.php'); $news='明日編程詞典上市了!'; $i=1; do{ ?> <table with='148' border='0' cellpadding='0' cellspacing='0'> <tr> <td height='20'><img src='http://www.gepszalag.com/wenda/images/mark_0.gif' height='10'></td> <td width='333'> <?php echo chinesesubstr($news, 0, 18); if(strlen($nes)>18){ echo '...'; } ?> </td> </tr><tr> <td height='5'></td> <td background='images/back_point_write.gif'></td></tr> </table><?php$i++;}while($i<=5);?></td> </tr> <tr> <td height='12'><img src='http://www.gepszalag.com/wenda/images/tell_bottom.gif' height='12'></td> </tr> </table>
相關(guān)文章:
1. mysql在限制條件下篩選某列數(shù)據(jù)相同的值2. php - 生產(chǎn)環(huán)境下,給MySQL添加索引,修改表結(jié)構(gòu)操作,如何才能讓線上業(yè)務(wù)不受影響?3. mysql - Sql union 操作4. mysql - 僅僅只是把單引號(hào)與反斜杠轉(zhuǎn)義不用prepare statement能否避免sql注入?5. java - Mybatis 數(shù)據(jù)庫多表關(guān)聯(lián)分頁的問題6. mysql主主同步,從庫不同步應(yīng)該怎么解決?7. mysql - 拖拽重排序后怎么插入數(shù)據(jù)庫?8. 新入手layuiadmin,部署到tp中。想用php自已寫一個(gè)后臺(tái)管理系統(tǒng)。9. android - 安卓做前端,PHP做后臺(tái)服務(wù)器 有什么需要注意的?10. mysql 獲取時(shí)間函數(shù)unix_timestamp 問題?
