我的编程空间,编程开发者的网络收藏夹
学习永远不晚

原生JavaScript实现购物车效果

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

原生JavaScript实现购物车效果

本文实例为大家分享了JavaScript实现购物车效果的具体代码,供大家参考,具体内容如下

HTML:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        <style type="text/css">
            table {
                border: 1px solid #e9e9e9;
                border-collapse: collapse;
                border-spacing: 0;
            }
 
            td {
                padding: 8px 16px;
                border: 1px solid #e9e9e9;
                text-align: left;
            }
 
            td img {
                width: 50px;
                height: 50px;
            }
 
            th {
                background-color: #f7f7f7;
                color: #5c6b77;
                font-weight: 600;
            }
        </style>
    </head>
    <body>
        图书类型:<select id="xlxx" onchange="tslx()">
            <option value="全部">全部</option>
            <option value="科幻">科幻</option>
            <option value="小说">小说</option>
            <option value="文学">文学</option>
            <option value="悬疑">悬疑</option>
        </select>
        <table border="0">
            <tr>
                <th><button type="button" style="border: 0;background-color: #f7f7f7;" id="qbxz"
                        onclick="quanxuan ()">全选</button></th>
                <th>序号</th>
                <th>商品名</th>
                <th>书籍名</th>
                <th>分类</th>
                <th>价格</th>
                <th>购买数量</th>
                <th>操作</th>
            </tr>
            <tr name="wx">
                <td><input type="checkbox" name="cb" onchange="zhjs()" id="" value="" class="qx" /></td>
                <td>1</td>
                <td><img onmouseover="tpmax(this.class="lazy" data-src)" onmouseout="tpmin()" class="lazy" data-src="../img/20180520083915_sMx82.jpeg"></td>
                <td>活着</td>
                <td>文学</td>
                <td><label name="jg">25</label></td>
                <td>
                    <button onclick="jia('num1')">+</button>
                    <label id="num1" name="num">1</label>
                    <button onclick="jian('num1')">-</button>
                </td>
                <td><button onclick="deletet(1)">移除</button></td>
            </tr>
            <tr name="kh">
                <td><input type="checkbox" name="cb" onchange="zhjs()" id="" value="" class="qx" /></td>
                <td>2</td>
                <td><img onmouseover="tpmax(this.class="lazy" data-src)" onmouseout="tpmin()" class="lazy" data-src="../img/20180520083916_8ntMr.jpeg"></td>
                <td>活着2</td>
                <td>科幻</td>
                <td><label name="jg">30</label></td>
                <td>
                    <button onclick="jia('num2')">+</button>
                    <label id="num2" name="num">1</label>
                    <button onclick="jian('num2')">-</button>
                </td>
                    <td><button onclick="deletet(2)">移除</button></td>
            </tr>
            <tr name="xs">
                <td><input type="checkbox" name="cb" onchange="zhjs()" id="" value="" class="qx" /></td>
                <td>3</td>
                <td><img onmouseover="tpmax(this.class="lazy" data-src)" onmouseout="tpmin()" class="lazy" data-src="../img/20191227173047_zrXxQ.jpeg"></td>
                <td>活着3</td>
                <td>小说</td>
                <td><label name="jg">35</label></td>
                <td>
                    <button onclick="jia('num3')">+</button>
                    <label id="num3" name="num">1</label>
                    <button onclick="jian('num3')">-</button>
                </td>
                    <td><button onclick="deletet(3)">移除</button></td>
            </tr>
            <tr name="xy">
                <td><input type="checkbox" name="cb" onchange="zhjs()" id="" value="" class="qx" /></td>
                <td>4</td>
                <td><img onmouseover="tpmax(this.class="lazy" data-src)" onmouseout="tpmin()" class="lazy" data-src="../img/20191227173048_eGeBA.jpeg"></td>
                <td>活着4</td>
                <td>悬疑</td>
                <td><label name="jg">40</label></td>
                <td>
                    <button onclick="jia('num4')">+</button>
                    <label id="num4" name="num">1</label>
                    <button onclick="jian('num4')">-</button>
                </td>
                    <td><button onclick="deletet(4)">移除</button></td>
            </tr>
 
        </table>
        <h1 id="nr" style="display: none;">购物车为空!</h1>
 
        总金额:<label id="zh" style="color: red;">0</label>¥
 
        <img class="lazy" data-src="" style="width: 150px;" id="img">
 
    </body>
    
    <script type="text/javascript">
        
    </script>
    <script class="lazy" data-src="../js/gwc.js" type="text/javascript" charset="utf-8"></script>
</html>

JavaScript:


 
// 1.图片悬浮时的放大
 
// 图片移入放大
function tpmax(lj) {
    //移入 将获取到的图片路径加载到下方显示图片路径实现移入显示
    document.getElementById("img").class="lazy" data-src = lj
}
// 图片移出隐藏
function tpmin() {
    //移出 将空的图片路径加载到下方显示图片路径实现移出不显示
    document.getElementById("img").class="lazy" data-src = "";
}
 
// 2.全选
function quanxuan() {
    var qxaj = document.getElementsByClassName("qx");
    // 遍历判断复选框的状态
    for (var i = 0; i < qxaj.length; i++) {
        if (qxaj[i].checked == true) {
            for (var i = 0; i < qxaj.length; i++) {
                qxaj[i].checked = false;
            }
 
        } else {
            for (var i = 0; i < qxaj.length; i++) {
                qxaj[i].checked = true;
            }
        }
    }
    zhjs();
}
 
