资讯专栏INFORMATION COLUMN

封装操作cookie的方法

gself / 1357人阅读

摘要:使用原生方法对操作是有些麻烦的,我们可以将其封装起来,代表键名,代表值,不填则为读取名为的值,代表设置值如有效期等。其中有效期单位为天。

使用原生方法对cookie操作是有些麻烦的,我们可以将其封装起来,name代表键名,value代表值,不填则为读取名为name的值,option代表设置值如有效期等。其中有效期单位为天。

</>复制代码

  1. function cookie(name, value, options) {
  2. if (typeof value != "undefined") {
  3. options = options || {};
  4. //如果值为null, 删除cookie
  5. if (value === null) {
  6. value = "";
  7. options = {
  8. expires: -1
  9. };
  10. }
  11. //设置有效期
  12. var expires = "";
  13. if (options.expires && (typeof options.expires == "number" || options.expires.toGMTString)) {
  14. var date;
  15. if (typeof options.expires == "number") {
  16. date = new Date();
  17. date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));
  18. } else {
  19. date = options.expires;
  20. }
  21. expires = ";expires=" + date.toGMTString();
  22. }
  23. var path = options.path ? ";path=" + (options.path) : "";
  24. var domain = options.domain ? ";domain=" + (options.domain) : "";
  25. var secure = options.secure ? ";secure" : "";
  26. //设置cookie
  27. document.cookie = [name, "=", encodeURIComponent(value), expires, path, domain, secure].join("");
  28. } else {
  29. //读取cookie
  30. if (document.cookie.length > 0) {
  31. var start = document.cookie.indexOf(name + "=")
  32. if (start != -1) {
  33. start = start + name.length + 1;
  34. var end = document.cookie.indexOf(";", start);
  35. if (end == -1){
  36. end = document.cookie.length;
  37. }
  38. return decodeURIComponent(document.cookie.substring(start, end));
  39. }
  40. }
  41. return ""
  42. }
  43. }
  44. cookie("name", "zhangsan"); //添加name=zhangsan
  45. cookie("name", null); // 删除name
  46. cookie("age", "10", {
  47. expires: 30
  48. }); // 添加age=10且有效期30天

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/44206.html

相关文章

  • 封装一个 cookie 功能

    摘要:中的在中操作通过来实现操作在传递过程中,使用上面这样的方式对于参数的传递和拼接都是不太方便的,下面我们来封装一个自己的功能。上面就是我们封装的功能模块来帮主我们设置和获取,之所以封装这个功能最终的目的就是让我们更方便的通过来操作。 showImg(https://segmentfault.com/img/remote/1460000018998719?w=1200&h=515); 阅...

    Cc_2011 评论0 收藏0
  • 封装操作cookie方法

    摘要:使用原生方法对操作是有些麻烦的,我们可以将其封装起来,代表键名,代表值,不填则为读取名为的值,代表设置值如有效期等。其中有效期单位为天。 使用原生方法对cookie操作是有些麻烦的,我们可以将其封装起来,name代表键名,value代表值,不填则为读取名为name的值,option代表设置值如有效期等。其中有效期单位为天。 function cookie(name, value, op...

    xiaoqibTn 评论0 收藏0
  • 封装操作cookie方法

    摘要:使用原生方法对操作是有些麻烦的,我们可以将其封装起来,代表键名,代表值,不填则为读取名为的值,代表设置值如有效期等。其中有效期单位为天。 使用原生方法对cookie操作是有些麻烦的,我们可以将其封装起来,name代表键名,value代表值,不填则为读取名为name的值,option代表设置值如有效期等。其中有效期单位为天。 function cookie(name, value, op...

    lieeps 评论0 收藏0
  • 封装操作cookie方法

    摘要:使用原生方法对操作是有些麻烦的,我们可以将其封装起来,代表键名,代表值,不填则为读取名为的值,代表设置值如有效期等。其中有效期单位为天。 使用原生方法对cookie操作是有些麻烦的,我们可以将其封装起来,name代表键名,value代表值,不填则为读取名为name的值,option代表设置值如有效期等。其中有效期单位为天。 function cookie(name, value, op...

    付伦 评论0 收藏0
  • 封装操作cookie方法

    摘要:使用原生方法对操作是有些麻烦的,我们可以将其封装起来,代表键名,代表值,不填则为读取名为的值,代表设置值如有效期等。其中有效期单位为天。 使用原生方法对cookie操作是有些麻烦的,我们可以将其封装起来,name代表键名,value代表值,不填则为读取名为name的值,option代表设置值如有效期等。其中有效期单位为天。 function cookie(name, value, op...

    Joonas 评论0 收藏0

发表评论

0条评论

gself

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<