Heim > Web-Frontend > H5-Tutorial > Verwandte Erklärungen zum lokalen HTML5-Speicher

Verwandte Erklärungen zum lokalen HTML5-Speicher

jacklove
Freigeben: 2018-06-11 16:59:30
Original
1703 Leute haben es durchsucht

Empfehlung des Herausgebers: Dieser Artikel stammt vom Hacker Magazine. Er bietet eine sehr umfassende Einführung und Analyse der Speichermethode von HTML5. Für Entwickler, die HTML5 erlernen, sollte er nicht fehlen.
VerlaufWenn wir vor der lokalen Speicherung von HTML5 persistente Daten auf dem Client speichern wollten, gab es mehrere Optionen:

  1. HTTP-Cookie. Die Nachteile von HTTP-Cookies liegen auf der Hand: Sie können nur bis zu 4 KB Daten speichern und jede HTTP-Anfrage wird im Klartext an den Server zurückgesendet (es sei denn, Sie verwenden SSL).

  2. IE-Benutzerdaten. userData ist eine lokale Speicherlösung, die von Microsoft während der Browserkriege der 1990er Jahre eingeführt wurde. Sie nutzt das Verhaltensattribut von DHTML, um bis zu 64 KB Daten zu speichern Die Mängel von userData liegen auf der Hand. Es ist nicht Teil der Webstandards. Wenn Ihre Anwendung also nicht nur den IE unterstützen muss, ist es von geringem Nutzen.

  3. Flash-Cookie. Der Name des Flash-Cookies ist eigentlich nicht dasselbe wie der Name „Flash Local Storage“. es überschreitet, Flash Es fordert automatisch mehr Speicherplatz vom Benutzer an. Mithilfe der ExternalInterface-Schnittstelle von Flash können Sie den lokalen Speicher von Flash problemlos über Javascript bedienen. Das Problem mit Flash ist einfach, dass es Flash ist.

  4. Google Gears. Gears ist ein Open-Source-Browser-Plugin, das 2007 von Google veröffentlicht wurde und darauf abzielt, die Kompatibilität mit den wichtigsten Browsern zu verbessern. Gears verfügt über eine integrierte SQLite-Datenbank und bietet Benutzern eine einheitliche API für den Zugriff auf die Datenbank Mit der Autorisierung kann jede Site Daten beliebiger Größe in der SQL-Datenbank speichern. Das Problem bei Gears ist, dass Google selbst diese nicht mehr verwendet.

Aktuelle SituationWas wir normalerweise als lokalen HTML5-Speicher bezeichnen, bezieht sich jetzt allgemein auf Web Speicherspezifikation , dieser Standard war einst Teil der HTML5-Spezifikation, wurde aber später aus verschiedenen Gründen von der HTML5-Spezifikation getrennt. Doch neben Web Storage gibt es noch zwei weitere Konkurrenten für den lokalen Speicherstandard von HTML5: Web SQL Database und IndexedDB. Schauen wir uns diese 3 Spezifikationen der Reihe nach an.
Web StorageWeb Storage ist derzeit die am häufigsten unterstützte lokale HTML5-Speicherspezifikation: IE 8+, FF 3.5+, Safari 4+, Chrome 4+, Opera 10.5+, sowie iPhone 2+ und Android 2+ unterstützen bereits Web Storage. Um festzustellen, ob Ihr Browser Web Storage unterstützt, können Sie die folgende Funktion verwenden:

Code

  1. function supports_html5_storage() {  
        try {  
            return 'localStorage' in window && window['localStorage'] !== null;  
        } catch (e) {  
            return false;  
        }  
    }
    Nach dem Login kopieren


HTML5-Speicher ist sehr einfach zu verwenden:

Code

  1. var foo = localStorage.getItem("bar");  
    // ...  
    localStorage.setItem("bar", foo);
    Nach dem Login kopieren


你也可以写成下面这样:

代码

  1. var foo = localStorage["bar"];  
    // ...  
    localStorage["bar"] = foo;
    Nach dem Login kopieren


如果要将某个key从存储空间删除,可以调用removeItem:

代码

  1. localStorage.removeItem(
    'foo'
    );
    Nach dem Login kopieren


你也可以像遍历数组那样遍历存储的所有键值对象:

代码

  1. for(var i=0; ivar key = localStorage.key(i);  
        console.log(key + ":" + localStorage[key]);  
    }
    Nach dem Login kopieren


如果你的程序需要在不同页面访问同一个值,你可能需要了解这个值是否已经被其他页面改变了,这可以通过向浏览器注册storage事件来实现:

代码

  1. window.addEventListener('storage', function(e) {  
        console.log(e.key + "'s value is changed from '" +  
            e.oldValue + "' to '" + e.newValue + "' by " + e.url);  
    }, false);  
    //A页面  
    localStorage['foo'] = 'bar';  
    //B页面  
    localStorage['foo'] = 'newBar';
    Nach dem Login kopieren


