search
HomeWeb Front-endJS TutorialPure js realizes local storage with unlimited space_javascript skills

It’s been a long time since I’ve written a blog. I thought that even though I promised to release the source code 2 years ago, I finally had time to open source the function of local storage with unlimited space using pure JS.

Project addresshttps://github.com/xueduany/localstore,

Demo seehttp://xueduany.github.io/localstore/,

Let me give you a brief introduction to the general principle. The specific details and exception handling will be discussed separately later when I have the opportunity

First let’s talk about the principle of breaking through localStorage. The official words are as follows http://www.w3.org/TR/2013/PR-webstorage-20130409/

So you know, you can take advantage of the fact that localStorage of multiple subdomains does not depend on each other to design and implement a storePool through localStorage of multiple subdomains, breaking the upper limit

Then, when the actual API is stored, it is not saved in localStorage

This is a bit similar to a Manager mode, that is, you tell the warehouse manager what you want to save, the warehouse manager gives you a key, and then you take the key to the corresponding warehouse to host your things, and the manager then gives you You have a token certificate. In the future, you only need to hold this certificate to take out the saved things

The end user does not need to care where my data is stored, as long as it implements an API similar to localStorage

Then design a js object to act as a warehouse administrator. How many tokens does this administrator need to support? Where should the corresponding saved things be stored? That is, in the space under which subdomain name it should be stored. Then we It is necessary to design and implement such a set of data structures

Below the corresponding key is the address of the warehouse where it exists, and the storage time. The concept of storage time is used to calculate the freshness of the data, that is, to calculate whether it has expired

So we first need to create multiple iframes to load proxy files under multiple domain names, interact with each other through HTML5 api postMessage or the old page cross-domain method, and save data through the proxy of this proxy

Save the stub of the data key under the current main domain name, and then save the actual data under each subdomain name

Ok, now that the storage limit has been exceeded, if we want to save a webpage, we must consider pulling down all the static resources related to the webpage. For webpage-related resources, including js, css, these are all text, these It's all simple. As long as an ajax request is made, you can get the content. The only thing to consider is security. Cross-domain issues cause js to not get the response data. Here you only need to set the response header to

on the CDN node server.

That’s it, get the content across domains

js, that is, can be changed to <script>the content obtained remotely</script>, css, Just change this to

Here we only need to consider the code blocks that can match the original HTML. We only need to consider one problem, that is, the regexp of js is greedy mode by default, so our regular expression must achieve the minimum match,

Then find the corresponding content in the html and replace it with the content already saved in localStorage

So for pictures, how to get the content of the picture? We know that the picture is rawdata, binary. First we have to solve the problem of obtaining the binary stream of the picture

Then convert it directly to base64 through fileReader, which can be saved locally, and then replace the src of the image from a url to a base64 string

Then replace the corresponding resources in the entire web page html with our special tags

LOCALSTORE tag, and then use a recursive search algorithm to obtain content from each sub-store and restore it to the original complete html

Then restore the original page directly through document.write

Through this principle, you can take a website offline and localize it, and then use singlePage technology to achieve browsing without sending any requests. Of course, there are some other technical details that need to be dealt with. What are they? Damn it, let me break it down next time! ! !

The above is the entire content of this article, I hope you all like it.

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
如何使用JS和百度地图实现地图平移功能如何使用JS和百度地图实现地图平移功能Nov 21, 2023 am 10:00 AM

如何使用JS和百度地图实现地图平移功能百度地图是一款广泛使用的地图服务平台,在Web开发中经常用于展示地理信息、定位等功能。本文将介绍如何使用JS和百度地图API实现地图平移功能,并提供具体的代码示例。一、准备工作使用百度地图API前,首先需要在百度地图开放平台(http://lbsyun.baidu.com/)上申请一个开发者账号,并创建一个应用。创建完成

js字符串转数组js字符串转数组Aug 03, 2023 pm 01:34 PM

js字符串转数组的方法:1、使用“split()”方法,可以根据指定的分隔符将字符串分割成数组元素;2、使用“Array.from()”方法,可以将可迭代对象或类数组对象转换成真正的数组;3、使用for循环遍历,将每个字符依次添加到数组中;4、使用“Array.split()”方法,通过调用“Array.prototype.forEach()”将一个字符串拆分成数组的快捷方式。

如何使用JS和百度地图实现地图热力图功能如何使用JS和百度地图实现地图热力图功能Nov 21, 2023 am 09:33 AM

如何使用JS和百度地图实现地图热力图功能简介:随着互联网和移动设备的迅速发展,地图成为了一种普遍的应用场景。而热力图作为一种可视化的展示方式,能够帮助我们更直观地了解数据的分布情况。本文将介绍如何使用JS和百度地图API来实现地图热力图的功能,并提供具体的代码示例。准备工作:在开始之前,你需要准备以下事项:一个百度开发者账号,并创建一个应用,获取到相应的AP

如何使用JS和百度地图实现地图多边形绘制功能如何使用JS和百度地图实现地图多边形绘制功能Nov 21, 2023 am 10:53 AM

如何使用JS和百度地图实现地图多边形绘制功能在现代网页开发中,地图应用已经成为常见的功能之一。而地图上绘制多边形,可以帮助我们将特定区域进行标记,方便用户进行查看和分析。本文将介绍如何使用JS和百度地图API实现地图多边形绘制功能,并提供具体的代码示例。首先,我们需要引入百度地图API。可以利用以下代码在HTML文件中导入百度地图API的JavaScript

js中new操作符做了哪些事情js中new操作符做了哪些事情Nov 13, 2023 pm 04:05 PM

js中new操作符做了:1、创建一个空对象,这个新对象将成为函数的实例;2、将新对象的原型链接到构造函数的原型对象,这样新对象就可以访问构造函数原型对象中定义的属性和方法;3、将构造函数的作用域赋给新对象,这样新对象就可以通过this关键字来引用构造函数中的属性和方法;4、执行构造函数中的代码,构造函数中的代码将用于初始化新对象的属性和方法;5、如果构造函数中没有返回等等。

用JavaScript模拟实现打字小游戏!用JavaScript模拟实现打字小游戏!Aug 07, 2022 am 10:34 AM

这篇文章主要为大家详细介绍了js实现打字小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。

php可以读js内部的数组吗php可以读js内部的数组吗Jul 12, 2023 pm 03:41 PM

php在特定情况下可以读js内部的数组。其方法是:1、在JavaScript中,创建一个包含需要传递给PHP的数组的变量;2、使用Ajax技术将该数组发送给PHP脚本。可以使用原生的JavaScript代码或者使用基于Ajax的JavaScript库如jQuery等;3、在PHP脚本中,接收传递过来的数组数据,并进行相应的处理即可。

js是什么编程语言?js是什么编程语言?May 05, 2019 am 10:22 AM

js全称JavaScript,是一种具有函数优先的轻量级,直译式、解释型或即时编译型的高级编程语言,是一种属于网络的高级脚本语言;JavaScript基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式和声明式,如函数式编程。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!