Cookie

1. Cookie 概念

  • cookie 是由服務(wù)器端生成打却,發(fā)送給 User-Agent倡鲸。瀏覽器會將cookie以key/value的形式保存到某個目錄下的文本文件中搔啊。下次請求同一網(wǎng)站時就發(fā)送該cookie給服務(wù)器简逮。
  • 每個瀏覽器都有一個cookie文件
  • cookie大小有限制趁啸,大約都在4k左右舶斧。

2. 基本用法

在Console中使用document.cookie可以獲取當(dāng)前的所有cookie

效果

同時也可以添加cookie欣鳖,也是通過這個document.cookie,例子如下:

<body>
    <script>
        var oDate = new Date();
        oDate.setDate(oDate.getDate() + 3);
        // console.log(oDate);
        document.cookie = 'age=18; max-age=1000';
        document.cookie = 'name=sun; expires=' + oDate;
        document.cookie = 'test=session';
    </script>
</body>

代碼效果

注意茴厉,設(shè)置了過期時間的cookie會到過了時間才被注銷泽台,而 Session這條cookie在瀏覽器關(guān)閉后,就會不見了的矾缓。

3. 封裝函數(shù)增刪改查cookie

其中 removeCookie 的操作就是調(diào)用 setCookie函數(shù)怀酷,將其過期時間設(shè)成 -1 即可。
由于document.cookie 返回的結(jié)果是一個字符串嗜闻,所以查找某個cookie的value蜕依,即函數(shù)getCookie 需要有拆分字符串成數(shù)組這樣的操作。

<body>
    <script>
        document.cookie = 'age=18; max-age=1000';
        document.cookie = 'test=session'; 

        var manageCookie = {
            setCookie: function(name, value, time) {
                document.cookie = name + '=' + value + ';max-age=' + time;
                return this;
            },
            removeCookie: function (name) {
                return this.setCookie(name, '', -1);
            },
            getCookie: function(name, cb) {
                var allCookieArr = document.cookie.split('; ');
                console.log(allCookieArr);
                for (var i = 0; i < allCookieArr.length; i++) {
                    var itemCookieArr = allCookieArr[i].split('=');
                    console.log(itemCookieArr);
                    if (itemCookieArr[0] === name) {
                        cb(itemCookieArr[1]);
                        return this;
                    }
                }
                cb(undefined);
                return this;
            }
        }

        manageCookie
            .setCookie('color', 'pink', 3000)
            .setCookie('id', '7', 5000)
            .removeCookie('age')
            .getCookie('id', function (data) {
                console.log(data);
            })
    </script>
</body>
代碼結(jié)果

代碼結(jié)果

4. Demo

做一個小方塊拖拽琉雳,cookie存儲小方塊位置样眠,頁面關(guān)閉后再次打開時,小方塊能處于上次關(guān)閉時候的位置咐吼。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Cookie Demo</title>
    <style>
        #square {
            position: absolute;
            top: 100px;
            left: 100px;
            width: 100px;
            height: 100px;
            background-color: pink;
        }
    </style>
</head>
<body>
    <div id="square"></div>
    <script>
        var oSquare = document.getElementById('square');

        var manageCookie = {
            setCookie: function(name, value, time) {
                document.cookie = name + '=' + value + ';max-age=' + time;
                return this;
            },
            removeCookie: function (name) {
                return this.setCookie(name, '', -1);
            },
            getCookie: function(name, cb) {
                var allCookieArr = document.cookie.split('; ');
                // console.log(allCookieArr);
                for (var i = 0; i < allCookieArr.length; i++) {
                    var itemCookieArr = allCookieArr[i].split('=');
                    // console.log(itemCookieArr);
                    if (itemCookieArr[0] === name) {
                        cb(itemCookieArr[1]);
                        return this;
                    }
                }
                cb(undefined);
                return this;
            }
        }
        // 拖拽功能
        var drag = {
            init: function(dom) {
                this.dom = dom;
                var _this = this;
                this.bindEvent();
                manageCookie.getCookie('newLeft', function (data) {
                    if (data) {
                        _this.dom.style.left = data + 'px';
                    }
                }).getCookie('newTop', function (data) {
                    if (data) {
                        _this.dom.style.top = data + 'px';
                    }
                })
            },
            bindEvent: function () {
                this.dom.onmousedown = this.mouseDown.bind(this);
            },
            mouseDown: function (e) {
                document.onmousemove = this.mouseMove.bind(this);
                document.onmouseup = this.mouseUp.bind(this);

                this.disX = e.clientX - this.dom.offsetLeft;
                this.disY = e.clientY - this.dom.offsetTop;
            },
            mouseMove: function(e) {
                this.newLeft = e.clientX - this.disX;
                this.newTop = e.clientY - this.disY;
                this.dom.style.left = this.newLeft + 'px';
                this.dom.style.top = this.newTop + 'px';
            },
            mouseUp: function () {
                document.onmousemove = null;
                document.onmouseup = null;
                manageCookie.setCookie('newLeft', this.newLeft, 10000).setCookie('newTop', this.newTop, 10000);
            }
        };

        drag.init(oSquare);
    </script>
