离线缓存技术的应用--web-storage-cache(三)

一、关于LocalStorage

优势:

  • localStorage 和 sessionStorage 属性允许在浏览器中存储 key/value 对的数据
  • localStorage 用于长久保存整个网站的数据,保存的数据没有过期时间,直到手动去删除
  • localStorage 拓展了 cookie 的 4K 限制
  • localStorage 会可以将第一次请求的数据直接存储到本地,这个相当于一个 5M 大小的针对于前端页面的数据库,相比于 cookie 可以节约带宽,但是这个却是只有在高版本的浏览器中才支持的

局限:

  • 浏览器的大小不统一,并且在 IE8 以上的 IE 版本才支持 localStorage 这个属性
  • 目前所有的浏览器中都会把localStorage的值类型限定为string类型,这个在对我们日常比较常见的JSON对象类型需要一些转换JSON.parse(json);
  • localStorage在浏览器的隐私模式下面是不可读取的
  • localStorage本质上是对字符串的读取,如果存储内容多的话会消耗内存空间,会导致页面变卡
  • localStorage不能被爬虫抓取到

使用:

if(! window.localStorage){
    alert("浏览器不支持localstorage");
    return false;
}else{
    //主逻辑业务
}

localStorage 其他注意事项:

一般我们会将 JSON 存入 localStorage 中,但是在 localStorage 会自动将 localStorage 转换成为字符串形式。
这个时候我们可以使用 JSON.stringify() 这个方法,来将 JSON 转换成为 JSON 字符串。
实例:

if(!window.localStorage){
    alert("浏览器不支持localstorage");
}else{
    var storage=window.localStorage;
    var data={
        name:'xiecanyong',
        sex:'man',
        hobby:'program'
    };
    var d=JSON.stringify(data);
    storage.setItem("data",d);
    console.log(storage.data);
}

读取之后要将 JSON 字符串转换成为 JSON 对象,使用 JSON.parse() 方法:

var storage=window.localStorage;
var data={
    name:'xiecanyong',
    sex:'man',
    hobby:'program'
};
var d=JSON.stringify(data);
storage.setItem("data",d);
//将JSON字符串转换成为JSON对象输出
var json=storage.getItem("data");
var jsonObj=JSON.parse(json);
console.log(typeof jsonObj);

参考链接:
https://www.runoob.com/jsref/prop-win-localstorage.html

二、关于web-storage-cache

此项目中使用web-storage-cache
https://www.npmjs.com/package/web-storage-cache
在这里插入图片描述
由于已经封装了方法,默认为JSON.stringify以及JSON.parse,所以可以直接使用set、get方法来进行操作。

三、封装localStorage

1.引入Local Storage

cnpm i --save web-storage-cache

2.安装完成后在utils目录下创建localStorage.js通用方法

import Storage from 'web-storage-cache'

const localStorage=new Storage()

//localStorage的封装

export function setLocalStorage(key,value){
    return localStorage.set(key,value);
}

export function  getLocalStorage(key) {
    return localStorage.get(key);
}

export function removeLocalStorage(key) {
    return localStorage.delete(key);
}

//全部清空
export function clearLocalStorage() {
    return localStorage.clear();
}

3.页面引入

import {
  setLocalStorage,
  getLocalStorage,
  removeLocalStorage,
  clearLocalStorage
} from "./../../utils/localStorage";

四、实现具体的业务代码

1.继续在localStorage.js中封装书这个对象

export function setBookObject(filename,key,value) {
    let book=getLocalStorage(`${filename}-info`);
    if(!book){
        book={};
    }
    book[key]=value;
    setLocalStorage(`${filename}-info`,book)
}

export function getBookObject(filename,key) {
    let book = getLocalStorage(`${filename}-info`);
    if (book) {
        return book[key];
    }
    else{
        return null;
    }
}

2.离线缓存字体

在localStorage.js中写出关于缓存字体的通用方法

//保存字体
export function saveFontFamily(filename, font) {
    return setBookObject(filename, 'fontFamily',font)
}
//获取字体
export function getFontFamily(filename) {
    return getBookObject(filename, 'fontFamily')
}

EbookSettingFontPopup.vue设置字体组件

import { saveFontFamily} from "./../../utils/localStorage";
  selectFamily(item) {
       saveFontFamily(this.filename,item.font);
      this.setDefaultFontFamily(item.font);
      this.setFontFamilyVisible(false);
      if (item.font === "Default") {
        this.currentBook.rendition.themes.font("Times New Roman");
      } else {
        this.currentBook.rendition.themes.font(item.font);
      }
    },

然后在EbookReader.vue组件中初始化字体

 this.rendition.display().then(() => {
        let fontfamily = getFontFamily(this.filename);
        if (fontfamily) {
          this.currentBook.rendition.themes.font(fontfamily);
          this.setDefaultFontFamily(fontfamily);
        }else{
          saveFontFamily(this.filename, this.defaultFontFamily);
        }
      });

3.离线缓存字号

同2中缓存字体,在localStorage.js中写出关于缓存字号的通用方法

//保存字体大小
export function saveFontSize(filename, fontSize) {
    return setBookObject(filename,'fontSize',fontSize);
}
//获取字体大小
export function getFontSize(filename) {
    return getBookObject(filename,'fontSize');
}

EbookSettingFont.vue组件中设置字体大小

import { saveFontSize } from "./../../utils/localStorage";
setFontSize(key){
      this.currentBook.rendition.themes.fontSize(key);
      this.setDefaultFontSize(key);
      saveFontSize(this.filename,key);
    },

然后在EbookReader.vue组件中初始化字号

import { saveFontFamily, getFontFamily,saveFontSize, getFontSize } from "./../../utils/localStorage";
let fontSize = getFontSize(this.filename);
 if (fontSize) {
          this.currentBook.rendition.themes.fontSize(fontSize);
          this.setDefaultFontSize(fontSize);
        } else {
          saveFontSize(this.filename, this.defaultFontSize);
        }

参考链接(侵删):
https://blog.csdn.net/weixin_43756060/article/details/88702581

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
<?php /**  * @link      http://github.com/zendframework/zend-cache for the canonical source repository  * @copyright Copyright (c) 2005-2016 Zend Technologies USA Inc. (http://www.zend.com)  * @license   http://framework.zend.com/license/new-bsd New BSD License  */ namespace Zend\Cache; class ConfigProvider {     /**      * Return default configuration for zend-cache.      *      * @return array      */     public function __invoke()     {         return [             'dependencies' => $this->getDependencyConfig(),         ];     }     /**      * Return default service mappings for zend-cache.      *      * @return array      */     public function getDependencyConfig()     {         return [             'abstract_factories' => [                 Service\StorageCacheAbstractServiceFactory::class,             ],             'factories' => [                 PatternPluginManager::class => Service\PatternPluginManagerFactory::class,                 Storage\AdapterPluginManager::class => Service\StorageAdapterPluginManagerFactory::class,                 Storage\PluginManager::class => Service\StoragePluginManagerFactory::class,             ],         ];     } }大家在使用PHP的过程中,会考虑到很重要的一点就是安全性问题。那么,今天我们就来为大家介绍保证PHP安全的首要措施验证类库,数据的验证是您可能采用的最重要的习惯。而在提及输入时,十分简单:不要相信用户。在保证PHP安全而进行验证数据时,记住设计并验证应用程序允许使用的值通常比防止所有未知值更容易。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

echo忘川

谢谢老板们

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值