资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

HTML5中怎么使用网络存储存储键值对的数据

本篇内容介绍了“HTML5中怎么使用网络存储存储键值对的数据”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

网站建设哪家好,找创新互联建站!专注于网页设计、网站建设、微信开发、成都微信小程序、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了临泽免费建站欢迎大家使用!

1.使用本地存储

我们使用localStorage对象来访问本地存储,他返回存储对象,存储使用存储键值对的数据,,他有下面一些属性和方法:

clear():清楚存储的键值对数据;

getItem():通过键获取值值;

key():通过索引获取键值;

长度:返回键值对的个数;

removeItem():通过键移出指定数据;

setItem():添加一个键值对,当指定键的键值对存在时,则实现更新操作;

[]:通过多重下标的方式,使用密钥获取指定的值值。

存储对象允许我们存储密钥和值都是字符串形式的密钥值对数据,密钥是唯一的,意味着当我们使用setItem方法添加键值对时,如果key值已经存在的话,将实现更新的操作。

复制代码代码如下: 

<!DOCTYPE HTML>

示例</ title></p><p><style></p><p>body> * {float:left;}</p><p>表{border-colla ps e:合拢; margin-left:50px;}</p><p>, td {padding:4px;}</p><p>th {text-align:right;}</p><p>输入{border:细实黑; padding:2px;}</p><p>标签{min-width:50px; display:inline-block; text-align:right;}</p><p>#countmsg,#buttons {margin-left:50px; margin-top:5px; margin-bottom:5px;}</p><p></ style></p><p></ head></p><p><body></p><p><div></p><p><div></p><p><label>键:</ label > <输入id =“ key”占位符=“ Enter Key” /> </ div></p><p><div></p><p><label>值:</ label> <输入id =“ value”占位符=“输入值” /> </ div></p><p><div id =“ buttons”></p><p><button id =“ add”>添加</ button></p><p><button id =“ clear”>清除</ button></p><p></ div></p><p><p id =“ countmsg”>有<span id =“ count”> </ span>项目</ p></p><p></ div></p><p><table id =“ data” border =“ 1”></p><p><tr></p><p><th>项目计数:</ th></p><p><td id =“ count“>-</ td></p><p></ tr></p><p></ table></p><p><script></p><p>displayData();</p><p>var button = document.getElementsByTagName('button');</p><p>for(var i = 0; i <button.length; i ++){</p><p>button [i] .onclick = handleButtonPress;</p><p>var value = document.getElementById('value')。value;</p><p>localStorage.setItem(key,value);</p><p>休息;</p><p>案例'clear':</p><p>localStorage.clear();</p><p>休息;</p><p>}</p><p>displayData();</p><p>}</p><p>函数displayData(){</p><p>var tableElement = document.getElementById('data');</p><p>tableElement.innerHTML ='';</p><p>var itemCount = localStorage.length;</p><p>document.getElementById('count')。innerHTML = itemCount;</p><p>for(var i = 0; i <itemCount; i ++){</p><p>var key = localStorage.key(i);</p><p>var val = localStorage.getItem(key);</p><p>tableElement.innerHTML + ='<tr> <th>'+键+':</ th> <td>'+ val +'</ td> </ tr>';</p><p></ html></p><p>浏览器不能删除我们通过localStorage的创建的数据,除非用户删除它。</p><p>2.监听存储事件</p><p>通过本地存储存储的数据对同源的文档具有可见性,比如你打开两个镀铬浏览器访问同一个URL地址,在任何一个页面上创建的本地存储对另外一个页面也是可见的。但是如果用别的浏览器(如firefox)打开相同的网址地址,本地存储是不可见的,因为他们不同源了。来监听存储的内容发生改变的,下面我们看他包含的其他属性:</p><p>key:返回发生改变的键值;</p><p>oldValue:返回发生改变键值以前的值值;</p><p>newValue:返回发生改变键值新的值值;</p><p>网址:发生改变的URL地址;</p><p>storageArea:返回发生改变的存储对象(是本地存储还是会话存储)</p><p>下面我们看个例子:</p><p>复制代码代码如下: </p><p><!DOCTYPE HTML></p><p><html></p><p><head></p><p><title>存储空间</ title></p><p><style></p><p>表{边界折叠:折叠;}</p><p>th,td {填充:4px;}</p><p></ style></p><p></ head></p><p><body ></p><p><table id =“ data” border =“ 1”></p><p><tr></p><p><th>键</ th></p><p><th> oldValue </ th></p><p><th> newValue </ th></p><p><th> url </ th></p><p>< th> storageArea </ th></p><p></ tr></p><p></ table></p><p><script></p><p>var tableElement = document.getElementById('data');</p><p>window.onstorage =函数(e){</p><p>var row ='<tr>';</p><p>行+ =' <td>'+ e.key +'</ td>';</p><p>行+ ='<td>'+ e.oleValue +'</ td>';</p><p>行+ ='<td>'+ e.newValue +'</ td>';</p><p>行+ ='<td>'+ e.url +'</ td>';</p><p>行+ ='<td>'+(e.storageArea == localStorage)+'</ td> </ tr>';</p><p>tableElement.innerHTML + =行;</p><p>}</p><p></ script></p><p></ body></p><p></ html></p><p>我们在例1中增删改改存储的数据,会在例2页面上显示出来。例2在chrome浏览器中运行正常,firefox没有反应,其他浏览器没有测试。</p><p>运行结果:</p><p>3.使用session storage</p><p>session storage在使用上和本地存储一样,只是他的访问性上只进入内部页面,并且页面关闭后会消失,我们通过sessionStorage来访问它。</p><p>复制代码代码如下: </p><p><!DOCTYPE HTML></p><p><html></p><p><head></p><p><title>示例</ title></p><p><style></p><p>body> * {float:left;}</p><p>table {border-collapse:塌陷; margin-left:50px;}</p><p>th,td { padding:4px;}</p><p>th {text-align:right;}</p><p>输入{border:细实黑色; padding:2px;}</p><p>标签{min-width:50px; display:inline-block; text-align:right;}</p><p>#countmsg ,#buttons {margin-left:50px; margin-top:5px; margin-bottom:5px;}</p><p></ style></p><p></ head></p><p><body></p><p><div></p><p><div></p><p><label>键:</ label> <输入id =“ key” placeholder =“ Enter Key” /> </ div></p><p><div></p><p><label>值:</ label> <输入id =“ value”占位符=“输入值” /> </ div></p><p><div id =“ buttons”></p><p><button id =“ add”>添加</ button></p><p><button id =“ clear”>清除</ button></p><p></ div></p><p><p id =“ countmsg”>有<span id =“ count”> </ </ span>项目</ p></p><p></ div></p><p><table id =“ data” border =“ 1”></p><p><tr></p><p><th>项目计数:</ th></p><p><td id =“ count”>-</ td></p><p></ tr></p><p></ table></p><p><iframe src =“ storage.html” width =“ 500” height =“ 175”> </ iframe></p><p><script></p><p>displayData();</p><p>var button = document.getElementsByTagName(“ button”);</p><p>for(var i = 0; i <button.length; i ++){</p><p>button [i]。onclick = handleButtonPress;</p><p>}</p><p>函数handleButtonPress(e){</p><p>开关(e.target.id){</p><p>案例'add':</p><p>var key = document.getElementById(“ key”)。value;</p><p>var value = document.getElementById(“ value”)。value;</p><p>sessionStorage.setItem(key,value);</p><p>休息;</p><p>案例'clear':</p><p>sessionStorage.clear();</p><p>休息;</p><p>}</p><p>displayData();</p><p>}</p><p>函数displayData(){</p><p>var tableElement = document.getElementById('data');</p><p>tableElement.innerHTML ='';</p><p>var itemCount = sessionStorage.length;</p><p>document.getElementById('count')。innerHTML = itemCount;</p><p>for(var i = 0; i <itemCount; i ++){</p><p>var key = sessionStorage.key(i);</p><p>var val = sessionStorage.getItem(key);</p><p>tableElement.innerHTML + =“ <tr> <th>” +键+“:</ th> <td>” + val +“ </ td> </ tr></p><p></ html></p><p>你在例3中做任何修改,例2的页面不会发生任何改变。</p><p>“HTML5中怎么使用网络存储存储键值对的数据”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!</p> <br> 分享文章:HTML5中怎么使用网络存储存储键值对的数据 <br> 转载源于:<a href="http://cdkjz.cn/article/jdihej.html">http://cdkjz.cn/article/jdihej.html</a> </div> <div class="g-return-wrapper clearfix"> <a href="http://www.cdkjz.cn/" class="home">返回首页</a> <a href="http://www.cdkjz.cn/news/" class="column">了解更多建站资讯</a> </div> </div> </div> <div class="full-related-news"> <h3 class="related-title">相关资讯</h3> <div class="related-news weblg"> <ul class="clearfix"> <li> <a href="/article/hpdpph.html"> <h2 class="title">vb.net强签名程序 net 强签名</h2> </a> </li><li> <a href="/article/hpdhop.html"> <h2 class="title">mysql中怎么插入数据 如何在mysql添加数据</h2> </a> </li><li> <a href="/article/hpdphh.html"> <h2 class="title">oracle9i如何建表 oracle怎么用代码创建表</h2> </a> </li><li> <a href="/article/hpdped.html"> <h2 class="title">C语言定义子函数的要求 c语言函数里定义函数</h2> </a> </li><li> <a href="/article/hpdhcg.html"> <h2 class="title">包含vb.netyield的词条</h2> </a> </li><li> <a href="/article/hpdpgo.html"> <h2 class="title">c语言函数按照隐式声明 c语言声明函数</h2> </a> </li><li> <a href="/article/hpdhsi.html"> <h2 class="title">怎么查看oracle效率 oracle视图能提高查询效率吗</h2> </a> </li><li> <a href="/article/hpdpee.html"> <h2 class="title">php数据过滤器参数 php filter函数</h2> </a> </li> </ul> </div> </div> <div class="full-icontact-cover m-ft-contact"> <div class="weblg"> <div class="clearfix content"> <div class="motto"> 多年建站经验 </div> <div class="info"> <h3>多一份参考,总有益处</h3> <h2> 联系快上网,免费获得专属《策划方案》及报价</h2> <div class="msg"> <p>咨询相关问题或预约面谈,可以通过以下方式与我们联系</p> <h4> 大客户专线   成都:<a href="tel:+13518219792" rel="nofollow">13518219792</a>   座机:<a href="tel:02886922220" rel="nofollow">028-86922220</a> </h4> </div> </div> </div> <div class="btns clearfix"> <a href="https://wpa.qq.com/msgrd?v=3&uin=631063699&site=qq&menu=yes" target="_blank" rel="nofollow" class="oline">在线咨询</a> <a href="javascript:;" class="edit" rel="nofollow">提交需求</a> </div> </div> </div> <div class="footer-content"> <div class="weblg clearfix"> <div class="friend-links"> <h6 class="clearfix"> <span class="tilte">友情链接</span> <a class="exchagne" href="http://wpa.qq.com/msgrd?v=3&uin=631063699&site=qq&menu=yes">交换友情链接</a> </h6> <div class="link-list clearfix"> <div class="link-slider"> <a href="http://www.cqcxhl.com/service/ds.html" title="重庆电商网站建设" target="_blank">重庆电商网站建设</a><a href="http://www.muyideyu.com/" title="营山月子护理" target="_blank">营山月子护理</a><a href="http://seo.cdkjz.cn/" title="成都seo优化" target="_blank">成都seo优化</a><a href="http://www.scyucang.com/" title="宇仓仓储" target="_blank">宇仓仓储</a><a href="http://www.hxwzsj.com/" title="和县翔豪网站" target="_blank">和县翔豪网站</a><a href="http://www.cdzhaopai.cn/" title="成都广告设计" target="_blank">成都广告设计</a><a href="http://www.jinhuajc.com/" title="橡塑保温材料" target="_blank">橡塑保温材料</a><a href="http://chengdu.cdcxhl.cn/seo/ " title="成都网站推广" target="_blank">成都网站推广</a><a href="https://www.cdxwcx.com/wangzhan/muban.html" title="成都成品网站" target="_blank">成都成品网站</a><a href="http://www.cdxwcx.cn/tuoguan/ershu.html" title="成都二枢机房" target="_blank">成都二枢机房</a> </div> </div> </div> </div> <div class="full-foot-bottom"> <div class="weblg clearfix"> <p>成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询<a href="tel:028-86922220">028-86922220</a></p> <p> 成都快上网科技有限公司-四川网站建设设计公司 | <a href="http://www.miitbeian.gov.cn/" target="_blank" rel="nofollow">蜀ICP备19037934号</a> Copyright 2020,ALL Rights Reserved cdkjz.cn | <a href="http://www.cdkjz.cn/" target="_blank">成都网站建设</a> | © Copyright 2020版权所有.</p> <p>专家团队为您提供<a href="http://www.cdkjz.cn/" target="_blank">成都网站建设</a>,<a href="http://www.cdkjz.cn/" target="_blank">成都网站设计</a>,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | <a href="###">网站建设地图</a></p> </div> </div> </div> <script type="text/javascript" src="../js/idangerous.swiper.min.js"></script> <script type="text/javascript" src="../js/wow.min.js"></script> <script type="text/javascript" src="../js/jquery.mousewheel.min.js"></script> <script type="text/javascript" src="../js/jquery.placeholder.min.js"></script> <script type="text/javascript" src="../js/layout.js"></script> </body> </html> <script> $(".singlepage img").each(function(){ var src = $(this).attr("src"); //获取图片地址 var str=new RegExp("http"); var result=str.test(src); if(result==false){ var url = "https://www.cdcxhl.com"+src; //绝对路径 $(this).attr("src",url); } }); window.onload=function(){ document.oncontextmenu=function(){ return false; } } </script>