// 3.分类

function tslx() {
    var xlxx = document.getElementById("xlxx").value;
    var kh = document.getElementsByName("kh");
    var xs = document.getElementsByName("xs");
    var wx = document.getElementsByName("wx");
    var xy = document.getElementsByName("xy");
    if (xlxx == "全部") {
        xianshi(kh);
        xianshi(xs);
        xianshi(wx);
        xianshi(xy);
    }
    if (xlxx == "科幻") {
        xianshi(kh);
        yincang(xs);
        yincang(wx);
        yincang(xy);
    }
    if (xlxx == "文学") {
        yincang(kh);
        yincang(xs);
        xianshi(wx);
        yincang(xy);
    }
    if (xlxx == "小说") {
        yincang(kh);
        xianshi(xs);
        yincang(wx);
        yincang(xy);
    }
    if (xlxx == "悬疑") {
        yincang(kh);
        yincang(xs);
        yincang(wx);
        xianshi(xy);
    }
}
 
// 显示
function xianshi(xlxx) {
    // 遍历寻找匹配的值
    for (var i = 0; i < xlxx.length; i++) {
        xlxx[i].style.visibility = "visible";
    }
}
 
// 隐藏
function yincang(xlxx) {
    for (var i = 0; i < xlxx.length; i++) {
        xlxx[i].style.visibility = "collapse";
    }
}
 
 
// 4.数值的加减
function jian(numid) {
    var num = document.getElementById(numid).innerHTML;
    var ljnum = parseInt(num) - 1;
    if (ljnum > 0) {
        document.getElementById(numid).innerHTML = ljnum;
    }
    zhjs();
}
 
function jia(numid) {
    // 得到原始值
    var num = document.getElementById(numid).innerHTML;
    // 得到累加值
    var ljnum = parseInt(num) + 1;
    // 赋值
    document.getElementById(numid).innerHTML = ljnum;
    zhjs();
}
 
 
//5.总和计算
function zhjs() {
    var jg = document.getElementsByName("jg");
    var sl = document.getElementsByName("num");
    var cb = document.getElementsByName("cb");
    var sum = 0;
    for (var i = 0; i < cb.length; i++) {
        if (cb[i].checked == true) {
            sum += parseInt(jg[i].innerHTML) * parseInt(sl[i].innerHTML);
        }
    }
 
    document.getElementById("zh").innerHTML = sum;
}
 
 
// 6.删除
 
// 遍历全部tr
var s = 0;
var qbtr = document.getElementsByTagName("tr");
for (var i = 0; i < qbtr.length; i++) {
    s++;
}
function deletet(index) {
    // tr()
    var c = document.getElementsByName("cb");
    c[index - 1].checked = false;
    var h = document.getElementsByTagName("tr");
    h[index].style.display = "none";
    s--;
    if (s == 1) {
        document.getElementById("nr").style.display = "block";
        document.getElementById("cartb").style.display = "none";
        document.getElementById("stype").style.display = "none";
    }
    zhjs();
 
 
}

效果:

全选:

分类:

删除:

添加数量

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

原生JavaScript实现购物车效果

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么使用Android实现购物车页面及购物车效果

这篇文章主要介绍了怎么使用Android实现购物车页面及购物车效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Android实现购物车页面及购物车效果(点击动画),具体如下
2023-05-30

原生js怎么实现购物车功能

本篇内容介绍了“原生js怎么实现购物车功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!* 实现购物车商品数量的加减,注意数量最少为1,数量
2023-06-30

JavaScript实现购物车图片局部放大预览效果

这篇文章主要为大家详细介绍了JavaScript如何通过canvas简单实现购物车图片放大预览效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
2023-03-07

Android实现购物车添加物品的动画效果

前言:当我们写商城类的项目的时候,一般都会有加入购物车的功能,加入购物车的时候会有一些抛物线动画,最近做到这个功能,借助别人的demo写了一个。 效果:开发环境:AndroidStudio2.1.2+gradle-2.10 涉及知识:1.沉
2022-06-06

View Controller Transition实现京东加购物车效果

这篇文章中我们主要来叙述一下上述动画效果的实现方案。主要涉及 View Controller 转场动画的知识。我搭建了个人站点,那里有更多内容,请多多指教。点我哦!!!Presenting a View Controller显示一个 Vie
2023-05-31

JavaScript如何实现购物车图片局部放大预览效果

这篇文章主要介绍了JavaScript如何实现购物车图片局部放大预览效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript如何实现购物车图片局部放大预览效果文章都会有所收获,下面我们一起来看看吧
2023-07-05

vue怎么实现购物车小球动画效果

这篇文章主要介绍“vue怎么实现购物车小球动画效果”,在日常操作中,相信很多人在vue怎么实现购物车小球动画效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue怎么实现购物车小球动画效果”的疑惑有所帮助!
2023-07-04

JavaScript如何实现购物车怎么

这篇文章主要介绍了JavaScript如何实现购物车怎么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体内容如下HTML结构
2023-06-26

原生js实现计算购物车总金额的示例

本文主要介绍了原生js实现计算购物车总金额的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-16

编程热搜

目录