这时你应该会在A页面的Console中看到:
foo’s value is changed from ‘bar’ to ‘newbar’ by http://localhost/test.html
要注意的是,storage事件仅仅只是通知你某个键对应的值已经发生了改变,你没有办法在回调中阻止这个改变发生。
HTML5 Storage看起来不错,那它有没什么缺点呢?好问题。要说HTML5 Storage的缺点,唯一的问题就是它默认的QUOTA只有5MB,并且你没办法通过程序自行或是提示用户来增加存储空间。唯一的办法就是用户自己打开 浏览器的设置,并手动修改QUOTA的大小,如果超出了5MB的限制,你将会遇到一个“QUOTA_EXCEEDED_ERR”的错误。
Web SQL DatabaseWeb SQL Database是一个已经废弃的规范,但是鉴于除了IE和Firefox,其他浏览器都已经实现了Web SQL Database,并且它还具有一些HTML5 Storage所不具有的特性,所以还是值得了解一下的。
Web SQL Database就像它的名字那样,就是一个让你可以在Web上直接使用的SQL数据库,你要做的就是打开数据库,然后执行SQL,和你对Mysql做的事情没什么两样:

代码

  1. openDatabase('documents', '1.0', 'Local document storage', 5*1024*1024,  
    function (db) {  
        db.changeVersion('', '1.0', function (t) {  
            t.executeSql('CREATE TABLE docids (id, name)');  
        }, error);  
    });
    Nach dem Login kopieren


关于Web SQL Database的更多介绍,可以参看这篇指南
但是它的缺点也同样明显。最大的问题就出在SQL上,实际上并不存在一种叫做SQL的标准结构化查询语言,我们平常使用的实际上是MS SQL、Oracle SQL、MySQL SQL、postgre SQL或者SQLite SQL(尽管有一个叫做SQL-92的规范,但它基本形同虚设),更进一步,甚至都不存在SQLite SQL,我们使用的实际上是SQLite x.y.z SQL,而这也就是Web SQL Database最大的问题,它无法统一各个浏览器厂商实现的SQL语言,如果你的某条Web SQL查询只能在Chrome上运行,这还能叫做标准吗?
所以,如果你现在访问Web SQL Database的规范页面,你会在顶部看到这样一则声明:
这个规范已经陷入了一个僵局:目前的所有实现都是基于同一个SQL后端(SQLite),但是我们需要更多的独立实现来完成标准化,所以除非有厂商愿意独立实现这个规范,否则当前的SQL规范只能采用SQLite的SQL方言,而作为一个标准,这是不可接受的。
IndexedDB最后我们要介绍的就是IndexedDB了,相比其他两个规范,目前只有Firefox实现了IndexedDB(顺便提一下,Mozilla表示它们永远不会去实现Web SQL Database),不过Google已经表示正在考虑在Chrome中加入IndexDB支持
IndexedDB引入了一个object store的概念,这有点像是一个SQL Database,你可以在“数据库”中存储“记录”,并且每条“记录”可以拥有很多“字段",每个字段都有一个特定的数据类型,你可以选择记录的子集, 并使用“光标”进行遍历,同时object store中的所有变更都是基于“事务”的。
下面让我们来看一个小例子:

代码

  1. var request = window.indexedDB.open("CandyDB",  
                                        "My candy store database");  
    request.onsuccess = function(event) {  
      var db = event.result;  
      if (db.version != "1") {  
        // User's first visit, initialize database.  
        var createdObjectStoreCount = 0;  
        var objectStores = [  
          { name: "kids", keyPath: "id", autoIncrement: true },  
          { name: "candy", keyPath: "id", autoIncrement: true },  
          { name: "candySales", keyPath: "", autoIncrement: true }  
        ];  
        function objectStoreCreated(event) {  
          if (++createdObjectStoreCount == objectStores.length) {  
            db.setVersion("1").onsuccess = function(event) {  
              loadData(db);  
            };  
          }  
        }  
        for (var index = 0; index < objectStores.length; index++) {  
          var params = objectStores[index];  
          request = db.createObjectStore(params.name, params.keyPath,  
                                         params.autoIncrement);  
          request.onsuccess = objectStoreCreated;  
        }  
      }  
      else {  
        // User has been here before, no initialization required.  
        loadData(db);  
      }  
    };
    Nach dem Login kopieren

关于Indexed的更多介绍可以参看Mozilla Blog的这篇指南。

本文讲解了关于HTML5本地存储的相关内容,更多相关内容请关注php中文网。

相关推荐:

Erklärung zur PHP-Captcha-Verifizierungscode-Klasse

MySQL-Informationsschema-bezogener Inhalt

MySQL-Datenbankgröße, Tabellengröße und letzte Änderungszeit anzeigen

Das obige ist der detaillierte Inhalt vonVerwandte Erklärungen zum lokalen HTML5-Speicher. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage