首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sessionStorage返回空

sessionStorage返回空
EN

Stack Overflow用户
提问于 2018-05-23 03:12:16
回答 1查看 4.2K关注 0票数 3

I试图实现这段代码,但是在我的控制台中它说是空的,这很奇怪,因为当我查看控制台时,sessionStorage不是空的.

代码语言:javascript
复制
$(".btn-alert").click(function(){
        var identifierOfSpan = $(this > "span").text();
        for(var prop in sessionStorage){
            var thing = JSON.parse(sessionStorage.getItem(prop))
            if(thing.id == identifierOfSpan){
                sessionStorage.removeItem(prop);                    
            }
        }
        $(this).closest(".voyages").remove();
        if(sessionStorage.length == 0){
            alert("Message!");
            location.href="reservation.html"

        }
    });

该按钮应该删除div和sessionStorage项,如下所示

Html:

代码语言:javascript
复制
  <div class="voyages">
<button class="btn btn-alert btn-md mr-2" tabindex="-1">delete the flight</button>
<span>ID : 4224762</span>
<div class="infos">
    <img src="img/angleterre.jpg" alt="maroc">
    <div>
        <ul>
            <li><h5>Angleterre, Londres (LON)</h5></li>
            <li><h5>2 adulte(s)</h5></li>
            <li><h5> Aucun enfants </h5></li>
            <li><h5>Type : Couple</h5></li>
        </ul>
    </div>
</div>
<hr>
<h3>Options</h3>
<ul>
    <li>voiture : 0</li>
    <li>Hotel : 0 </li>
</ul>
<hr>
<h3>Prix :3713$</h3>

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-23 03:31:00

如果我没看错你的问题,你想.

  1. 点击按钮
  2. 查找第一个兄弟级<span>元素,并从其文本内容中解析一个数字。
  3. 使用匹配的sessionStorage属性删除所有id项(JSON序列化对象)

对于ID,我强烈建议直接向<button>添加一些数据,以帮助您识别正确的记录。如果你可以的话,试一试

代码语言:javascript
复制
<button class="btn btn-alert btn-md mr-2" data-voyage="4224762"...

试试像这样的东西

代码语言:javascript
复制
$('.btn-alert').on('click', function() {
  const btn = $(this)
  const id = btn.data('voyage')
  // or, if you cannot add the "data-voyage" attribute
  const id = btn.next('span').text().match(/\d+$/)[0]

  // for index-based removal, start at the end and work backwards
  for (let i = sessionStorage.length -1; i >= 0; i--) {
    let key = sessionStorage.key(i)
    let thing = JSON.parse(sessionStorage.getItem(key))
    if (thing.id == id) {
      sessionStorage.removeItem(key)
    }
  }

  // and the rest of your code
  btn.closest(".voyages").remove();
  if(sessionStorage.length === 0) {
    alert("Message!");
    location.href = 'reservation.html'
  }
})

for..in上使用sessionStorage循环的问题是,不仅添加了任何项键,而且还添加了

  • length
  • key
  • getItem
  • setItem
  • removeItem
  • clear
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50479262

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档