我将尽可能详细地解释这个问题。
我正在尝试将 AngularJS 与 Express 一起使用,但遇到了麻烦。我希望显示 HTML 文件(不使用模板引擎)。这些 HTML 文件将具有 AngularJS 指令。
但是,我无法显示一个简单的 HTML 文件本身!
目录结构如下:
Root
---->public
-------->js
------------>app.js
------------>controllers.js
---->views
-------->index.html
-------->partials
------------>test.html
---->app.js
的内容public/js/app.js
是:
angular.module('myApp', []).
config(['$routeProvider', function($routeProvider) {
$routeProvider.when('/', {templateUrl: 'partials/test.html', controller: IndexCtrl});
$routeProvider.otherwise({redirectTo: '/'});
}]);
的内容public/js/controllers/js
是:
function IndexCtrl() {
}
其中body标签的内容views/index.html
是:
<div ng-view></div>
就是这样。期望 AngularJS 将用 test.html 替换上面的视图 -views/partials/test.html
其内容是:
This is the test page!
包含在段落标签中。就是这样!
最后,ROOT/app.js
文件的内容是:
var express = require('express');
var app = module.exports = express();
// Configuration
app.configure(function(){
app.set('views', __dirname + '/views');
app.engine('html', require('ejs').renderFile);
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.static(__dirname + '/public'));
app.use(app.router);
});
app.configure('development', function(){
app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});
app.configure('production', function(){
app.use(express.errorHandler());
});
// routes
app.get('/', function(request, response) {
response.render('index.html');
});
// Start server
app.listen(3000, function(){
console.log("Express server listening on port %d in %s mode", this.address().port, app.settings.env);
});
现在,当我$node app.js
在根文件夹中进行操作时,服务器启动时没有任何错误。但是,如果我localhost:3000
在浏览器中访问,URL 会更改为localhost:3000/#/
并且页面会卡住/冻结。我什至无法检查 Chrome 中的控制台日志!
这是我面临的问题。关于我做错了什么的任何线索?