【问题标题】:Unable to load installed module in the jade client无法在翡翠客户端中加载已安装的模块
【发布时间】:2013-04-07 10:52:12
【问题描述】:

谁能指出为什么我在客户端加载 socket.io 模块时出现 404 错误?我认为我在 layout.jade 文件中调用 socket.io 模块的方式有问题。

脚本(type='text/javascript', src='../socket.io/socket.io.js')

这是一个基本的 express 应用程序,它使用 Socket.io 模块创建一个网络套接字。当我使用客户端(使用 Jade 模板引擎)连接到 Web 套接字时,它会抛出 -

GET http://localhost:3000/socket.io/socket.io.js 404 (Not Found)

这里是我的 layout.jade、index.jade 和 app.js 的内容。

Layout.jade

doctype 5
html
head
title= title
script(src='http://ajax.googleapis.com/ajax/libs/jquery/1.4.3/jquery.min.js')       
script(type='text/javascript', src='/javascripts/flot/jquery.js')
script(type='text/javascript', src='/javascripts/flot/jquery.flot.js')      
script(type='text/javascript', src='../socket.io/socket.io.js') //script(src='http://'+ domain + ':3000/socket.io/socket.io.js')    
link(rel='stylesheet', href='/stylesheets/style.css')
body
block content'

Index.jade

extends layout
block content
h1= title
p Welcome to #{title}

Index.js

exports.index = function(req, res){  
res.render('index', { title: 'Temperature Monitor',domain: 'localhost'  });
};

app.js

var express = require('express'),
routes = require('./routes'),
user = require('./routes/user'),
http = require('http'),
path = require('path');

var app = express();
var httpServer = http.createServer(app);
var io = require('socket.io').listen(httpServer);

app.configure(function(){
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
});

app.configure('development', function(){
app.use(express.errorHandler());
});

app.get('/', routes.index);
app.get('/users', user.list);

http.createServer(app).listen(app.get('port'), function(){
      console.log("Express server listening on port " + app.get('port'));
});

io.sockets.on('connection', function(socket) {
    socket.emit('welcome', {'salutation':'TMP36 Sensor output!'});      
});'

我运行了以下命令来创建应用程序。

express homeAutomation
cd homeAutomation
npm install
node app.js

我的文件夹结构的详细信息 -

HomeAutomation
  ->node_modules
    ->express
    ->jade
    ->socket.io    
  ->public
    ->routes
  ->views
    ->index.jade
    ->layout.jade
  App.js

【问题讨论】:

    标签: node.js express pug


    【解决方案1】:

    您的 app.js 文件有一些错误的代码。修改如下。

        var express = require('express'),
        routes = require('./routes'),
        user = require('./routes/user'),
        http = require('http'),
        path = require('path');
    
        var app = express();
    
    
        app.configure(function(){
        app.set('port', process.env.PORT || 3000);
        app.set('views', __dirname + '/views');
        app.set('view engine', 'jade');
        app.use(express.favicon());
        app.use(express.logger('dev'));
        app.use(express.bodyParser());
        app.use(express.methodOverride());
        app.use(app.router);
        app.use(express.static(path.join(__dirname, 'public')));
        });
    
        app.configure('development', function(){
        app.use(express.errorHandler());
        });
    
        app.get('/', routes.index);
        app.get('/users', user.list);
    
       var httpServer = http.createServer(app).listen(app.get('port'), function(){
        console.log("Express server listening on port " + app.get('port'));
       });
    
        var io = require('socket.io').listen(httpServer);
        io.sockets.on('connection', function(socket) {
            socket.emit('welcome', {'salutation':'TMP36 Sensor output!'});      
        });
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2013-05-19
      • 1970-01-01
      • 2014-04-10
      • 1970-01-01
      • 1970-01-01
      • 2014-04-17
      • 2015-06-03
      • 1970-01-01
      相关资源
      最近更新 更多