cookie的初識和運用(js和jq)

来源:http://www.cnblogs.com/chendc/archive/2016/04/07/5360253.html
-Advertisement-
Play Games

cookie是什麼 cookie是瀏覽器提供的一種機制,它將document 對象的cookie屬性提供給JavaScript。可以由JavaScript對其進行控制,而並不是JavaScript本身的性質。cookie是存於用戶硬碟的一個文件,這個文件通常對應於一個功能變數名稱,當瀏覽器再次訪問這個功能變數名稱時 ...


 

cookie是什麼


cookie是瀏覽器提供的一種機制,它將document 對象的cookie屬性提供給JavaScript。可以由JavaScript對其進行控制,而並不是JavaScript本身的性質。cookie是存於用戶硬碟的一個文件,這個文件通常對應於一個功能變數名稱,當瀏覽器再次訪問這個功能變數名稱時,便使這個cookie可用。因此,cookie可以跨越一個功能變數名稱下的多個網頁,但不能跨越多個功能變數名稱使用。

cookie使用場合


(1)保存用戶登錄狀態。例如將用戶id存儲於一個cookie內,這樣當用戶下次訪問該頁面時就不需要重新登錄了,現在很多論壇和社區都提供這樣的功能。 cookie還可以設置過期時間,當超過時間期限後,cookie就會自動消失。因此,系統往往可以提示用戶保持登錄狀態的時間:常見選項有一個月、三個 月、一年等。 

(2)跟蹤用戶行為。例如一個天氣預報網站,能夠根據用戶選擇的地區顯示當地的天氣情況。如果每次都需要選擇所在地是煩瑣的,當利用了 cookie後就會顯得很人性化了,系統能夠記住上一次訪問的地區,當下次再打開該頁面時,它就會自動顯示上次用戶所在地區的天氣情況。因為一切都是在後 台完成,所以這樣的頁面就像為某個用戶所定製的一樣,使用起來非常方便。 

(3)定製頁面。如果網站提供了換膚或更換佈局的功能,那麼可以使用cookie來記錄用戶的選項,例如:背景色、解析度等。當用戶下次訪問時,仍然可以保存上一次訪問的界面風格。

 

cookie的用法


 

js方式:

 

function setCookie(sName, sValue, oExpires, sPath, sDomain, bSecure) { //js設置cookie 
                var sCookie = sName + '=' + encodeURIComponent(sValue);  
                 if (oExpires) {  
                     var date = new Date();  
                     date.setTime(date.getTime() + oExpires * 60 * 60 * 1000);  
                     sCookie += '; expires=' + date.toUTCString();  
                }  
                if (sPath) {  
                     sCookie += '; path=' + sPath;  
                if (sDomain) {  
                     sCookie += '; domain=' + sDomain;  
                }  
                 if (bSecure) {  
                     sCookie += '; secure';  
                }  
                 document.cookie = sCookie;  
}
    function getCookie(name){ //獲取cookie
        var strCookie=document.cookie; 
        var arrCookie=strCookie.split("; "); 
        for(var i=0;i<arrCookie.length;i++){ 
        var arr=arrCookie[i].split("="); 
            if(arr[0]==name){
return decodeURIComponent(arr[1]);
} }
return ""; }

 

function delCookie(name){//刪除cookie
// 該函數檢查下cookie是否設置,如果設置了則將過期時間調到過去的時間;
//剩下就交給操作系統適當時間清理cookie啦
if (getCookie(name))
    {
            document.cookie = name + "=" + "; expires=Thu, 01-Jan-70 00:00:01 GMT";
    }
}
                    

 

jq插件方式:

jq官網http://plugins.jquery.com/搜索cookie插件,幾k的大小,使用非常方便:

  <script type="text/javascript" src="js/jquery.js"></script>
  <script type="text/javascript" src="js/jquery.cookie.js"></script>

 

在引入以上庫文件後,使用方式如下:

  <script>
        $.cookie('the_cookie'); //讀取Cookie值 
        $.cookie('the_cookie', 'the_value'); //設置cookie的值 
        $.cookie('the_cookie', 'the_value', {expires: 7, path: '/', domain: 'jquery.com', secure: true});//新建一個cookie 包括有效期 路徑 功能變數名稱等 
        $.cookie('the_cookie', 'the_value'); //新建cookie 
        $.cookie('the_cookie', null); //刪除一個cookie 
  </script>

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一.攔截器與過濾器的區別: 1.filter基於回調函數,我們需要實現的filter介面中doFilter方法就是回調函數,而interceptor則基於Java本身的反射機制,這是兩者最本質的區別。 2.filter是依賴於servlet容器的,即只能在servlet容器中執行,很顯然沒有serv ...
  • 獲取【下載地址】 QQ: 313596790 【免費支持更新】三大資料庫 mysql oracle sqlsever 更專業、更強悍、適合不同用戶群體【新錄針對本系統的視頻教程,手把手教開發一個模塊,快速掌握本系統】A 集成代碼生成器(開發利器); 技術:313596790 增刪改查的處理類,ser ...
  • 適配器模式(Adapter) 適配器模式有兩種形式:類的適配器模式和對象的適配器模式。 一、類的適配器模式 類圖 描述 類的適配器模式: Target,目標介面,可以是具體的或抽象的類,也可以是介面; Adaptee,需要適配的類; Adapter,適配器類,把源介面轉換成目標介面;Adapter類 ...
  • 我們可以試驗一下,JS類的繼承 children.constructor==father 返回的是true,而原型繼承children.constructor==father 返回的是false; ...
  • 1.解決HTML頁面中的中文問題: 為了使HTML頁面很好地支持中文,就必須在每個HTML頁面的頭部增加如下代碼: <HEAD> ... <META http-equiv=Content-Type content="text/html;charset=gb2312"> ... <HEAD> 2.解決 ...
  • 本文內容 Angular JS 實現模式對話框。基於 AngularJS v1.5.3 和 Bootstrap v3.3.6。 項目結構 圖 1 項目結構 運行結果 圖 1 運行結果:大模態 index.html Angul... ...
  • 本文要介紹的是網頁中常見的圖片上傳後直接在頁面生成小圖預覽的實現思路,考慮到該功能有一定的適用性,於是把相關的邏輯封裝成了一個ImageUploadView組件,實際使用效果可查看下一段的git效果圖。在實現這個組件的過程中,有用到前面幾篇博客介紹的相關內容,比如繼承庫class.js,任意組件的事... ...
  • × 目錄 [1]坐標軸 [2]透視 [3]變形函數 [4]透視函數 [5]變形原點 [6]背景可見 [7]變形風格 前面的話 本文將詳細介紹關於transform變形3D的內容,但需以瞭解transform變形2D為基礎。3D變形涉及的屬性主要是transform-origin、transform、 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...