欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

前端存儲(chǔ)后端響應(yīng)數(shù)據(jù)超詳細(xì)的實(shí)現(xiàn)方式和注意事項(xiàng)

 更新時(shí)間:2025年03月27日 11:58:29   作者:z2637305611  
前端通過(guò)多種方式向后端獲取數(shù)據(jù),下面這篇文章主要介紹了前端存儲(chǔ)后端響應(yīng)數(shù)據(jù)超詳細(xì)的實(shí)現(xiàn)方式和注意事項(xiàng),文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

在前端存儲(chǔ)后端響應(yīng)數(shù)據(jù)是常見(jiàn)需求,可以優(yōu)化性能(減少重復(fù)請(qǐng)求)、支持離線訪問(wèn)或提升用戶體驗(yàn)。以下是超詳細(xì)的實(shí)現(xiàn)方式和注意事項(xiàng):

一、前端存儲(chǔ)后端數(shù)據(jù)的核心步驟

1. 獲取后端數(shù)據(jù)

使用 fetch 或 axios 發(fā)送請(qǐng)求:

<JAVASCRIPT>

// 使用 fetch
fetch('https://api.example.com/data')
  .then(response => response.json())
  .then(data => saveData(data))
  .catch(err => console.error('請(qǐng)求失敗:', err));

// 或使用 async/await
async function fetchData() {
  try {
    const response = await fetch('https://api.example.com/data');
    const data = await response.json();
    saveData(data);
  } catch (error) {
    console.error('請(qǐng)求失敗:', error);
  }
}

2. 存儲(chǔ)數(shù)據(jù)

根據(jù)數(shù)據(jù)量、訪問(wèn)頻率和緩存策略選擇合適的存儲(chǔ)方式:

二、前端存儲(chǔ)技術(shù)的選擇

1. 短期緩存(會(huì)話級(jí)別)

(1) sessionStorage

  • 特點(diǎn):會(huì)話級(jí)存儲(chǔ),關(guān)閉標(biāo)簽頁(yè)后失效。
  • 適用場(chǎng)景:臨時(shí)保存需要跨頁(yè)面使用的敏感信息。
  • 代碼示例

    <JAVASCRIPT>

    // 存儲(chǔ)
    const data = { userId: 123, token: 'abcdef' };
    sessionStorage.setItem('sessionData', JSON.stringify(data));
    
    // 讀取
    const sessionData = JSON.parse(sessionStorage.getItem('sessionData'));

2. 長(zhǎng)期緩存(持久化存儲(chǔ))

(1) localStorage

  • 特點(diǎn):數(shù)據(jù)永久存儲(chǔ),需手動(dòng)清除,單域名容量約 5MB。
  • 適用場(chǎng)景:緩存基礎(chǔ)配置、用戶偏好等非敏感數(shù)據(jù)。
  • 代碼示例

    <JAVASCRIPT>

    // 存儲(chǔ)
    const userPrefs = { theme: 'dark', language: 'zh-CN' };
    localStorage.setItem('userPrefs', JSON.stringify(userPrefs));
    
    // 讀取時(shí)處理異常
    try {
      const prefs = JSON.parse(localStorage.getItem('userPrefs'));
    } catch (e) {
      console.error('解析失敗:', e);
      localStorage.removeItem('userPrefs'); // 清理?yè)p壞數(shù)據(jù)
    }

(2) IndexedDB

  • 特點(diǎn):支持存儲(chǔ)大量結(jié)構(gòu)化數(shù)據(jù)(上限約 50% 硬盤空間),支持事務(wù)、索引。
  • 適用場(chǎng)景:緩存復(fù)雜數(shù)據(jù)集(如用戶歷史操作)、離線應(yīng)用。
  • 代碼示例

    <JAVASCRIPT>

    // 打開(kāi)或創(chuàng)建數(shù)據(jù)庫(kù)
    const request = indexedDB.open('MyAppDB', 1);
    
    request.onupgradeneeded = (event) => {
      const db = event.target.result;
      if (!db.objectStoreNames.contains('userData')) {
        db.createObjectStore('userData', { keyPath: 'id' });
      }
    };
    
    request.onsuccess = (event) => {
      const db = event.target.result;
      const transaction = db.transaction('userData', 'readwrite');
      const store = transaction.objectStore('userData');
    
      // 存儲(chǔ)數(shù)據(jù)
      store.put({ id: 1, name: 'John', orders: [123, 456] });
    };

3. 內(nèi)存緩存

