使用 Express 为 AngularJS 渲染一个 .ejs 模板并使用 AngularJS $scope 中的数据

Posted

技术标签:

【中文标题】使用 Express 为 AngularJS 渲染一个 .ejs 模板并使用 AngularJS $scope 中的数据【英文标题】:Using Express to render an .ejs template for AngularJS and use the data inside AngularJS $scope 【发布时间】:2015-08-26 22:58:48 【问题描述】:

我希望我可以用我在 Stack Overflow 上发布的第一个问题来解释自己。

我正在使用 MEAN 堆栈构建一个小型测试应用程序。

应用程序根据我创建的 Express Route 从 Mongoose 接收可变数据。

例如 url 是:localhost:3000/cities/test/Paris

根据城市名称,回复会给出城市名称和描述。我知道如何在 .ejs 模板中获取这些数据 但这不是我想要的。我想在 ngRepeat 中使用这些数据。

也许这不是正确的方法,但也许你可以帮我解决这个问题。

我想要这样做的原因是因为我不想要一个单页应用程序,而是一个可以为每个城市反复使用的 Angular 模板,并且只使用从 mongoose find() 结果返回的数据而不是整个城市数组。

app.js:

var cityRoutes = require('./routes/cities');
app.use('/cities', cityRoutes);
app.set('views', './views'); // specify the views directory
app.set('view engine', 'ejs'); // register the template engine

./routes/cities/cities.js :

var express = require('express');
var citiesList  = require('../server/controllers/cities-controller');

var bodyParser = require('body-parser');
var urlencode = bodyParser.urlencoded( extended: false );

var router = express.Router();

// because this file is a fallback for the route /cities inside app.js
// the route will become localhost:3000/cities/test/:name
// not to be confused by its name in this file.
router.route('/test/:name')
    .get(citiesList.viewTest)

 module.exports = router;

../server/controllers/cities-controller.js :

var City = require('../models/cities');

module.exports.viewTest = function(request, responce)
City.find( stad: request.params.name , function(err, results)

    if (err) return console.error(err);
        if (!results.length) 
            responce.json( "404" );
     else 
        responce.render('angular.ejs',   messages:results );
        // through this point everything works fine
        // the angular.ejs template gets rendered correctly
        // Now my problem is how tho get the results from the 
        // response.render inside the Angular directive 
        // so I can use the data in a $scope
    
    );
;

../models/cities.js

var mongoose = require('mongoose');

module.exports = mongoose.model('City', 
    stad:  type: String, required: true ,
    omschrijving: String
);

AngularJS 指令:

// This is where I would like to use the messages result data
// so I can create a $scope that handles data that can be different
// for each url 
// so basically I am using this directive as a template

app.directive('bestelFormulier', function () 
return 
    restrict: 'E',
    templateUrl: '/partials/bestel-formulier.html',
    controller: ['$scope', '$http', '$resource', '$cookieStore',
function($scope, $http, $resource, $cookieStore) 


    // at this point it would be nice that the $scope gets the
    // url based results. But I don't now how to do that..
    // at this point the var "Cities" gets the REST API with 
    // all the cities...

    var Cities = $resource('/cities');

        // get cities from mongodb
        Cities.query(function(results)
            $scope.cities = results;
            //console.log($scope.products);
        );

        $scope.cities = ;

    ],
    controllerAs: 'productsCtrl'


);

数据库是这样存储的:

[
    
        stad: 'Paris',
        omschrijving: 'description Paris',
    ,
    
        stad: 'Amsterdam',
        omschrijving: 'description Amsterdam',
    
]

我希望包含的这些文件有助于解释我的问题。

提前感谢您帮助我

【问题讨论】:

【参考方案1】:

我想出了一个办法……

对我的代码的以下更改解决了我的问题。

在 app.js 中

var cityRoutes = require('./routes/cities');
app.use('/', cityRoutes);
// removed the name cities

./routes/cities/cities.js :

router.route('/cities/test/:name')

    .get(citiesList.viewTest)

// added this route to use as an API
router.route('/api/cities/test/:name')

    .get(citiesList.viewStad)

../server/controllers/cities-controller.js :

// added this callback so that a request to this url
// only responses with the data I need
module.exports.viewStad = function(request, responce)
    City.find( stad: request.params.name , function(err, results)

        if (err) return console.error(err);
        if (!results.length) 
            responce.json( "404" );
         else 
            responce.json( results );
        
    );
;

在我的 AngularJS 应用程序中,我添加了 $locationDirective 并将 Angular 指令中的以下内容更改为:

var url = $location.url();
var Cities = $resource('/api' + url);
// now when my .ejs template gets loaded the Angular part looks at
// the current url puts /api in front of it and uses it to get the
// correct resource

这就是我可以在我的 $scope 中使用它并使用所有可爱的 Angular 功能的方式:-)

希望我可以帮助其他人...最终这是一个简单的解决方案,也许有人知道更好的方法来做到这一点。对我来说,它现在可以工作了。

【讨论】:

以上是关于使用 Express 为 AngularJS 渲染一个 .ejs 模板并使用 AngularJS $scope 中的数据的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 Express、AngularJS、Socket.io 广播和获取通知?

如何正确渲染部分视图,并使用 Express/Jade 在 AJAX 中加载 JavaScript 文件?

AngularJS 的 $routeProvider templateUrl 总是使用 Express 返回 404

在 Node.js 中加载 html 页面

angularjs加载渲染完页面怎么更改数据?

请求新页面时如何将 AngularJS 路由与 Express (Node.js) 一起使用?