ホームページ >ウェブフロントエンド >H5 チュートリアル >HTML5 ローカル ストレージ Web ストレージ アプリケーションの紹介_html5 チュートリアル スキル

HTML5 ローカル ストレージ Web ストレージ アプリケーションの紹介_html5 チュートリアル スキル

WBOY
WBOYオリジナル
2016-05-16 15:50:361448ブラウズ

Web ストレージは、HTML5 で導入された非常に重要な機能です。HTML4 の Cookie と同様に、データをクライアントにローカルに保存できますが、その機能は Cookie よりもはるかに強力であり、Web ストレージは各 Web サイトで公式に推奨されているサイズが 4 KB です。 5MB。
Web ストレージは 2 つのタイプに分類されます :
sessionStorage
localStorage
文字通りの意味から、sessionStorage はセッション内のデータを保存し、ブラウザは閉じていることが明確にわかります。
sessionStorage であっても localStorage であっても、使用できる API は次のとおりです (localStorage を例にします)。 🎜> データの保存: localStorage.setItem(key,value);
データの読み取り: localStorage.getItem(key);
単一のデータの削除: localStorage.removeItem(key);
すべてのデータの削除: localStorage。 clear ();
インデックスのキーを取得します: localStorage.key(index);
上記のように、キーと値は両方とも文字列である必要があります。つまり、Web Storage API は文字列に対してのみ操作できます。
次に、Web Storage を介して単純なアドレス帳アプレットを開発し、関連する API の使用を示します。
連絡先には、名前と携帯電話番号の 2 つのフィールドがあります。携帯電話番号をキーとして localStorage に保存します。
携帯電話番号に基づいて所有者を検索します。
現在保存されている連絡先情報をすべてリストします。

まず、単純な HTML ページを準備します。次のように :

コードをコピー コードは次のとおりです:


