6

我正在开发一个使用 AngularJS 和 Socket.io 的项目。我发现了这个非常好的集成示例。

这是项目结构:

app.js                  --> app config
bower.json              --> for bower
package.json            --> for npm
public/                 --> all of the files to be used in on the client side
  css/                  --> css files
    app.css             --> default stylesheet
  img/                  --> image files
  js/                   --> javascript files
    app.js              --> declare top-level app module
    controllers.js      --> application controllers
    directives.js       --> custom angular directives
    filters.js          --> custom angular filters
    services.js         --> custom angular services
  bower_components/
    angular/            --> angular.js
    angular-socket-io/  --> socket.io adapter for angular
routes/
  index.js              --> route for serving HTML pages and partials
  socket.js             --> serve content over a socket
  api.js                --> serve JSON to our AngularJS client
views/
  index.jade            --> main page for app
  layout.jade           --> doctype, title, head boilerplate
  partials/             --> angular view partials (partial jade templates)
    partial1.jade
    partial2.jade

在 app.js 中:

var express = require('express'),
    routes = require('./routes'),
    api = require('./routes/api'),
    socket = require('./routes/socket');

...

// serve index and view partials
app.get('/', routes.index);
app.get('/partials/:name', routes.partials);

// JSON API
app.get('/api/name', api.name);

// redirect all others to the index (HTML5 history)
app.get('*', routes.index);

// Socket.io Communication
io.sockets.on('connection', require('./routes/socket'));

现在,虽然通常我只是将服务器逻辑放入app.js其中,但这里的逻辑似乎分为api.js,socket.jsindex.js- 我非常喜欢这个。

但是,假设socket.js我需要使用api.js.. 中定义的东西,我应该添加一个var api = require('./api');insocket.js吗?

4

1 回答 1

-1

我最终创建了模块/对象,将所有内容导入 app.js 并通过相互引用传递它们(在需要时)..

  var mashup = require('./routes/mashupModule'),
  socket = require('./routes/socketModule'),
  browser = require('./routes/browserModule');

  socket.init(server, browser, mashup);
  browser.init(socket, mashup);

不确定这是否是在代码中进行某种分离的最佳方式。我习惯了 Java,而且在 JS 中它通常是一个大源文件,这很糟糕。

于 2013-08-05T23:31:00.980 回答