點擊增加或者減少商品數量並且自動計算總價格

来源:http://www.cnblogs.com/softwhy/archive/2016/01/30/5170411.html
-Advertisement-
Play Games

點擊增加或者減少商品數量並且自動計算總價格:本章節介紹一下如何實現點擊按鈕來添加或者刪除商品的數量,並且能夠自動計算商品的總價格。代碼實例如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" con


點擊增加或者減少商品數量並且自動計算總價格:
本章節介紹一下如何實現點擊按鈕來添加或者刪除商品的數量,並且能夠自動計算商品的總價格。
代碼實例如下:

<!DOCTYPE html> 
<html> 
<head> 
<meta charset=" utf-8"> 
<meta name="author" content="http://www.softwhy.com/" /> 
<title>螞蟻部落</title> 
<style type="text/css">
span{
  color:red;
  cursor:pointer;
}
</style>
<script type="text/javascript" src="mytest/jQuery/jquery-1.8.3.js"></script>
<script type="text/javascript">
$(function(){
  $("#quantity").keyup(function(){
    if(isNaN($(this).val())||parseInt($(this).val())<1){
      $(this).val("1");
      $("#totalPrice").html($("#price").val());
      return;
    }
    var total=parseFloat($("#price").val())*parseInt($(this).val());
    $("#totalPrice").html(total.toFixed(2));
  })
   
  $("#add").click(function(){
    numAdd();
  });
   
  $("#del").click(function(){
    numDec();
  });
})
/*商品數量+1*/
function numAdd(){
  var num_add = parseInt($("#quantity").val())+1;
  if($("#quantity").val()==""){
    num_add = 1;
  }
  $("#quantity").val(num_add);
  var total = parseFloat($("#price").val())*parseInt($("#quantity").val());
  $("#totalPrice").html(total.toFixed(2));
}
/*商品數量-1*/
function numDec(){
  var num_dec = parseInt($("#quantity").val())-1;
  if(num_dec<1){
    //購買數量必須大於或等於1
    alert("not lt 1");
  }
  else{
    $("#quantity").val(num_dec);
    var total = parseFloat($("#price").val())*parseInt($("#quantity").val());
    $("#totalPrice").html(total.toFixed(2));
  }
}
</script>
</head>
<body>
<p>
  數量:<span id="del">-</span> 
  <input type="text" id="quantity" /> 
  <span id="add">+</span>
</p>
<p class="sdsd">
  總價格:<span id="totalPrice">28.10</span>
</p>
<input type="hidden" value="28.1" id="price" />
</body>
</html>

以上代碼中,點擊左右按鈕可以實現上篇的增減,並且能夠自動計算總價格,在文本框手動寫入數量的時候也能夠自動計算總價格,下麵介紹一下它的實現過程:
一.代碼註釋:
1.$(function(){}),當文檔結構完全載入完畢再去執行函數中的代碼。
2.$("#quantity").keyup(function(){}),為文本框註冊keyup事件處理函數。
3.if(isNaN($(this).val())||parseInt($(this).val())<1),判斷文本框中的內容是否非數字或者小於1.
4.$(this).val("1"),將文本框的內容設置為1。
5.$("#totalPrice").html($("#price").val()),將顯示價格的span元素的內容設置為id屬性值為price提供的價格。
6.return,跳出函數的執行。
7.var total=parseFloat($("#price").val())*parseInt($(this).val()),計算商品的總價格。
8.$("#totalPrice").html(total.toFixed(2)),將總價格寫入span元素。
9.$("#add").click(function(){}),註冊事件處理函數,點擊可以添加商品數量。
10.$("#del").click(function(){}),註冊事件處理函數,點擊可以刪除商品數量。
11.function numAdd(){},此函數可以添加商品數量並且能夠自動計算總價格。
12.var num_add = parseInt($("#quantity").val())+1,將文本框數字值加1.
13.if($("#quantity").val()==""){num_add = 1;},如果文本框的內容為空,則將num_add值設置為1。
14.$("#quantity").val(num_add),設置文本框的值。
15.var total = parseFloat($("#price").val())*parseInt($("#quantity").val()),計算總價格。
16.$("#totalPrice").html(total.toFixed(2)),對價格進行保留兩位小數處理,並寫入span。
二.相關閱讀:
1.isNaN()函數可以參閱JavaScript的isNaN()方法一章節。
2.parseInt()函數可以參閱javascript的parseInt()函數一章節。 
3.html()函數可以參閱jQuery的html()方法一章節。 
4.parseFloat()函數可以參閱javascript的parseFloat()方法一章節。 
5.toFixed()函數可以參閱javascript的Number對象的toFixed()方法一章節。

原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=13693

更多內容可以參閱:http://www.softwhy.com/jquery/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.0 jQuery 序列化表單數據 serialize() 得到的是 ""; 表單元素沒有name屬性.(用的美工的頁面,沒註意這個細節.)
  • css如何設置文本在li元素中垂直居中顯示:本章節介紹一下如何利用css將文本設置為在li元素中垂直居中效果。實現此效果非常的簡單,只要利用line-height屬性即可。代碼實例如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <m
  • 點擊enter和ctrol實現表單提交效果:大家一定都用過QQ聊天軟體,當發送信息的時候,可以選擇點擊回車或者點擊enter+ctrol,本人更加傾向於後者,因為可以有效的防止誤操作,因為回車也有換行的功能,也防止了兩者的衝突,下麵介紹一下如何使用enter和ctrol組合鍵實現提交表單效果。代碼如
  • 使用setTimeout()實現倒計時效果代碼實例:大多數情況下實現倒計時效果是使用setInterval()函數,因為此函數可以每隔指定的實現就執行一次指定函數,而setTimeout()函數只能夠執行一次,不過也是可以實現倒計時效果的,下麵就通過代碼實例介紹一下如何利用setTimeout()函
  • css3各種類型瀏覽器首碼簡單分享:在寫此文章的時候,很多css3屬性在當前還屬於實驗性質的,在使用它們的時候,前面通常要加上各個類型瀏覽器的首碼。下麵就做一下分享羅列: -webkit-transform:rotate(45deg);/*谷歌和Safari瀏覽器*/ -o-transform:ro
  • jQuery實現的監聽回車按鍵代碼實例:回車鍵是最為常用的按鍵之一,所以點擊回車來執行一段代碼是比較常見的操作,下麵就通過實例代碼介紹一下如何實現此功能。代碼如下: <!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="a
  • js如何使用指定字元分割字元串:在實際應用中,可能需要將字元進行分割,然後進行相關操作,下麵就給出這樣一個代碼實例供大家參考。代碼如下: var str="a-n-t-z-o-n-e"; var theArray=str.split("-"); console.log(theArray); 以上代碼
  • <link>和@import url()引入外部css文件的區別:標題中的兩種方式都可以引入外部css文件,關於它們的基本用法這裡就不多介紹了,具體可以參閱相關閱讀。相關閱讀:(1).<link>標簽可以參閱HTML的<link>標簽一章節。(2).@import url()可以參閱css的@imp
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...