其他项目怎么做quan? [私人]

Posted

技术标签:

【中文标题】其他项目怎么做quan? [私人]【英文标题】:how to do quan for other items? [priv] 【发布时间】:2020-04-11 17:42:40 【问题描述】:

所以我可以为列表中的所有项目添加数量,并且所有数量都可以在数组中更新,但是,我似乎无法更新 html 中的数量,它只在第一个更新列表中的项目,有人可以帮我解决这个问题。

这是我的第 3 页的脚本和 html 代码。

var arr = [
    img: 'umbrella.png',
    item: 'Umbrella',
    price: '$10',
    value: 1,
    qty: 0
  ,
  
    img: 'lipbalm.png',
    item: 'Lip Balm',
    price: '$5',
    value: 2,
    qty: 0
  ,
  
    img: 'flu.png',
    item: 'Flu Medication',
    price: '$5',
    value: 3,
    qty: 0
  ,
  
    img: 'glucose.png',
    item: 'Glucose Sweets',
    price: '$1',
    value: 4,
    qty: 0
  
];
var globalIndex = 0;

function populateList() 
  console.log('populateList');

  var s = "";
  $.each(arr, function(index, val) 
    console.log("index:" + index);
    var img = arr[index].img;
    var item = arr[index].item;
    var price = arr[index].price;
    var value = arr[index].value;
    var qty = arr[index].qty;
    s = s + "<li><a href='#'><img src='images/" + img + "'><h3>" + item + "</h3><p>" + price + "</p>" + "<p id='qty'>Qty: " + qty + "</p></a><a href='#' id='addQtyBtn' class='addQtyBtn'></a></li>";
  );
  $("#myList").html(s);
  $('#myList').listview('refresh');


$(document).on("pagecreate", "#page3", function() 
  populateList();

  $('#myList li').on('tap', function() 
    var index = $(this).index();
    globalIndex = index;
    console.log('list item was tapped' + index);

    if ($('#addQtyBtn').hasClass('addQtyBtn')) 
      var newQty = arr[globalIndex].qty;
      newQty += 1;
      console.log(newQty);

      //update in array
      arr[globalIndex].qty = newQty;

      console.log(arr);

      $('#qty').html("Qty: " + newQty);
     else 
      return false;
      console.log('error');
    ;

  );
);
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<html>

<head>
  <meta name="viewport" content="width=device-width, initial-scale=1">

  <link href="jquery.mobile-1.4.5/jquery.mobile-1.4.5.css" type="text/css" rel="stylesheet" />
  <link href="themes/jquery.mobile.icons.min.css" type="text/css" rel="stylesheet" />
  <link href="themes/CA1_Theme.min.css" type="text/css" rel="stylesheet" />

  <script src="jquery-1.12.4.min.js" type="text/javascript"></script>
  <script src="jquery.mobile-1.4.5/jquery.mobile-1.4.5.js"></script>
</head>
<div data-role="page" id="page3">
  <div data-role="main" class="ui-content">

    <ul id='myList' data-role='listview' data-split-icon="plus"></ul>

    <div data-role="content" class="ui-content">
      <button id="checkoutBtn" class="ui-btn ui-corner-all" style="width: 70%; margin-left: auto; margin-right: auto;">
                        <a href="#page4" data-transition="flip">Checkout</a>
                    </button>
      <!-- <button id="checkoutBtn" class="ui-btn ui-corner-all">Checkout</button> -->
    </div>

  </div>

  <div data-role="footer" data-position="fixed">
    <div data-role="navbar">
      <ul>
        <li><a href="#page1" class="ui-btn ui-icon-home ui-btn-icon-top">Home</a></li>
        <li><a href="#page2" class="ui-btn ui-icon-plus ui-btn-icon-top">Page 2</a></li>
        <li><a href="#page3" class="ui-btn ui-icon-info ui-btn-icon-top">Page 3</a></li>
        <li><a href="#page4" class="ui-btn ui-icon-location ui-btn-icon-top">Page 4</a></li>
        <li><a href="#page5" class="ui-btn ui-icon-plus ui-btn-icon-top">Page 5</a></li>
      </ul>
    </div>
  </div>
</div>

</html>

【问题讨论】:

ID 应该是唯一的 @RiteshKhandekar 嗨,哪个 ID 以及如何使用? $.each循环:s= s+ "... @RiteshKhandekar 有一个ID tho @Sunny 在 HTML 中,所有 ID 属性必须是唯一的。因此,如果您创建一个循环并为每个循环设置相同的 id,那么它就是无效的 HTML。 【参考方案1】:

您不需要globalIndex,甚至不需要为您的列表项分配唯一的id。您可以使用自定义数据属性并将您的数据存储在列表项本身中。这样,您的数据直接绑定到每个列表视图项,并且您始终可以在单击列表视图项时检索它。