</body>
</html>
代碼效果
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吹缔,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子锯茄,更是在濱河造成了極大的恐慌厢塘,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,110評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件肌幽,死亡現(xiàn)場離奇詭異晚碾,居然都是意外死亡,警方通過查閱死者的電腦和手機喂急,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評論 3 395
  • 文/潘曉璐 我一進店門格嘁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人廊移,你說我怎么就攤上這事糕簿√饺耄” “怎么了?”我有些...
    開封第一講書人閱讀 165,474評論 0 356
  • 文/不壞的土叔 我叫張陵懂诗,是天一觀的道長蜂嗽。 經(jīng)常有香客問我,道長殃恒,這世上最難降的妖魔是什么植旧? 我笑而不...
    開封第一講書人閱讀 58,881評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮离唐,結(jié)果婚禮上病附,老公的妹妹穿的比我還像新娘。我一直安慰自己亥鬓,他們只是感情好完沪,可當(dāng)我...
    茶點故事閱讀 67,902評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著嵌戈,像睡著了一般丽焊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上咕别,一...
    開封第一講書人閱讀 51,698評論 1 305
  • 那天,我揣著相機與錄音写穴,去河邊找鬼惰拱。 笑死,一個胖子當(dāng)著我的面吹牛啊送,可吹牛的內(nèi)容都是我干的偿短。 我是一名探鬼主播,決...
    沈念sama閱讀 40,418評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼馋没,長吁一口氣:“原來是場噩夢啊……” “哼昔逗!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起篷朵,我...
    開封第一講書人閱讀 39,332評論 0 276
  • 序言:老撾萬榮一對情侶失蹤勾怒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后声旺,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體笔链,經(jīng)...
    沈念sama閱讀 45,796評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,968評論 3 337
  • 正文 我和宋清朗相戀三年腮猖,在試婚紗的時候發(fā)現(xiàn)自己被綠了鉴扫。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,110評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡澈缺,死狀恐怖坪创,靈堂內(nèi)的尸體忽然破棺而出炕婶,到底是詐尸還是另有隱情,我是刑警寧澤莱预,帶...
    沈念sama閱讀 35,792評論 5 346
  • 正文 年R本政府宣布柠掂,位于F島的核電站,受9級特大地震影響锁施,放射性物質(zhì)發(fā)生泄漏陪踩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,455評論 3 331
  • 文/蒙蒙 一悉抵、第九天 我趴在偏房一處隱蔽的房頂上張望肩狂。 院中可真熱鬧,春花似錦姥饰、人聲如沸傻谁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽审磁。三九已至,卻和暖如春岂座,著一層夾襖步出監(jiān)牢的瞬間态蒂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評論 1 272
  • 我被黑心中介騙來泰國打工费什, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留钾恢,地道東北人。 一個月前我還...
    沈念sama閱讀 48,348評論 3 373
  • 正文 我出身青樓鸳址,卻偏偏與公主長得像瘩蚪,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子稿黍,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,047評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 什么是 Cookie “cookie 是存儲于訪問者的計算機中的變量疹瘦。每當(dāng)同一臺計算機通過瀏覽器請求某個頁面時,就...
    恩德_b0c2閱讀 408評論 0 3
  • 1. cookie 1.1 什么是cookie cookie 是存儲于訪問者的計算機中的變量巡球。每當(dāng)同一臺計算機通過...
    cbw100閱讀 4,060評論 0 13
  • 背景在HTTP協(xié)議的定義中言沐,采用了一種機制來記錄客戶端和服務(wù)器端交互的信息,這種機制被稱為cookie酣栈,cooki...
    時芥藍閱讀 2,366評論 1 17
  • 什么是 Cookie “cookie 是存儲于訪問者的計算機中的變量呢灶。每當(dāng)同一臺計算機通過瀏覽器請求某個頁面時,就...
    小旭同志閱讀 478評論 1 1
  • 吳邪,一個本和整件事情無關(guān)的人奖年,在杭州經(jīng)營著一家小小的古董鋪子细诸,整日過得悠閑自得的小老板的快活日子,卻因為一個帶著...
    女王sama閱讀 2,053評論 1 3