Heim Web-Frontend js-Tutorial Der Unterschied zwischen den drei Datenspeichermethoden von JavaScript

Der Unterschied zwischen den drei Datenspeichermethoden von JavaScript

May 16, 2016 pm 03:02 PM
cookie javascript js storage 存储 数据存储

In diesem Kapitel werden die Unterschiede zwischen den drei Datenspeichermethoden von JavaScript vorgestellt. Freunde in Not können sich darauf beziehen.

Die gemeinsamen Punkte zwischen sessionStorage, localStorage und Cookies:

werden alle auf der Browserseite gespeichert und haben denselben Ursprung.

Der Unterschied zwischen sessionStorage, localStorage und Cookies:

Cookie-Daten werden in der HTTP-Anfrage immer vom gleichen Ursprung übertragen (auch wenn sie nicht benötigt werden), d. h Das heißt, das Cookie wird im Browser gespeichert und an den Server übertragen. SessionStorage und localStorage senden Daten nicht automatisch an den Server, sondern speichern sie nur lokal. Cookie-Daten haben auch das Konzept eines Pfads, der Cookies darauf beschränken kann, nur zu einem bestimmten Pfad zu gehören.

Die Speichergrößenbeschränkung ist ebenfalls unterschiedlich. Da jede HTTP-Anfrage Cookies enthält, eignen sie sich nur zum Speichern sehr kleiner Daten, z. B. Sitzungskennungen. Obwohl sessionStorage und localStorage ebenfalls Speichergrößenbeschränkungen haben, sind sie viel größer als Cookies und können 5 MB oder mehr erreichen.

Der Datengültigkeitszeitraum ist unterschiedlich: Er ist nur gültig, bis das aktuelle Browserfenster geschlossen wird, und kann natürlich nicht beibehalten werden. LocalStorage: Er ist immer gültig und wird auch dann gespeichert, wenn das Fenster oder der Browser geschlossen ist geschlossen, daher wird es als persistente Daten verwendet; das Cookie ist nur bis zur eingestellten Cookie-Ablaufzeit gültig, auch wenn das Fenster oder der Browser geschlossen ist.

Unterschiedliche Bereiche, sessionStorage wird nicht in verschiedenen Browserfenstern gemeinsam genutzt, selbst auf derselben Seite; localStorage wird in allen Fenstern gleichen Ursprungs gemeinsam genutzt;

Web Storage unterstützt einen Ereignisbenachrichtigungsmechanismus, der Datenaktualisierungsbenachrichtigungen an Listener senden kann.

Die API-Schnittstelle von Web Storage ist bequemer zu verwenden.

Die gekapselte localStorage-Methode kann die Anzahl der gespeicherten Daten und die Zeit steuern

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

