我制作了一个html5游戏(使用GameMaker),它由一个index.html和一个文件夹" html5game"组成。它包含游戏的依赖关系 - javascript代码和资源。问题是资源数量众多且多样化(声音,精灵等),客户需要它们才能发挥作用。
我正在寻找一种方法来发送它们而不是专门命名它们。
我尝试了glob模块:
var glob = require( 'glob' );
var files = glob.sync( './html5game/**' ).forEach( function( file ) {
require( path.resolve( file ) );
});
但是一旦我这样做,我就无法使用res.sendFile()来发送文件。
我试过
var express = require('express');
var app = express();
[...]
app.get('/aeronavale/jeu', function(req, res){
res.sendFile(__dirname + '/aeronavale/index.html');
res.sendFile(files)
});
[...]
app.listen(3000, function(){
console.log('app started on port 3000, yeah !')
})
但它给了我错误:
TypeError: path argument is required to res.sendFile
如果您有其他解决方案,我也有兴趣。谢谢你的回答!
答案 0 :(得分:5)
您将无法使用res.sendFile
发送多个文件。你可以在这里做的最直接的事情是:
将您的index.html
文件和html5game
目录放入某个公共目录,例如:调用html
并将其放在您拥有Node.js程序的位置。示例目录布局为:
/home/you/yourapp:
- app.js (your node program)
- package.json (your package.json etc)
- html (a new directory)
- index.html (your main html to serve)
- html5game (the directory with other files)
- (other files)
现在,在您的Node程序中,您可以使用以下内容:
var path = require('path');
var express = require('express');
var app = express();
var htmlPath = path.join(__dirname, 'html');
app.use(express.static(htmlPath));
var server = app.listen(3000, function () {
var host = 'localhost';
var port = server.address().port;
console.log('listening on http://'+host+':'+port+'/');
});
这将在以下地址上提供您的所有文件(包括index.html
):
index.html
)当然,您仍需确保正确引用index.html
文件中的资源,例如:
<script src="/html5game/xxx.js"></script>
在上面的示例布局中。
包含静态资源(您拥有index.html
)的顶级目录通常称为static
,public
或html
,但您可以随意调用它,只要您在调用express.static()
时使用正确的路径。
如果您希望游戏在根路径以外的某个路径中可用,则可以将其指定为app.use
。例如,如果你改变了这个:
app.use(express.static(htmlPath));
到此:
app.use('/game', express.static(htmlPath));
然后代替那些网址:
index.html
)这些网址将可用:
index.html
)这里有很多问题与使用Express提供静态文件有关,所以我做了一个工作示例并将其发布在GitHub上,以便人们可以有一个有效的起点并从那里开始:
另请参阅其他一些答案,我会更详细地讨论它:
答案 1 :(得分:0)
解决方法是使用archiver library压缩目录并在前端将其解压缩。