(1) 全局變量或狀態(tài)管理(Vuex、Redux)

  • 特點(diǎn):數(shù)據(jù)僅在頁(yè)面刷新前有效,響應(yīng)速度快。
  • 適用場(chǎng)景:高頻訪問(wèn)的共享狀態(tài)(如用戶登錄信息)。
  • 代碼示例(Redux)

    <JAVASCRIPT>

    // Action
    const fetchUserData = () => async (dispatch) => {
      const data = await fetch('/api/user');
      dispatch({ type: 'SET_USER_DATA', payload: data });
    };
    
    // Reducer
    const initialState = { userData: null };
    const reducer = (state = initialState, action) => {
      switch (action.type) {
        case 'SET_USER_DATA':
          return { ...state, userData: action.payload };
        default:
          return state;
      }
    };

三、緩存策略進(jìn)階

1. 為存儲(chǔ)數(shù)據(jù)添加元信息

存儲(chǔ)數(shù)據(jù)時(shí)附加時(shí)間戳或版本號(hào),便于后續(xù)驗(yàn)證有效性:

<JAVASCRIPT>

const cacheEntry = {
  data: { /* 后端返回的數(shù)據(jù) */ },
  timestamp: new Date().getTime(),
  version: '1.0.2',
};
localStorage.setItem('cachedData', JSON.stringify(cacheEntry));

2. 緩存失效策略

  • 基于時(shí)間:設(shè)置有效期(如緩存 1 小時(shí)):

    <JAVASCRIPT>

    const CACHE_EXPIRY = 3600 * 1000; // 1小時(shí)
    
    function isCacheValid(cachedData) {
      return (Date.now() - cachedData.timestamp) < CACHE_EXPIRY;
    }
  • 基于版本:當(dāng)后端數(shù)據(jù)結(jié)構(gòu)變更時(shí)強(qiáng)制更新:

    <JAVASCRIPT>

    const API_VERSION = '2.3.0';
    
    function checkCacheVersion(cachedData) {
      return cachedData.version === API_VERSION;
    }

四、完整示例:結(jié)合緩存的請(qǐng)求邏輯

<JAVASCRIPT>

async function fetchDataWithCache() {
  // 檢查是否有有效緩存
  const cachedData = JSON.parse(localStorage.getItem('cachedData'));
  if (cachedData && isCacheValid(cachedData)) {
    return cachedData.data; // 直接使用緩存
  }

  // 沒(méi)有有效緩存則發(fā)起請(qǐng)求
  try {
    const response = await fetch('https://api.example.com/data');
    const freshData = await response.json();

    // 更新緩存
    const newCache = {
      data: freshData,
      timestamp: Date.now(),
      version: API_VERSION,
    };
    localStorage.setItem('cachedData', JSON.stringify(newCache));

    return freshData;
  } catch (error) {
    console.error('請(qǐng)求失敗:', error);
    if (cachedData) return cachedData.data; // 降級(jí)使用舊數(shù)據(jù)
    throw error;
  }
}

五、關(guān)鍵注意事項(xiàng)

1. 安全性

  • 絕對(duì)不要存儲(chǔ)敏感數(shù)據(jù)(如密碼、支付信息),即使使用 localStorage 也不安全。
  • 使用 HTTP Only Cookies :涉及身份驗(yàn)證的 Token 應(yīng)通過(guò)安全 Cookie 傳輸。

2. 序列化與反序列化

  • localStorage 只能存儲(chǔ)字符串,存儲(chǔ)對(duì)象需用 JSON.stringify
  • 解析時(shí)使用 try/catch 防止 JSON 格式錯(cuò)誤導(dǎo)致頁(yè)面崩潰:

    <JAVASCRIPT>

    try {
      const data = JSON.parse(localStorage.getItem('data'));
    } catch (e) {
      console.error('解析失敗:', e);
    }

3. 存儲(chǔ)上限

存儲(chǔ)方式容量限制
localStorage約 5MB(不同瀏覽器差異)
IndexedDB一般不少于 250MB
Cookies每個(gè)域名約 4KB

4. 隱私模式兼容

  • 部分瀏覽器隱私模式下會(huì)禁用 localStorage,需做好錯(cuò)誤處理:

    <JAVASCRIPT>

    function isLocalStorageAvailable() {
      try {
        localStorage.setItem('test', 'test');
        localStorage.removeItem('test');
        return true;
      } catch (e) {
        return false;
      }
    }

六、高級(jí)場(chǎng)景

1. Service Worker 緩存

配合 Cache API 實(shí)現(xiàn)離線優(yōu)先策略:

<JAVASCRIPT>

// service-worker.js
self.addEventListener('fetch', (event) => {
  event.respondWith(
    caches.match(event.request)
      .then(cachedResponse => cachedResponse || fetch(event.request))
  );
});

