jquery 实现加入购物车功能

请问怎么实现点击加入购物车上方我的购物车数字增加 有动画效果 并且选择哪个产品就出现那个产品的信息 。求详细代码 所有分都给大神
小弟新手 对这么很陌生 请各位不吝赐教!!!谢谢

参考以下代码:

注意需要导入jquery.js.

<!DOCTYPE html>  
<html>  
  <head>  
    <title>购物车----jQuery</title>  
    <meta charset="utf-8" />  
    <style type="text/css">  
      h1 {  
        text-align:center;  
      }  
      table {  
        margin:0 auto;  
        width:60%;  
        border:2px solid #aaa;  
        border-collapse:collapse;  
      }  
      table th, table td {  
        border:2px solid #aaa;  
        padding:5px;  
      }  
      th {  
        background-color:#eee;  
      }  
    </style>  
    <script type="text/javascript" src="./js/jquery.js"></script>  
    <script type="text/javascript">  
      function add_shoppingcart(btn){//将btn(dom)转换为jQuery对象  
        //先获取商品名字和单价还有库存以备后面使用  
        var $tds = $(btn).parent().siblings();  
        //$tds.eq(0)是jQuery对象  $tds[0]是DOM对象  
        var name = $tds.eq(0).html();//string  
        var price = $tds.eq(1).html();//string  
        var stock = $tds.eq(3).html();//string  
          
        //查看库存是否还有<=0  
        if(stock <= 0){  
          return;     
        }  
          
        //无论购物车中是否有该商品,库存都要-1  
        $tds.eq(3).html(--stock);  
          
        //在添加之前确定该商品在购物车中是否存在,若存在,则数量+1,若不存在则创建行  
        var $trs = $("#goods>tr");  
        for(var i=0;i<$trs.length;i++){  
          var $gtds = $trs.eq(i).children();  
          var gName = $gtds.eq(0).html();  
          if(name == gName){//若存在  
            var num = parseInt($gtds.eq(2).children().eq(1).val());  
            $gtds.eq(2).children().eq(1).val(++num);//数量+1  
            //金额从新计算  
            $gtds.eq(3).html(price*num);  
            return;//后面代码不再执行  
          }  
        }  
        //若不存在,创建后追加  
        var li =  
          "<tr>"+  
            "<td>"+name+"</td>"+  
            "<td>"+price+"</td>"+  
            "<td align='center'>"+  
              "<input type='button' value='-' onclick='decrease(this);'/> "+  
              "<input type='text' size='3' readonly value='1'/> "+  
              "<input type='button' value='+' onclick='increase(this);'/>"+  
            "</td>"+  
            "<td>"+price+"</td>"+  
            "<td align='center'>"+  
              "<input type='button' value='x' onclick='del(this);'/>"+  
            "</td>"+  
          "</tr>";  
        //追加到#goods后面  
        $("#goods").append($(li));  
          
        //总计功能  
        total();  
      }  
        
      //辅助方法--单击购物车中的"+"  "-"  "x"按钮是找到相关商品所在td,以jQuery对象返回  
      function findStock(btn){  
        var name = $(btn).parent().siblings().eq(0).html();//获取商品名字  
        //注意table默认有行分组,若此处使用 $("#table1>tr:gt(0)")则找不到任何tr  
        var $trs = $("#table1>tbody>tr:gt(0)");  
        for(var i=0;i<$trs.length;i++){  
          var fName = $trs.eq(i).children().eq(0).html();  
          if(name == fName){//找到匹配的商品  
            return $trs.eq(i).children().eq(3);  
          }  
        }  
      }  
        
      //增加"+"功能  
      function increase(btn){  
        //获取该商品库存看是否<=0  
        var $stock = findStock(btn);  
        var stock = $stock.html();  
        if(stock <= 0){  
          return;  
        }  
        //库存-1    
        $stock.html(--stock);  
        //购物车数据改变  
        var $td = $(btn).prev();  
        var num = parseInt($td.val());//number  
        //num此时为number类型(在计算时会自动转换为number类型)  
        $td.val(++num);  
        //获取单价,再加计算前要先转换为number类型  
        var price = parseInt($(btn).parent().prev().html());  
        $(btn).parent().next().html(num*price);  
          
        //总计功能  
        total();  
      }  
        
      //减少"-"功能  
      function decrease(btn){  
        //该商品数量=1时候不能再减少  
        var num = parseInt($(btn).next().val());  
        if(num <= 1){  
          return;     
        }  
        var $stock = findStock(btn);  
        //库存+1  
        var stock = $stock.html();  
        $stock.html(++stock);  
        //商品数量-1  
        $(btn).next().val(--num);  
        //从新计算金额  
        var price = parseInt($(btn).parent().prev().html());  
        $(btn).parent().next().html(price*num);  
          
        //总计功能  
        total();  
      }  
        
      //"x"删除按钮功能  
      function del(btn){  
        //将商品数量归还库存  
        var $stock = findStock(btn);  
        var stock = parseInt($stock.html());  
        var num = parseInt($(btn).parent().prev().prev().children().eq(1).val());  
        $stock.html(num + stock);  
        //清空改行商品列表  
        $(btn).parent().parent().remove();  
          
        //总计功能  
        total();  
      }  
    //总计功能  
    function total(){  
      //获取所有购物车中的trs  
      var $trs = $("#goods tr");  
      var amount = 0;  
      for(var i=0;i<$trs.length;i++){  
        var money = parseInt($trs.eq(i).children().eq(3).html());  
        amount += money;  
      }  
      //写入总计栏  
      $("#total").html(amount);  
    }  
    </script>  
  </head>  
  <body>  
    <h1>真划算</h1>  
    <table id="table1">  
      <tr>  
        <th>商品</th>  
        <th>单价(元)</th>  
        <th>颜色</th>  
        <th>库存</th>  
        <th>好评率</th>  
        <th>操作</th>  
      </tr>     
      <tr>  
        <td>罗技M185鼠标</td>  
        <td>80</td>  
        <td>黑色</td>  
        <td>5</td>  
        <td>98%</td>  
        <td align="center">  
          <input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/>  
        </td>  
      </tr>  
      <tr>  
        <td>微软X470键盘</td>  
        <td>150</td>  
        <td>黑色</td>  
        <td>9028</td>  
        <td>96%</td>  
        <td align="center">  
          <input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/>  
        </td>  
      </tr>  
      <tr>  
        <td>洛克iphone6手机壳</td>  
        <td>60</td>  
        <td>透明</td>  
        <td>672</td>  
        <td>99%</td>  
        <td align="center">  
          <input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/>  
        </td>  
      </tr>  
      <tr>  
        <td>蓝牙耳机</td>  
        <td>100</td>  
        <td>蓝色</td>  
        <td>8937</td>  
        <td>95%</td>  
        <td align="center">  
          <input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/>  
        </td>  
      </tr>  
      <tr>  
        <td>金士顿U盘</td>  
        <td>70</td>  
        <td>红色</td>  
        <td>482</td>  
        <td>100%</td>  
        <td align="center">  
          <input type="button" value="加入购物车" onclick="add_shoppingcart(this);"/>  
        </td>  
      </tr>  
    </table>  
    
    <h1>购物车</h1>  
    <table>  
      <thead>  
        <tr>  
          <th>商品</th>  
          <th>单价(元)</th>  
          <th>数量</th>  
          <th>金额(元)</th>  
          <th>删除</th>  
        </tr>  
      </thead>  
      <tbody id="goods">  
      </tbody>  
      <tfoot>  
        <tr>  
          <td colspan="3" align="right">总计</td>  
          <td id="total"></td>  
          <td></td>  
        </tr>  
      </tfoot>  
    </table>      
  </body>  
