1. ホーム
  2. javascript

[解決済み] 未定義のプロパティ 'protocol' を読み取ることができません。

2022-02-12 07:59:01

質問

APIからデータを取得しようとすると、コンソールにエラーが表示されます。どなたかこの問題を経験された方はいらっしゃいますか?

var url = "https://api.website.com/get/?type=events&lat=" + localStorage.getItem('latitude')
+ "&lng=" + localStorage.getItem('longitude') + "&distance=50";

$http({
    headers: {
        'Content-type': 'application/json'
    }
})

$http.get(url).success(function (events) {
    $scope.events = events;
});

のエラーが発生しました。

TypeError: Cannot read property 'protocol' of undefined
at Gb (http://localhost:38772/www/js/plugins/angular.min.js:114:238)
at s (http://localhost:38772/www/js/plugins/angular.min.js:65:249)
at new EventsController (http://localhost:38772/www/js/angular.js:4:5)
at d (http://localhost:38772/www/js/plugins/angular.min.js:30:452)
at Object.instantiate (http://localhost:38772/www/js/plugins/angular.min.js:31:80)
at http://localhost:38772/www/js/plugins/angular.min.js:61:486
at http://localhost:38772/www/js/plugins/angular.min.js:49:14
at q (http://localhost:38772/www/js/plugins/angular.min.js:7:380)
at E (http://localhost:38772/www/js/plugins/angular.min.js:48:382)
at f (http://localhost:38772/www/js/plugins/angular.min.js:42:399) 

解決方法は?

不正な $http リクエストを発行しています。

ヘッダを設定するために、別の呼び出しで $http . への呼び出し $http() は実際にリクエストを発行しますが、ヘッダだけ (url やメソッドはなし) で構成されているため、 (予想通り) このエラーがスローされます。

ヘッダを設定したい場合は、カスタム設定オブジェクトを2番目のパラメータとして $http.get() を呼び出します。

$http.get(url, {
  headers: {
    'Content-type': 'application/json'
  }
}).success(function (events) {
  $scope.events = events;
});