angularjs -- 頁面模板清除

来源:https://www.cnblogs.com/donghuang/archive/2018/07/19/9295026.html
-Advertisement-
Play Games

angularJs模板緩存的清除,包括傳統的 HTML標簽設置清除緩存,以及angularJs的一些配置清除,和angularJs的路由切換操作清除 ...


  前幾天項目在上線過程中,出現了一些新問題。頁面在切換時由於前一個頁面的模板清理不及時,會造成頁面的重疊。導致這個問題的原因是:頁面模板緩存,即上一個頁面退出時,瀏覽器沒有及時清空上一個頁面的模板,導致新頁面載入時,舊頁面模板依然存在,從而頁面出現重疊。

模板緩存清除:

  模板緩存的清除包括傳統的 HTML標簽設置清除緩存,以及angularJs的一些配置清,和angularJs路由切換清除

1、以下是傳統的清除瀏覽器的方法

  HTMLmeta標簽設置清除緩存

<!-- 清除緩存 -->
<meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate" />
<meta http-equiv="Pragma" content="no-cache" />
<meta http-equiv="Expires" content="0" />

  清理form表單臨時緩存

<body onLoad="javascript:document.formName.reset()">

 

2、angularJs配置清除緩存

  1、清除路由緩存,在route路由配置中,註入$httpProvider服務,通過$httpProvider服務配置,清除路由緩存。

app.config(["$stateProvider","$urlRouterProvider",'$locationProvider','$httpProvider',function ($stateProvider, $urlRouterProvider,$locationProvider,$httpProvider) {
    if (!$httpProvider.defaults.headers.get) {
        $httpProvider.defaults.headers.get = {};
    }
    $httpProvider.defaults.headers.common["X-Requested-With"] = 'XMLHttpRequest';
    $httpProvider.defaults.headers.get['Cache-Control'] = 'no-cache';
    $httpProvider.defaults.headers.get['Pragma'] = 'no-cache';
}]);

  2、用隨機數,隨機數也是一種很不錯避免緩存的的方法,即在鏈接 URL 參數後加上隨機數(一般加時間戳) 。用隨機時間,和隨機數一樣。

  3、在狀態路由配置中,將cache配置項,配置為false。

.state("discountCoupon", {
    url: "/discountCoupon",
    templateUrl: "discountCoupon.html?" + new Date().getTime(),    //隨機數
    controller: 'discountCoupon',
    cache: false,    //cache配置
})
.state("customerPhone", {
    url: "/customerPhone",
    templateUrl: "customerPhone.html?" + new Date().getTime(),    //隨機數
    controller: 'customerPhone',
    cache: false,    //cache配置
})

3、angularJs的路由切換清除緩存

angularJs預設 模板載入都會被緩存起來,使用的緩存服務是 $tempalteCache, 發送模板請求的服務是$templateRequest,所以可以在路由切換時將上一個頁面的模板清除:

  1.每次發送 $http 請求模板完成後,可以調用 $tempalteCache.remove(url)  或 $tempalteCache. removeAll 清除所有模板緩存。

$rootScope.$on('$stateChangeStart',     //路由開始切換
    function (event, toState, toParams, fromState, fromParams) {
        //路由開始切換,清除以前所有模板緩存
        if (fromState.templateUrl !== undefined) {
            $templateCache.remove(fromState.templateUrl);
            // $templateCache.removeAll();
        }
    });

$rootScope.$on('$stateChangeSuccess',       //路由切換完成
    function (event, toState, toParams, fromState, fromParams) {
    //路由切換成功,清除上一個頁面模板緩存
    if (fromState.templateUrl !== undefined) {
        $templateCache.remove(fromState.templateUrl);
        // $templateCache.removeAll();
    }
});

  2.使用 $provide.decorator 改寫原生的 $templateRequest (angularJs 自帶 $provide服務里  $templateRequest: $TemplateRequestProvider)服務。在 $TemplateRequestProvider 服務裡面我們可以看到預設使用了 $tempalteCache (本質還是 angularJs 的  $cacheFactory 服務) 服務,

this.$get = ['$templateCache', '$http', '$q', '$sce', function($templateCache, $http, $q, $sce) {
    function handleRequestFn(tpl, ignoreRequestError) {
        handleRequestFn.totalPendingRequests++;

併在獲取模板時,預設以 $templateCache 作為 cache使用,將獲取到的模板數據,添加到 $templateCache內保存。

return $http.get(tpl, extend({
    cache: $templateCache,
    transformResponse: transformResponse
}, httpOptions))
    ['finally'](function () {
    handleRequestFn.totalPendingRequests--;
})
    .then(function (response) {
        $templateCache.put(tpl, response.data);
        return response.data;
    }, handleError);

所以可以通過禁掉緩存,在 $templateRequest 的源碼中將 $tempalteCache去掉,達到清除模板緩存的目的,不過這個一般不建議直接修改框架源代碼!


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

-Advertisement-
Play Games
更多相關文章
  • 動態生成HTML元素的方法有三種: 第一種:document.createElement()創建元素,再用appendChild( )方法將元素添加到指定節點 第二種:使用innerHTML直接將元素添加到指定節點 第三種:jQuery創建節點 jQuery中創建DOM對象,使用jQuery的工廠函 ...
  • 前言 雖然現在已經是ES6的時代,但是,還是有必要瞭解下ES5是怎麼寫一個類的。 本文詳述JavaScript面向對象編程中的類寫法,並分步驟講述如何寫出優雅的類。 一、例子 例子為一個輕提示組件 。 需要實現的功能: 方法,顯示提示 方法,隱藏提示 方法,初始化提示語 二、類的構成 JavaScr ...
  • 結構 Html:html是什麼、html文件結構 html:head html常用標簽學習筆記 html:常見行內標簽,常見塊級標簽,常見可變標簽,常見自閉合標簽,常見屬性, html5常見新增標簽 樣式 html之css選擇器語法學習筆記 html之CSS樣式學習筆記 行為 javascript的... ...
  • 標簽: JavaScript JavaScript有六種數據類型,分別為undefined、null、number、string、Boolean、object,前面的五種是基礎數據類型,也稱之為原始類型,也就是無法再細分的基本類型,object則是複雜數據類型,其中通常是不止一種數據類型,除此之外在 ...
  • 本文主要分享JS中數組的方法封裝,基於原生JS封裝數組slice方法 ...
  • 現在微信已經成為了一個比較好的聊天工具,人們會使用這個工具與周圍的親朋好友進行聯繫,當然也可以和許多的人去進行交流,它的出現已經改變了人們的生活。平時看到比較多的就是很多的朋友拿著微信和他人聊天。但是在使用微信的同時,人們比較擔心的便是自己的微信密碼被破譯掉。生活中很多人想要查看他人的微信聊天記錄, ...
  • 在我們的周邊微信密碼被破譯的情況經常會出現。近日,在網上便有一種關於亂加微信密碼會被破譯的話語存在。事實上,許多人表示自己在加了一些不認識的人的微信之後,人家便可以通過自己的軟體里的自動碰號,然後將微信綁定的銀行卡的密碼給破譯掉,這主要是由於自己設置的微信密碼過於簡單所致。 事實上,近日在網上有很多 ...
  • 這裡主要總結記錄下表格的一些屬性和簡單的樣式,方便以後不時之需。 1、<table> 用來定義HTML的表格,具有本地屬性 border 表示邊框,border屬性的值必須為1或空字元串("")。該屬性不會控制邊框的樣式,而是由CSS來控制 table元素可以有tr,th,td,thead,tbod ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...