$cookiesProvider浏览器
使用$cookiesProvider改变$cookies服务的默认行为。安全
默认属性cookie
path:字符串,cookies只在这个路径及其子路径可用。默认状况下,这个将会是出如今你基础标签上的网址路径。session
domain:字符串,cookies只在这个域及其子域可用。为了安全问题,若是当前域不是需求域的或者其子域,那么用户代理不会接受cookies。dom
expires:字符串,日期。"Wdy, DD Mon YYYY HH:MM:SS GMT"格式的字符串或者一个日期对象表示cookies将在这个确切日期/时间过时。ide
secure:boolean,该cookies将只在安全链接中被提供。spa
$cookiesProvider 配置代理
(function () { angular.module('Demo', []) .config(["$cookiesProvider",cookiesFn ]) function cookiesFn($cookiesProvider) { $cookiesProvider.defaults = { path: yourPath, domain: yourDomain, expires: expireDate, secure: true/false }; } }());
$cookiescode
提供浏览器cookies的读/写访问操做。对象
支持1.4及以上版本。
须要引入ngCookies模块。angular.cookies[.min].js
方法:
get(key);
根据key返回该cookies值。
key:搜索cookies的id。
getObject(key);
根据key返回该cookies的反序列化值。
key:搜索cookies的id。
getAll();
返回全部cookies的键值对格式对象。
put(key,value,[options]);
根据给定的id设置一个cookies。
key:cookies值的id。
value:要存储的cookies原始值。
[options]:选项对象。
putObject(key,value,[options]);
根据给定的id设置一个cookies。
key:cookies值的id。
value:要存储的cookies原始值。
[options]:选项对象。
remove(key,[options]);
移除指定id的cookies。
key:要删除的键值cookies对的id。
[options]:选项对象。
$cookieStore
提供一个被session cookies支持的键值对(字符串-对象)存储。被存入和取出的对象将自动经过angular的toJson/fromJson进行序列化/反序列化。
依赖:$cookies
方法:
get(key);
根据key返回cookies值(已被反序列化)。
key:搜索cookies的id。
put(key,value);
根据给定的id设置一个cookies。
key:cookies值的id。
value:要存储的cookies值。
remove(key);
移除指定id的cookies。
key:要删除的键值cookies对的id。
使用代码:
(function () { angular.module('Demo', ["ngCookies"]) .controller('testCtrl', ["$cookies","$cookieStore","$timeout",testCtrl]); function testCtrl($cookies,$cookieStore,$timeout) { var time = new Date().getTime()+5000; $cookies.put("theCookie","Hello World",{expires:new Date(new Date().getTime()+5000)}); $cookies.putObject("objCookie",{value:"Hello World"},{expires:new Date(new Date().getTime()+5000)}); $cookieStore.put("newCookie",{value:"Hello World"}); var getCookie = $cookies.get("theCookie"); // Hello World var getObjCookie = $cookies.getObject("objCookie"); // Object{ value="Hello World" } var getNewCookie = $cookieStore.get("newCookie"); // Hello World //$cookies.remove("theCookie"); // theCookie = unfefined //$cookies.remove("objCookie"); // objCookie = undefined var allCookies = $cookies.getAll(); // Object{ theCookie="Hello World", objCookie="{"value":"Hello World"}", newCookie="{"value":"Hello World"}" } $timeout(function(){ var _getCookie = $cookies.get("theCookie"); // theCookie = unfefined var _getObjCookie = $cookies.getObject("objCookie"); // objCookie = undefined $cookieStore.remove("newCookie"); // newCookie = undefined },6000); } }());
注意 : angular 使用 cookies 须要引入angular-cookies[.min].js
使用 cookies 需谨慎,多注意路径(path)和域(domain)的坑就基本没什么问题了