Angularjs http get请求返回'length'错误

时间:2017-04-27 02:49:03

标签: angularjs mongodb mean

我是Angularjs和MongoDB中的新手我需要从MongoDB发送HTTP请求以获取自动完整的角度素材当我发送到git hub API时它工作得很好但是对于我的数据库,我得到'无法读取未定义的属性'长度' “ 我在客户端的控制器

    /*jslint latedef:false*/
(function () {
  'use strict';
  angular
      .module('clientApp')
      .controller('CarnetCtrl', function($http){

        this.querySearch = function(query){
        //for this link work "https://api.github.com/search/users"  
       return$http.get("http://localhost:3000/carnet/export_countries/", {
                params: {
                    q: query
                }
            }).then(function(response){
                return response.data.items;
            });

        };
      });

})();

我的Mongodb控制器

    var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var Q = require('q'); // We can now use promises!



//Create Schema
var CarnetExportCountriesSchema = new Schema({


CarnetExportCountriesSchema.statics.getCarnetExportCountries = function(Country_Name_EN) {

    var deferred = Q.defer();

    this.findOne({Country_Name_EN: Country_Name_EN}, function(error, CarnetExportCountries){

        if (error) {

            deferred.reject(new Error(error));
        }
        else {

            deferred.resolve(manufacturers);
        }
    });

    return deferred.promise;
}


CarnetExportCountriesSchema);



module.exports = CarnetExportCountriesSchema;

和index.js服务器端:

//Add Middleware necessary for REST API's
app.use(bodyParser.urlencoded({extended: true}));
app.use(bodyParser.json());
app.use(bodyParser.json({type:'application/vnd.api+json'}));
app.use(methodOverride('X-HTTP-Method-Override'));

//CROS Support
app.use(function(req,res,next){
    res.header('Access-Control-Allow-Origin','*');
    res.header('Access-Control-Allow-Methods','GET,PUT,POST,DELETE');
    res.header('Access-Control-Allow-Headers','Content-Type');
    res.header('("Content-Length", ""+json.length() );');
    next();
});

我的app.js

  .config(function (
    $routeProvider,
    RestangularProvider
    ) {
    RestangularProvider.setBaseUrl('http://localhost:3000');
    $routeProvider
      .when('/main', {
        templateUrl: 'views/main.html',
        controller: 'MainCtrl',
        controllerAs: 'main'
      })

我的错误:

TypeError: Cannot read property 'length' of undefined
    at hasMatches (angular-material.js:25423)
    at shouldShow (angular-material.js:25415)
    at shouldHide (angular-material.js:25380)
    at setLoading (angular-material.js:25371)
    at angular-material.js:25564
    at handleCallback (angular.js:17010)
    at angular.js:16825
    at processQueue (angular.js:16843)
    at angular.js:16887
    at Scope.$digest (angular.js:17982) "Possibly unhandled rejection: {}"

请帮助我解决这个问题我在1周内搜索和阅读,但无法解决这个问题

2 个答案:

答案 0 :(得分:0)

尝试删除res.header('("Content-Length", ""+json.length() );');

答案 1 :(得分:0)

请检查return$http.get是否写成一个单词(返回和$ http之间的空格)并在回复时进行检查

if(response && response.data && response.data.items){
 return response.data.items
}
 return [];