演示:

var arr = [
  img: 'umbrella.png', item: 'Umbrella', price: '$10', value: 1, qty: 0,
  img: 'lipbalm.png', item: 'Lip Balm', price: '$5', value: 2, qty: 0,
  img: 'flu.png', item: 'Flu Medication', price: '$5', value: 3, qty: 0,
  img: 'glucose.png', item: 'Glucose Sweets', price: '$1', value: 4, qty: 0
];

function populateList() 
  var s = '';
  $.each(arr, function (index, item) 
    s += '<li data-icon="false" data-value="' + item.value + '" data-index="' + index + '">';
    s +=   '<a href="#">';
    s +=     '<h3>' + item.item + '</h3>';
    s +=     '<p>' + item.price + '</p>';
    s +=     '<p class="qty">Qty: ' + item.qty + '</p>';
    s +=   '</a>';
    s +=   '<div class="split-custom-wrapper">';
    s +=     '<a href="#" class="ui-btn ui-icon-plus ui-btn-icon-notext split-custom-button"></a>';
    s +=     '<a href="#" class="ui-btn ui-icon-minus ui-btn-icon-notext split-custom-button"></a>';
    s +=   '</div>';
    s += '</li>';
  );
  $("#myList").html(s).listview("refresh");


$(document).on("pagecreate", "#page3", function() 
  populateList();

  $('#myList a.ui-icon-plus').on('vclick', function() 
    // go up to find the parent list item
    var listViewItem = $(this).closest("li"),
        index = parseInt(listViewItem.data("index"));
    // update in array
    arr[index].qty += 1;
    // update in listview
    listViewItem.find(".qty").text("Qty: " + arr[index].qty);
    return false;
  )
  
  $('#myList a.ui-icon-minus').on('vclick', function() 
    var listViewItem = $(this).closest("li"),
        index = parseInt(listViewItem.data("index"));
    if(arr[index].qty > 0) 
      arr[index].qty -= 1;
      listViewItem.find(".qty").text("Qty: " + arr[index].qty);
    
    return false;
  )
  
);
#myList > li > a 
  margin-right: 3em !important;


.split-custom-wrapper 
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;


.split-custom-button 
  position: relative;
  box-sizing: border-box;
  height: 50% !important;
  margin: 0 !important;
  min-width: 3em !important;


#checkoutBtn 
  width: 70%;
  margin-left: auto;
  margin-right: auto;


/* JQM no frills */
.ui-btn,
.ui-btn:hover,
.ui-btn:focus,
.ui-btn:active,
.ui-btn:visited 
  text-shadow: none !important;


/* Remove JQM blue halo */
.ui-btn:focus 
  -moz-box-shadow: none !important;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;


/* Speed-up some android & ios devices */
* 
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
  <link rel="stylesheet" href="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css">
  <script src="https://code.jquery.com/jquery-2.2.4.min.js"></script>
  <script src="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"></script>
</head>

<body>

  <div data-role="page" id="page3">
    <div data-role="main" class="ui-content">
      <ul id="myList" data-role="listview"></ul>
      <br>
      <a id="checkoutBtn" class="ui-btn ui-corner-all" href="#page4" data-transition="flip">Checkout</a>
    </div>

    <div data-role="footer" data-position="fixed">
      <div data-role="navbar">
        <ul>
          <li><a href="#page1" class="ui-btn ui-icon-home ui-btn-icon-top">Home</a></li>
          <li><a href="#page2" class="ui-btn ui-icon-plus ui-btn-icon-top">Page 2</a></li>
          <li><a href="#page3" class="ui-btn ui-icon-info ui-btn-icon-top">Page 3</a></li>
          <li><a href="#page4" class="ui-btn ui-icon-location ui-btn-icon-top">Page 4</a></li>
          <li><a href="#page5" class="ui-btn ui-icon-plus ui-btn-icon-top">Page 5</a></li>
        </ul>
      </div>
    </div>
  </div>
</body>
</html>

【讨论】:

以上是关于其他项目怎么做quan? [私人]的主要内容,如果未能解决你的问题,请参考以下文章

如何将私人加密用户数据存储在数据库中,但使其可供其他选定用户使用?

私人包裹的处理方式是啥?

来自私人 github 存储库的 Pip install wheel

面试中的项目介绍怎么介绍?从哪些方面介绍?一文搞明白(大数据方向,其他方向可借鉴)

面试中的项目介绍怎么介绍?从哪些方面介绍?一文搞明白(大数据方向,其他方向可借鉴)

面试中的项目介绍怎么介绍?从哪些方面介绍?一文搞明白(大数据方向,其他方向可借鉴)