I'm trying to use cookies within Angular - here's what I'm trying:
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.14/angular-cookies.min.js"></script>
var capApp = angular.module('capApp', ['ngRoute','ui.bootstrap','ngCookies']);
capApp.controller('cookieCtrl', ['$scope','$cookies', function($scope, $cookies) {
var favoriteCookie = $cookies.get('user_id');
alert(favoriteCookie);
}]);
I get this error in the console:
TypeError: $cookies.get is not a function
Any ideas where I'm going wrong?
UPDATE
Check which version of Angular you are using for everything - any Angular guys read this, make the version switch in the docs bright green and huge! You simply don't notice it.
In Angular 1.3.14 you can just use
var favoriteCookie = $cookies[user_id];
See the documentaiton here: Angular Cookies
The following method should work.
var favoriteCookie = $cookies.user_id;
The syntax you have is for version 1.4.x but you are referencing an older version. If you do not want to update to 1.4.x, you can use $cookieStore instead as follows:
$cookieStore.put("key", "value");
var value = $cookieStore.get("key");
Alternatively if you are using version 1.3.x or below, you can use $cookies as follows:
$cookies.key = "value";
var value = $cookies.key;
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With