Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/38.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
平均堆栈-使用Express发送AngularJS的所有静态内容_Angularjs_Node.js_Express_Mean Stack - Fatal编程技术网

平均堆栈-使用Express发送AngularJS的所有静态内容

平均堆栈-使用Express发送AngularJS的所有静态内容,angularjs,node.js,express,mean-stack,Angularjs,Node.js,Express,Mean Stack,我很抱歉,我已经用node制作了一些应用程序,并且在一些前端使用了Angular,但我从未将这两者结合起来。我完全不知道在发送index.html时如何将所有视图发送到前端。目前,我的服务器中有以下代码: ... app.use(express.static('./app')); app.listen(config.port, function() { logger.info('Server listening on ' + config.port); }); .... app.ge

我很抱歉,我已经用node制作了一些应用程序,并且在一些前端使用了Angular,但我从未将这两者结合起来。我完全不知道在发送index.html时如何将所有视图发送到前端。目前,我的服务器中有以下代码:

...
app.use(express.static('./app'));
app.listen(config.port, function() {
   logger.info('Server listening on ' + config.port);
}); 
....

 app.get('/update', auth.isLoggedIn, (req, res) => {
     byo.userUpdate(res);
 })

app.get('/*', function(req, res) {
    res.sendFile(__dirname + '/app/index.html');//'/public/index.html');
})
/////////

HTML Template:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<meta name="description" content="">
<meta name="viewport" content="width=device-width">
<!-- Place favicon.ico and apple-touch-icon.png in the root directory -->
<!-- build:css(.) styles/vendor.css -->
<!-- bower:css -->
<!-- endbower -->
<!-- endbuild -->
<!-- build:css(.tmp) styles/main.css -->
<link rel="stylesheet" href="styles/main.scss">
<link rel="stylesheet"        href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css" integrity="sha384-1q8mTJOASx8j1Au+a5WDVnPi2lkFfwwEAa8hDDdjZlpLegxhjVME1fgjWPGmkzs7" crossorigin="anonymous">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js" integrity="sha384-0mSbJDEHialfmuBBQP6A4Qrprq5OVfW37PRR3j5ELqxss1yVqOtnepnHVP9aJ7xS" crossorigin="anonymous"></script>
<script  src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.7/angular.min.js">   </script>
<!-- endbuild -->
</head>
<body ng-app="uptimeApp">


<!-- Add your site or application content here -->
<div class="header">
  <div class="navbar navbar-default" role="navigation">
    <div class="container">
       <nav class="navbar navbar-inverse navbar-fixed-top">
         <div class="container">
            <div class="navbar-header">
               <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
               <span class="sr-only">Toggle navigation</span>
               <span class="icon-bar">asdasd</span>
               <span class="icon-bar"></span>
               <span class="icon-bar"></span>
               </button>
               <a class="navbar-brand" href="#">Uptime Robot</a>
            </div>
            <div id="navbar" class="collapse navbar-collapse">
               <ul class="nav navbar-nav">
                  <li class="active"><a href="">Home</a></li>
                 <!-- <li><a href="#link">Link</a></li>
                  <li><a href="#link">Link</a></li> -->
               </ul>
            </div>
        <!--/.nav-collapse -->
        </div>
     </nav>


<div class="container">
    <!--- Main Angular VIEW -->
  <div ng-view></div>

</div>

<div class="footer">
  <div class="container">
    <p><span class="glyphicon glyphicon-heart"></span> from the support team</p>
  </div>
</div>




<!-- build:js(.) scripts/vendor.js -->
<!-- bower:js -->
<script src="bower_components/jquery/dist/jquery.js"></script>
<script src="bower_components/angular/angular.js"></script>
<script src="bower_components/bootstrap-sass-official/assets/javascripts/bootstrap.js"></script>
<script src="bower_components/angular-animate/angular-animate.js"></script>
<script src="bower_components/angular-cookies/angular-cookies.js"></script>
<script src="bower_components/angular-resource/angular-resource.js"></script>
<script src="bower_components/angular-route/angular-route.js"></script>
<script src="bower_components/angular-sanitize/angular-sanitize.js"></script>
<script src="bower_components/angular-touch/angular-touch.js"></script>
<!-- endbower -->
<!-- endbuild -->

    <!-- build:js({.tmp,app}) scripts/scripts.js -->
    <script src="scripts/app.js"></script>
    <script src="scripts/controllers/byo.js"></script>
    <script src="scripts/controllers/about.js"></script>
    <!-- endbuild -->