define(function (require) {

  var $ = require('jquery');

  var Cache = {};

 

  function support() {

    var _t = !(typeof window.localStorage === 'undefined');

    return _t;

  }

 

  $.extend(Cache, {

    config: {

      size: 5,

      // lifeTime: 86400 //一天的秒数

      lifeTime: 1*60

    },

    localStorage: window.localStorage,

    memQueue: (function () {

      if (support()) {

        var jsonStr = window.localStorage.getItem('LRUConfig');

        return jsonStr ? JSON.parse(jsonStr) : {

          keys: {},

          objs: []

        };

      } else {

        return {};

      }

    })(),

 

    get: function(appid, url) {

      if (true == support()) {

        var key = appid + ':' + url;

        //开始做LRU算法。

        this.LRU(key);

        //LRU算法结束。

        var isFresh = true;

        var nowTime = (new Date()).getTime() / 1000;

        if(key in this.memQueue.keys){

          var cacheTime = this.memQueue.keys[key].life / 1000;

          //如果过期时间超过 配置的lifeTime,

          //则清除掉当前缓存

          if(nowTime - cacheTime >= this.config.lifeTime){

            delete this.memQueue.keys[key];

            for (var i=0, len = this.memQueue.objs.length; i < len; i++) {

              var _o = this.memQueue.objs[i];

              if(_o.key == key){

                this.memQueue.objs.splice(i,1);

                break;

              }

            }

            isFresh = false;

          }

        }

        //如果isFresh为假,就是已过期,则返回null,否则从localStorage中取

        return (false == isFresh) ? null : this.localStorage[key];

      }

    },

    set: function(appid, url, value) {

      if (true == support()) {

        var key = appid + &#39;:&#39; + url;

        var lruKey = this.getLRU();

        //淘汰最近最少使用的这个。

        //另外起一个方法读取最符合淘汰的这个

        //前提是当前这个key,不在localStorage里面。

        if (lruKey) {

          this.localStorage.removeItem(lruKey);

        }

        //开始设置一下这个值

        //为了兼容性,用以下方法设置

        if (typeof this.memQueue.objs != &#39;undefined&#39; &&

          this.memQueue.objs.length = this.config.size) {

            var lruKey = this.getLRU();

            //淘汰最近最少使用的这个。

            //另外起一个方法读取最符合淘汰的这个

            if (lruKey) {

              this.localStorage.removeItem(lruKey);

              delete this.memQueue.keys[lruKey];

              for (var i = 0; i < this.memQueue.objs.length; i++) {

                var _o = this.memQueue.objs[i];

                if(_o.key == lruKey){

                  this.memQueue.objs.splice(i,1);

                  break;

                }

              }

            }

          }

        }

 

        this.localStorage[key] = value;

        //当前的key,也必须lru一下

        this.LRU(key);

        //lru结束

 

        this.localStorage.setItem(&#39;LRUConfig&#39;, JSON.stringify(this.memQueue));

      }

    },

    /*

     * 近期最少使用算法

     */

    LRU: function(key) {

      var memQueue = this.memQueue;

      if (typeof memQueue.objs != &#39;undefined&#39;) {

        var _o = memQueue.objs;

 

        //开始计算那个要淘汰的key,

        //就是那个times最大的,如果times最大的有几个

        //则返回那个time最小的

        var isIn = false;

        for (var i = 0, len = _o.length; i < len; i++) {

          _o[i].times = (key == _o[i].key) ? 0 : _o[i].times + 1;

          _o[i].time = (key == _o[i].key) ? (new Date()).getTime() : _o[i].time;

          if(key == _o[i].key && false == isIn){

            isIn = true;

          }

        }

        // 如果

        if(false == isIn){

          var _to = {

            &#39;key&#39;: key,

            &#39;times&#39;: 0,

            &#39;time&#39;: (new Date()).getTime(),

            &#39;life&#39;: (new Date()).getTime()

          };

          this.memQueue.keys[key] = _to;

          this.memQueue.objs.push(_to);

        }

        _o.sort(function(f, s) {

          //按times降序排列。

          if (f.times < s.times) {

            return 1;

          } else if (f.times > s.times) {

            return -1;

          } else {

            //开始比较time

            //按time,时间升序排列

            if (f.time < s.time) {

              return -1;

            } else {

              return 1;

            }

          }

        });

      } else {

        this.memQueue.objs = [];

        this.memQueue.keys = {};

        var _to = {

          &#39;key&#39;: key,

          &#39;times&#39;: 0,

          &#39;time&#39;: (new Date()).getTime(),

          &#39;life&#39;: (new Date()).getTime()

        };

        this.memQueue.keys[key] = _to;

        this.memQueue.objs.push(_to);

        return null;

      }

    },

    /*

     * 读取需要淘汰的一项

     */

    getLRU: function() {

      var _o = this.memQueue.objs;

      if (_o) {

        return (_o.length >= this.config.size) ? _o.shift().key : null;

      }

 

      return null;

 

    }

  });

 

  return {

    &#39;cache&#39;: Cache

  };

});

Nach dem Login kopieren
Nutzungsmethode


1

2

3

4

5

6