2. 數(shù)據(jù)加密

提升敏感信息存儲(chǔ)安全性(需結(jié)合 HTTPS):

<JAVASCRIPT>

import CryptoJS from 'crypto-js';

const SECRET_KEY = 'your-secret-key';

// 加密存儲(chǔ)
const encryptedData = CryptoJS.AES.encrypt(
  JSON.stringify(data),
  SECRET_KEY
).toString();
localStorage.setItem('encryptedData', encryptedData);

// 解密讀取
const bytes = CryptoJS.AES.decrypt(encryptedData, SECRET_KEY);
const originalData = JSON.parse(bytes.toString(CryptoJS.enc.Utf8));

通過(guò)合理利用前端存儲(chǔ)技術(shù),可以顯著提升應(yīng)用性能,但需權(quán)衡安全性、數(shù)據(jù)一致性和用戶體驗(yàn)。在實(shí)踐中需結(jié)合具體場(chǎng)景選擇最佳方案。

總結(jié)

到此這篇關(guān)于前端存儲(chǔ)后端響應(yīng)數(shù)據(jù)的文章就介紹到這了,更多相關(guān)前端存儲(chǔ)后端響應(yīng)數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JSON字符串和JSON對(duì)象相互轉(zhuǎn)化實(shí)例詳解

    JSON字符串和JSON對(duì)象相互轉(zhuǎn)化實(shí)例詳解

    這篇文章主要介紹了JSON字符串和JSON對(duì)象相互轉(zhuǎn)化方法,結(jié)合實(shí)例形式詳細(xì)分析了json對(duì)象與字符串的功能、使用、轉(zhuǎn)換方法及相關(guān)注意事項(xiàng),需要的朋友可以參考下
    2017-01-01
  • js實(shí)現(xiàn)頁(yè)面多個(gè)日期時(shí)間倒計(jì)時(shí)效果

    js實(shí)現(xiàn)頁(yè)面多個(gè)日期時(shí)間倒計(jì)時(shí)效果

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)頁(yè)面多個(gè)日期時(shí)間倒計(jì)時(shí)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • Bootstrap實(shí)現(xiàn)模態(tài)框效果

    Bootstrap實(shí)現(xiàn)模態(tài)框效果

    這篇文章主要為大家詳細(xì)介紹了Bootstrap實(shí)現(xiàn)模態(tài)框效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • 不錯(cuò)的asp中顯示新聞的功能

    不錯(cuò)的asp中顯示新聞的功能

    不錯(cuò)的asp中顯示新聞的功能...
    2006-10-10
  • JS中利用swiper實(shí)現(xiàn)3d翻轉(zhuǎn)幻燈片實(shí)例代碼

    JS中利用swiper實(shí)現(xiàn)3d翻轉(zhuǎn)幻燈片實(shí)例代碼

    大家都知道Swiper(Swiper master)是目前應(yīng)用較廣泛的移動(dòng)端網(wǎng)頁(yè)觸摸內(nèi)容滑動(dòng)js插件。下面這篇文章主要給大家介紹了在JS中利用swiper實(shí)現(xiàn)3d翻轉(zhuǎn)幻燈片的相關(guān)資料,文中給出了完整的示例代碼供大家參考學(xué)習(xí),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-08-08
  • Webpack之plugin的使用

    Webpack之plugin的使用

    本文主要介紹了Webpack之plugin的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • Windows下支持自動(dòng)更新的Electron應(yīng)用腳手架的方法

    Windows下支持自動(dòng)更新的Electron應(yīng)用腳手架的方法

    這篇文章主要介紹了Windows下支持自動(dòng)更新的Electron應(yīng)用腳手架的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • 微信小程序?qū)W習(xí)總結(jié)(三)條件、模板、文件引用實(shí)例分析

    微信小程序?qū)W習(xí)總結(jié)(三)條件、模板、文件引用實(shí)例分析

    這篇文章主要介紹了微信小程序條件、模板、文件引用,結(jié)合實(shí)例形式分析了微信小程序if條件判斷、模板調(diào)用、wxss文件引用等相關(guān)操作技巧,需要的朋友可以參考下
    2020-06-06
  • cropperjs實(shí)現(xiàn)裁剪圖片功能

    cropperjs實(shí)現(xiàn)裁剪圖片功能

    這篇文章主要為大家詳細(xì)介紹了cropperjs實(shí)現(xiàn)裁剪圖片功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • JavaScript實(shí)現(xiàn)簡(jiǎn)單計(jì)算器

    JavaScript實(shí)現(xiàn)簡(jiǎn)單計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03

最新評(píng)論