HTML5 ローカル ストレージの Web ストレージ/title> <br></head> <br><div style="border: 2px 破線 #ccc;width:320px;text-align:center;"> <label for="user_name">名前:</label><br><input type="text" id="user_name" name="user_name" class="text"/>< ;br /> <br><label for="mobilephone">携帯電話: </label><br><input type="text" id="mobilephone" name="mobilephone"/> <br> <br/> <br><input type="button" onclick="save()" value="新しいレコード"/> <br><hr/> label for ="search_phone">携帯電話番号を入力してください:</label><br><input type="text" id="search_phone" name="search_phone"/> "button" onclick="find()" value="所有者の検索"/> <br><p id="find_result"><br/></p> ; <br><br/> <br></body> <br><br><br>インターフェースは次のようになります<br>: <br><br> <br>連絡先を保存するには、次の JS メソッドを実装するだけです: <br><br><br><br><br><br>コードをコピー</div> <br><strong>コードは次のとおりです:</strong><br> <img alt="" src="http://files.jb51.net/file_images/article/201301/2013010615435390.png" align="middle">//データを保存<br>function save(){ <br>var mobilephone = document.getElementById("mobilephone").value; <br>var user_name = document.getElementById("user_name").value; <div class="msgheader">localStorage.setItem(mobilephone,user_name); 🎜><div class="right"><span style="max-width:90%" onclick="copycode(getid('phpcode74'));"><u>所有者を見つけるには、次の JS メソッドを実装します</u>: </span></div> </div> <div class="msgborder" id="phpcode74"> <br><br>コードをコピー<br><br><br>コードは次のとおりです: <br><br> </div>//データの検索<br>function find(){ <strong>var search_phone = document.getElementById("search_phone").value; name = localStorage.getItem( search_phone); </strong>var find_result = document.getElementById("find_result"); <br>find_result.innerHTML = search_phone "名前; <br><div class="msgheader"><div class="right">保存されているすべての連絡先情報を表示するには、次のように localStorage.key(index) メソッドを使用する必要があります: <span style="CURSOR: pointer" onclick="copycode(getid('phpcode75'));"><u></u></span> </div></div>コードをコピーします<div class="msgborder" id="phpcode75"> <br><br>コードは次のとおりです:<br><div class="msgborder" id="phpcode76"> <br>//localStorage に保存されているすべてのオブジェクトを抽出し、インターフェースに表示します。 <br>functionloadAll(){ <br>var list = document.getElementById("list"); <br> if(localStorage. length>0){ <br>var result = "<table border='1'>"; <br />result = "<tr><td>名前</td><td>携帯電話番号< ;/td></tr>"; <br>for(var i=0;i<localStorage.length;i ){ <br />var mobilephone = localStorage.key(i); <br />var name = localStorage .getItem(携帯電話); <br />結果 = "<tr><td>" 携帯電話 "<br> } <br>result = "</table>"; <br>list.innerHTML = result; <br>}else{ <br>list.innerHTML = "データは現在空です。今すぐ追加を開始してください。"; <br>} <br>} <br> </div> <br>効果は次のとおりです: <br><img alt="" src="http://files.jb51.net/file_images/article/201301/2013010615435392.png" align="middle"> <br>問題: 上記のデモには、名前と携帯電話番号の 2 つのフィールドしかありません。会社名、自宅の住所など、より豊富な連絡先情報を保存したい場合、どうすればよいでしょうか? Web Storage は文字列しか扱わないのでしょうか?現時点では、JSON の stringify() メソッドを使用して複雑なオブジェクトを文字列に変換し、Web Storage に保存できます。Web Storage から読み取る場合は、JSON の parse() メソッドを使用してそれらを JSON オブジェクトに変換できます。 🎜>以下は、会社属性を持つ連絡先を保存するための JS コードを追加する簡単なデモです<br>: <strong></strong><br><br><div class="msgheader"> <div class="right">コードをコピー<span style="CURSOR: pointer" onclick="copycode(getid('phpcode77'));"><u></u>コードは次のとおりです: </span> </div> </div>//データを保存<div class="msgborder" id="phpcode77">function save(){ <br>var contact = new Object; <br>contact.user_name = document.getElementById(" user_name").value; <br>contact.mobilephone = document.getElementById("mobilephone").value; <br>contact.company = document.getElementById("company").value; <br>var str = JSON. stringify(contact) ; <br>localStorage.setItem(contact.mobilephone,str); <br>loadAll(); <br>} <br>//localStorage に保存されているすべてのオブジェクトを抽出してインターフェースに表示します<br> function loadAll(){ <br>var list = document.getElementById("list"); <br>if(localStorage.length>0){ <br>var result = "<table border='1'>" ; <br />result = "<tr>gt;<td>名前</td>gt;<td>携帯電話番号</td>会社<br />"; (var i=0;i<localStorage.length;i ){ <br />var mobilephone = localStorage.key(i); <br />var str = localStorage.getItem(mobilephone); <br />var contact = JSON .parse (str); <br />結果 = "<tr><td>" contact.user_name "</td><td>" "</td></tr>"; <br>} <br>result = "</table>"; <br>list.innerHTML = result; <br> リスト。 innerHTML = "データは現在空です。すぐに連絡先の追加を開始してください"; <br>} <br>} <br><br><br>効果は次のとおりです: <br> </div> </div></div><div class="nphpQianMsg"><div class="clear"></div></div><div class="nphpQianSheng"><span>声明:</span><div>この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。</div></div></div><div class="nphpSytBox"><span>前の記事:<a class="dBlack" title="HTML5 は Web 世界を再形成します HTML5 はインターネットをどのように変えます_html5 チュートリアルのヒント" href="https://m.php.cn/ja/faq/6528.html">HTML5 は Web 世界を再形成します HTML5 はインターネットをどのように変えます_html5 チュートリアルのヒント</a></span><span>次の記事:<a class="dBlack" title="HTML5 は Web 世界を再形成します HTML5 はインターネットをどのように変えます_html5 チュートリアルのヒント" href="https://m.php.cn/ja/faq/6531.html">HTML5 は Web 世界を再形成します HTML5 はインターネットをどのように変えます_html5 チュートリアルのヒント</a></span></div><div class="nphpSytBox2"><div class="nphpZbktTitle"><h2>関連記事</h2><em><a href="https://m.php.cn/ja/article.html" class="bBlack"><i>続きを見る</i><b></b></a></em><div class="clear"></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="fluid" data-ad-layout-key="-6t+ed+2i-1n-4w" data-ad-client="ca-pub-5902227090019525" data-ad-slot="8966999616"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><ul class="nphpXgwzList"><li><b></b><a href="https://m.php.cn/ja/faq/348281.html" title="AlloyTouch 全画面スクロール プラグインは 30 秒で滑らかな H5 ページを作成します" class="aBlack">AlloyTouch 全画面スクロール プラグインは 30 秒で滑らかな H5 ページを作成します</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/ja/faq/348372.html" title="HTML5の実戦とタッチイベント解析(touchstart、touchmove、touchend)" class="aBlack">HTML5の実戦とタッチイベント解析(touchstart、touchmove、touchend)</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/ja/faq/348373.html" title="HTML5 Canvas 9での画像描画例を詳しく解説" class="aBlack">HTML5 Canvas 9での画像描画例を詳しく解説</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/ja/faq/348374.html" title="正規表現と新しい HTML5 要素" class="aBlack">正規表現と新しい HTML5 要素</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/ja/faq/348469.html" title="NodeJS と HTML5 を組み合わせて複数のファイルをドラッグ アンド ドロップしてサーバーにアップロードする方法" class="aBlack">NodeJS と HTML5 を組み合わせて複数のファイルをドラッグ アンド ドロップしてサーバーにアップロードする方法</a><div class="clear"></div></li></ul></div></div><ins class="adsbygoogle" style="display:block" data-ad-format="autorelaxed" data-ad-client="ca-pub-5902227090019525" data-ad-slot="5027754603"></ins><script> (adsbygoogle = window.adsbygoogle || []).push({}); </script><footer><div class="footer"><div class="footertop"><img src="/static/imghwm/logo.png" alt=""><p>福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!</p></div><div class="footermid"><a href="https://m.php.cn/ja/about/us.html">私たちについて</a><a href="https://m.php.cn/ja/about/disclaimer.html">免責事項</a><a href="https://m.php.cn/ja/update/article_0_1.html">Sitemap</a></div><div class="footerbottom"><p> © php.cn All rights reserved </p></div></div></footer><script>isLogin = 0;</script><script type="text/javascript" src="/static/layui/layui.js"></script><script type="text/javascript" src="/static/js/global.js?4.9.47"></script></div><script src="https://vdse.bdstatic.com//search-video.v1.min.js"></script><link rel='stylesheet' id='_main-css' href='/static/css/viewer.min.css' type='text/css' media='all'/><script type='text/javascript' src='/static/js/viewer.min.js?1'></script><script type='text/javascript' src='/static/js/jquery-viewer.min.js'></script><script>jQuery.fn.wait = function (func, times, interval) { var _times = times || -1, //100次 _interval = interval || 20, //20毫秒每次 _self = this, _selector = this.selector, //选择器 _iIntervalID; //定时器id if( this.length ){ //如果已经获取到了,就直接执行函数 func && func.call(this); } else { _iIntervalID = setInterval(function() { if(!_times) { //是0就退出 clearInterval(_iIntervalID); } _times <= 0 || _times--; //如果是正数就 -- _self = $(_selector); //再次选择 if( _self.length ) { //判断是否取到 func && func.call(_self); clearInterval(_iIntervalID); } }, _interval); } return this; } $("table.syntaxhighlighter").wait(function() { $('table.syntaxhighlighter').append("<p class='cnblogs_code_footer'><span class='cnblogs_code_footer_icon'></span></p>"); }); $(document).on("click", ".cnblogs_code_footer",function(){ $(this).parents('table.syntaxhighlighter').css('display','inline-table');$(this).hide(); }); $('.nphpQianCont').viewer({navbar:true,title:false,toolbar:false,movable:false,viewed:function(){$('img').click(function(){$('.viewer-close').trigger('click');});}}); </script></body><!-- Matomo --><script> var _paq = window._paq = window._paq || []; /* tracker methods like "setCustomDimension" should be called before "trackPageView" */ _paq.push(['trackPageView']); _paq.push(['enableLinkTracking']); (function() { var u="https://tongji.php.cn/"; _paq.push(['setTrackerUrl', u+'matomo.php']); _paq.push(['setSiteId', '9']); var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0]; g.async=true; g.src=u+'matomo.js'; s.parentNode.insertBefore(g,s); })(); </script><!-- End Matomo Code --></html>