抓取mongodb中的对象并将其放在$ scope中

时间:2014-09-26 13:59:25

标签: node.js angularjs mongodb mean-stack ng-view

我试图从网址中获取产品的标识符(例如。/product/<productId>),从mongodb中获取Product对象,并在我的应用程序的$scope中访问该对象。从网址中抓取productId可以正常使用$routeParams,但我很难将对象从mongodb中移出并进入范围。

我的猜测是我需要在服务器端的products-controller.js中添加代码,但是如何从服务器端的$ scope调用productId?

我知道查询应该是什么样的(例如。db.products.find({_id : ObjectId("5422c8b2d4cc50e99f007f73")})

server.js
    app.get('/api/products', productsController.list);

app.js

var app = angular.module('productApp', ['ngResource', 'ngRoute']);

app.config(['$routeProvider', '$locationProvider', function($routeProvider, $locationProvider) {
    $routeProvider
        .when('/', {
            templateUrl: '/views/productsoverview.html',
            controller: 'productsController'
        })
        .when('/product/:productId', {
            templateUrl: '/views/productFocus.html',
            controller: 'productFocusController'
        })
        .otherwise({
            redirectTo: '/'
        });
    $locationProvider.html5Mode(true)
}]);

app.controller('productsController', ['$scope', '$resource', 
    function($scope, $resource) {
        var Product = $resource('/api/products');

        $scope.products = [];

        Product.query(function (results) {
            $scope.products = results;
        });

}]);

app.controller('productFocusController', ['$routeParams', '$scope', '$resource', 
    function($routeParams, $scope, $resource) {
        if($routeParams.productId) {
            $scope.productId = $routeParams.productId

        }
}]);

products-controller.js (服务器)

var Product = require('../models/product');
module.exports.list = function (req, res) {
  Product.find({}, function (err, results) {
    res.json(results);
  });
}

1 个答案:

答案 0 :(得分:1)

  

如何从服务器端的$ scope调用productId?   将$ scope.productId作为参数传递,将其包含在像

这样的URL中

您在服务器端的路线可能类似于

/api/products/:productId

然后将您从客户端URL获取的参数传递给您的资源:

pp.controller('productsController', ['$scope', '$resource', '$routeParams',
    function($scope, $resource,$routeParams) {
        var ProductEndpoint = $resource('/api/products/:productId',{productId:'@productId'});
        var product = new ProductEndPoint();
        product.productId = $routeParams.productId;
        $scope.products = [];
        Product.query(function (results) {
            $scope.products = results;
        });

}]);
服务器端的

var Product = require('../models/product');
module.exports.list = function (req, res) {
  Product.find({_id:req.params.productId}, function (err, results) {
    res.json(results);
  });
}