</html>

最终效果图:

温馨提示:内容为网友见解,仅供参考
第1个回答  2015-04-30
站长素材里面搜索“购物车”有好多这样的效果。

http://sc.chinaz.com/jiaobendemo.aspx?downloadid=131125151751482本回答被网友采纳

jquery 实现加入购物车功能
购物车 商品 单价(元) 数量 金额(元) 删除 总计 最终效果图: 已赞过

jquery 弹出框,如下图 ,加入购物车效果???
margin: 0 auto; border-radius: 12px 12px; position: fixed; display:none; } .add2carttip > div { vertical-align: middle; color: #D0D0D0; text-align: center; font-size: 1.2em; font-weight: bold; margin: 0; ...

web前端购物车功能实现
其实思路都是很简单的,如果你要纯前端的实现,那用Javascript或者jquery就可以做了,如果想前后端联动,那么具体数据操作你就提交到后台,然后后台重新返回页面就可以了

请高手帮我看看,这个jQuery实现的购物车表单金额统计出不来结果_百度知...
单价:1.95 这里出现两个tdprice,,很可能导致循环错乱,建议修改方案,给tr一个id吧,按照你的产品id序号给,比如:<tr id="trprice_<% =id %>" class="trprice">... (".add").click(function(){ ...var trpriceObj = $(this).parents("trprice").attr("id");setTotal(trprice...

ecshop jquery冲突,按照网上说的解决冲突的方法修改后,购物车、评论什...
解决思路大概就是屏蔽ECshop扩展的toJSONString方法,用别的函数代替。为了照顾下小菜们,就写详细点吧。一,修改默认js文件 1、首先复制一份 transport.js 改名为 transport.org.js 提供给后台使用 2、屏蔽掉transport.js里的toJSON功能 行数大概有497-737行之间 由if ( ! Object.prototype.toJSON...

java程序员个人简历精选【4篇】
项目功能:用户登录查看书籍信息加入购物车信用卡支付 主要负责:数据库层 项目收获:通过此项目对数据库的操作更加熟悉,使得页面与数据库得到了更好的交互。 (2)电子邮件应用 使用技术:Jsp javaBean servlet MySql JavaMail API ajax 项目功能:邮件发送 接收 查看 主要负责:业务服务器层 项目收获:采用了潮流的Ajax实现...

前端面试时被问到前端布局,这个怎么回答
音乐播放、登入状态、加入购物车 web前端面试被问到为什么离职 实话实说,但是注意言辞,回答过程中千万不要抱怨、或是“吐槽”前东家的种种不好,请客观地叙述与自己现在状态有哪些不相契合的点。 参考:原东家的发展空间达不到我的期望,我想要寻找新的机会挑战自己,同时创造更大的价值。 注意:避免假大空的官话,会...

Vue面试题集锦
③ 功能场景? 单页应用中,组件之间的状态。音乐播放、登录状态、加入购物车等。 ④ vuex的状态: a. State特性:vuex就是一个仓库,仓库里面放了很多对象,其中state就是数据源存放地,对应于一般Vue对象里面的data。state里面存放的数据是响应式的,Vue组件从store中读取数据,若是store中的数据发生改变,依赖这个数据的...

TypeScript是怎么提高JavaScript编程效果的
TypeScript还将大量ECMAScript6功能加入到了JavaScript当中,具体包括类与模块,并尝试将这两种本是同根生的语言加以进一步融合,从而满足ECMAScript6的标准化方法要求。通过这种方式,大家可以利用TypeScript开发出能够为ECMAScript6所接纳的代码,同时充分发挥TypeScript的静态类型优势以提升代码安全性水平。Type...

软件开发工程师个人简历(精选8篇)
3、产品全文搜索:采用compass实现商品的全文搜索功能。用户输入查询关健词就可以搜索到相关商品,匹配度高的商品显示在前面; 4、购物车:用户可以把产品添加入购物车,同一产品如果样式或尺码不同视为两个购物项,对同一商品多次点击“购买”,每点击一次累加购物车中该商品的购买数量。购物车具有添加商品、删除商品、修改商...

相似回答