</body>
</html>
关于.js:

 angular.module('uptimeApp')
 .controller('AboutCtrl', function () {
  this.awesomeThings = [
  'HTML5 Boilerplate',
  'AngularJS',
  'Karma'
  ];
});
app.js:

angular
.module('uptimeApp', [
'ngAnimate',
'ngCookies',
'ngResource',
'ngRoute',
'ngSanitize',
'ngTouch'
 ])
 .config(function ($routeProvider, $locationProvider, $httpProvider) {

$routeProvider

  .when('/', {
    templateUrl: 'views/byo.html',
    controller: 'byoCTRL',
    controllerAs: 'byo'
  })
  .when('/about', {
    templateUrl: 'views/about.html',
    controller: 'AboutCtrl',
    controllerAs: 'about'
  })
  .otherwise({
    redirectTo: '/'
  });


  $locationProvider.html5Mode(true);
 });
//////

my static file structure is as such:
-app
--images
--scripts
 |-controllers
 |-service
 |-app.js (angular routing file)
--views
 |-byo.html
 |-about.html
--index.html
当我运行服务器并导航到localhost:8080/时,index.html页面将按预期加载。当我签入dev工具时,html页眉/页脚中包含的所有css文件和js文件都会按预期的那样包含进来。但是,我在任何地方都看不到任何其他html文件。由于未加载ng视图,索引页的正文为空

Angular routing:
...
.config(function ($routeProvider, $locationProvider, $httpProvider) {

$routeProvider

  .when('/', {
    templateUrl: 'views/byo.html',
    controller: 'byoCTRL',
    controllerAs: 'byo'
  })
...
我有一种感觉,我错过了一些非常基本的东西,但却无法理解。在研究之后,我发现了很多关于模板引擎的文章,但我不想使用(我必须吗?)。非常感谢任何帮助,如果有任何其他信息我可以提供,请让我知道


谢谢

由于您的资源加载顺序,
byoCtrl
看起来是未知的。尝试切换加载顺序,以便在ngRoutes config()点击时byo控制器可用


是否加载了根视图
视图/byo.html
请检查控制台网络选项卡?请添加你的index.html模板。不,这是我无法理解的。索引页(基本上是页眉/页脚)看起来很好,但是“/”的主体是byo.html,没有加载任何内容。我不知道如何将其放到前端:(.我的控制台选项卡正在加载除视图文件夹之外的所有内容。请添加基本HTML模板。您是否检查了网络控制台选项卡?AngularJS是否正在启动加载
视图/byo.HTML
?您的控制台中是否有任何错误输出?我收到:未捕获错误:[$injector:modulerr]…ogleapis.com%2Fajax%2Flibs%2Fangularjs%2F1.5.7%2Fangular.min.js%3A21%3A163)在angular.js:38在angular.js:4631在r(angular.js:321)在g(angular.js:4592)在db(angular.js:4514)在c(angular.js:1751)在Bc(angular.js:1772)在ge(angular.js:1657)在HTMLDocument.js(angular.js:31468)在j(jquery.js:3148)好的,请添加你的
app.js
main.js
about.js
的全部代码。
Angular routing:
...
.config(function ($routeProvider, $locationProvider, $httpProvider) {

$routeProvider

  .when('/', {
    templateUrl: 'views/byo.html',
    controller: 'byoCTRL',
    controllerAs: 'byo'
  })
...
<script src="scripts/controllers/byo.js"></script>
<script src="scripts/controllers/about.js"></script>
<script src="scripts/app.js"></script>
app.get('/', function(req, res) {
    res.sendFile(__dirname + '/app/index.html');//'/public/index.html');
})