var cache = require(&#39;cache&#39;);

// set 值

cache.Cache.set(&#39;ip&#39;, &#39;你自己的一个url&#39;, value);

 

// get值

cache.Cache.get(&#39;ip&#39;)

Nach dem Login kopieren
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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Huawei wird nächstes Jahr innovative MED-Speicherprodukte auf den Markt bringen: Die Rack-Kapazität übersteigt 10 PB und der Stromverbrauch beträgt weniger als 2 kW Huawei wird nächstes Jahr innovative MED-Speicherprodukte auf den Markt bringen: Die Rack-Kapazität übersteigt 10 PB und der Stromverbrauch beträgt weniger als 2 kW Mar 07, 2024 pm 10:43 PM

Diese Website berichtete am 7. März, dass Dr. Zhou Yuefeng, Präsident der Datenspeicherproduktlinie von Huawei, kürzlich an der MWC2024-Konferenz teilgenommen und speziell die magnetoelektrische Speicherlösung OceanStorArctic der neuen Generation vorgestellt hat, die für warme Daten (WarmData) und kalte Daten (ColdData) entwickelt wurde. Zhou Yuefeng, Präsident der Datenspeicherproduktlinie von Huawei, hat eine Reihe innovativer Lösungen veröffentlicht: Die dieser Website beigefügte offizielle Pressemitteilung von Huawei lautet wie folgt: Die Kosten dieser Lösung sind 20 % niedriger als die von Magnetbändern Der Stromverbrauch ist 90 % niedriger als der von Festplatten. Laut Foreign Technology Media BlocksandFiles gab ein Huawei-Sprecher auch Informationen über die magnetoelektrische Speicherlösung preis: Huaweis magnetoelektronische Disk (MED) sei eine bedeutende Innovation bei magnetischen Speichermedien. ME der ersten Generation

Empfohlen: Ausgezeichnetes JS-Open-Source-Projekt zur Gesichtserkennung und -erkennung Empfohlen: Ausgezeichnetes JS-Open-Source-Projekt zur Gesichtserkennung und -erkennung Apr 03, 2024 am 11:55 AM

Die Technologie zur Gesichtserkennung und -erkennung ist bereits eine relativ ausgereifte und weit verbreitete Technologie. Derzeit ist JS die am weitesten verbreitete Internetanwendungssprache. Die Implementierung der Gesichtserkennung und -erkennung im Web-Frontend hat im Vergleich zur Back-End-Gesichtserkennung Vor- und Nachteile. Zu den Vorteilen gehören die Reduzierung der Netzwerkinteraktion und die Echtzeiterkennung, was die Wartezeit des Benutzers erheblich verkürzt und das Benutzererlebnis verbessert. Die Nachteile sind: Es ist durch die Größe des Modells begrenzt und auch die Genauigkeit ist begrenzt. Wie implementiert man mit js die Gesichtserkennung im Web? Um die Gesichtserkennung im Web zu implementieren, müssen Sie mit verwandten Programmiersprachen und -technologien wie JavaScript, HTML, CSS, WebRTC usw. vertraut sein. Gleichzeitig müssen Sie auch relevante Technologien für Computer Vision und künstliche Intelligenz beherrschen. Dies ist aufgrund des Designs der Webseite erwähnenswert

Git-Installationsprozess unter Ubuntu Git-Installationsprozess unter Ubuntu Mar 20, 2024 pm 04:51 PM

Git ist ein schnelles, zuverlässiges und anpassungsfähiges verteiltes Versionskontrollsystem. Es ist für die Unterstützung verteilter, nichtlinearer Arbeitsabläufe konzipiert und eignet sich daher ideal für Softwareentwicklungsteams jeder Größe. Jedes Git-Arbeitsverzeichnis ist ein unabhängiges Repository mit einem vollständigen Verlauf aller Änderungen und der Möglichkeit, Versionen auch ohne Netzwerkzugriff oder einen zentralen Server zu verfolgen. GitHub ist ein in der Cloud gehostetes Git-Repository, das alle Funktionen der verteilten Revisionskontrolle bietet. GitHub ist ein Git-Repository, das in der Cloud gehostet wird. Im Gegensatz zu Git, einem CLI-Tool, verfügt GitHub über eine webbasierte grafische Benutzeroberfläche. Es wird zur Versionskontrolle verwendet, was die Zusammenarbeit mit anderen Entwicklern und die Verfolgung von Änderungen an Skripten und anderen umfasst

Detaillierte Erklärung, wo Browser-Cookies gespeichert werden Detaillierte Erklärung, wo Browser-Cookies gespeichert werden Jan 19, 2024 am 09:15 AM

Mit der Popularität des Internets ist die Verwendung von Browsern zum Surfen im Internet zu einer Lebensweise geworden. Bei der täglichen Verwendung von Browsern stoßen wir häufig auf Situationen, in denen wir Kontokennwörter eingeben müssen, z. B. beim Online-Shopping, bei sozialen Netzwerken, bei E-Mails usw. Diese Informationen müssen vom Browser aufgezeichnet werden, damit sie bei Ihrem nächsten Besuch nicht erneut eingegeben werden müssen. Was sind Cookies? Bei einem Cookie handelt es sich um eine kleine Datendatei, die vom Server an den Browser des Benutzers gesendet und lokal gespeichert wird. Sie enthält das Benutzerverhalten einiger Websites.

Welcher Dateityp ist eine DAT-Datei? Welcher Dateityp ist eine DAT-Datei? Feb 19, 2024 am 11:32 AM

Die DAT-Datei ist ein universelles Datendateiformat, das zum Speichern verschiedener Datentypen verwendet werden kann. DAT-Dateien können verschiedene Datenformen wie Text, Bilder, Audio und Video enthalten. Es wird häufig in vielen verschiedenen Anwendungen und Betriebssystemen verwendet. dat-Dateien sind in der Regel Binärdateien, die Daten in Bytes statt in Textform speichern. Das bedeutet, dass DAT-Dateien nicht geändert oder ihr Inhalt direkt mit einem Texteditor angezeigt werden kann. Stattdessen sind spezielle Software oder Tools erforderlich, um die Daten von DAT-Dateien zu verarbeiten und zu analysieren. D

So nutzen Sie sessionStorage richtig zum Schutz sensibler Daten So nutzen Sie sessionStorage richtig zum Schutz sensibler Daten Jan 13, 2024 am 11:54 AM

Für die korrekte Verwendung von sessionStorage zum Speichern vertraulicher Informationen sind bestimmte Codebeispiele erforderlich. Ob bei der Webentwicklung oder der Entwicklung mobiler Anwendungen, wir müssen häufig vertrauliche Informationen wie Benutzeranmeldeinformationen, ID-Nummern usw. speichern und verarbeiten. In der Front-End-Entwicklung ist die Verwendung von sessionStorage eine gängige Speicherlösung. Da es sich bei sessionStorage jedoch um eine browserbasierte Speicherung handelt, müssen einige Sicherheitsaspekte beachtet werden, um sicherzustellen, dass die gespeicherten vertraulichen Informationen nicht in böswilliger Absicht abgerufen und verwendet werden.

Häufig gestellte Fragen und Lösungen zu Cookie-Einstellungen Häufig gestellte Fragen und Lösungen zu Cookie-Einstellungen Jan 19, 2024 am 09:08 AM

Für häufige Probleme und Lösungen für Cookie-Einstellungen sind spezifische Codebeispiele erforderlich. Mit der Entwicklung des Internets wurden Cookies als eine der häufigsten herkömmlichen Technologien in großem Umfang in Websites und Anwendungen eingesetzt. Einfach ausgedrückt handelt es sich bei einem Cookie um eine Datendatei, die auf dem Computer des Benutzers gespeichert wird und zum Speichern der Benutzerinformationen auf der Website verwendet werden kann, einschließlich Anmeldename, Inhalt des Warenkorbs, Website-Präferenzen usw. Cookies sind ein unverzichtbares Werkzeug für Entwickler, gleichzeitig werden jedoch häufig Cookie-Einstellungen vorgenommen

Die Beziehung zwischen js und vue Die Beziehung zwischen js und vue Mar 11, 2024 pm 05:21 PM

Die Beziehung zwischen js und vue: 1. JS als Eckpfeiler der Webentwicklung; 2. Der Aufstieg von Vue.js als Front-End-Framework; 3. Die komplementäre Beziehung zwischen JS und Vue; Vue.

See all articles