HTML代码实现简易购物车

网上关于购物车实现的代码非常多,本次的这篇文章主要是和大家分享了HTML代码实现简易购物车,有需要的小伙伴可以看一下,接下来讲解一下具体的实现。

1、用html实现内容;

2、用css修饰外观;

3、用js(jq)设计动效。

 

第一步:首先是进行html页面的设计,我用一个大的p将所有商品包含,然后用不同的p将不同的商品进行封装,商品列表中我用了ul li实现,具体实现代码如下(代码中涉及到的商品都是网上随便copy的,不具有参考价值):

立即学习“前端免费学习笔记(深入)”;

  • @@##@@
  • ¥25.00
  • 《飞鸟集》中很多诗歌是用孟加拉文创作的,这部诗集最早由郑振铎先生译介到中国。
  • 加入购物车

  • @@##@@
  • ¥56.00
  • 本书主要介绍了如何使用现有的Web 相关技术构建Android 应用程序。
  • 加入购物车

  • @@##@@
  • ¥37.00
  • 用文字打败时间。冯唐最畅销作品,杂文才是其销量最好、最受欢迎的作品。
  • 加入购物车

  • @@##@@
  • ¥25.00
  • 《飞鸟集》中很多诗歌是用孟加拉文创作的,这部诗集最早由郑振铎先生译介到中国。
  • 加入购物车

  • @@##@@
  • ¥56
  • 本书主要介绍了如何使用现有的Web 相关技术构建Android 应用程序。
  • 加入购物车

  • @@##@@
  • ¥37.00
  • 用文字打败时间。冯唐最畅销作品,杂文才是其销量最好、最受欢迎的作品。
  • 加入购物车

0

@@##@@

      其中涉及到一个知识点:在 

中,我用到了javascript:;这个的意思表示不进行跳转,执行一个空事件。

      第二步:进行外观设计,为了更好的显示,我将包含每个商品列表的p设置了width和height,以及border,值得注意的是,我为了让购物车固定在某个位置,将其position设置为fixed,然后通过设置top和left让其固定在你想要的位置上。另外,要学会灵活使用margin和padding,让显示更美观。

注意:如果想给行内元素设置width和height或者其他块级元素的属性,那么需要设置display:block才可以。
具体设计代码如下:

* {    padding: 0px;    margin: 0px;    font-family: "微软雅黑";}.goodsItem{    width:280px;    height: 400px;    float: left;    border: 1px solid #ccc;    margin:5px;}#goods{    width:910px;}.goditem{    list-style: none;}.godpic img{    display: block;    width:250px;    height: 250px;    margin:0px auto;}.godprice,.godinfo,.godadd{    display: block;    width:220px;    margin:0px auto;    text-align: center;}.godprice{    font-size: 20px;    color: #f00;}.godinfo{    text-align: center;    font-size: 14px;    margin: 10px 0px;}.godadd a{    display: block;    width: 150px;    height: 36px;    background-color: #fd6a01;    border-radius: 10px;    margin: 0px auto;    text-decoration: none;    color:#fff;    line-height: 36px;}#godcar{    position: fixed;    right: 0px;    top:40%;    width: 72px;    height: 64px;}#godcar .dnum{    width:24px;    height: 24px;    border-radius: 12px;    background-color: #f00;    text-align: center;    line-height: 24px;    position: absolute;    font-size: 12px;    top:0px;}.godadd .bg {    background-color: #808080;}

       第一个*表示为所有元素设置属性,在一开始就设置margin和padding是一个很好的习惯。

      第三步:实现了静态页面,接下来需要通过jq进行购物车具体的实现,比如加入购物车,购物车数量变化等。我花了一些时间在设计:如何让商品加入购物车时,图片能够慢慢移动到购物车,然后变小,最后消失。其中,我用到了animate函数实现这个过程。要实现这个功能的难点在于:图片要怎么移动,怎么变化。
接下来讲解如何实现这个过程:

1)首先需要获取到商品的图片,然后将获取到的图片复制一份;

 var img = $(this).parent().find(".godpic").find("img"); var cimg = img.clone();

2)得到商品图片的top和left值,购物车的top和left值,这样才可以通过animate函数实现移动;

var imgtop = img.offset().top;var imgleft = img.offset().left;var cartop = $("#godcar").offset().top;var carleft = $("#godcar").offset().left;

3)编写animate函数,实现具体的效果;

cimg.appendTo($("body")).css({                "position": "absolute",//绝对定位                "opacity": "0.7",                "top": imgtop,                "left": imgleft            }).animate({                "top": cartop,                "left": carleft,                "width": "40px",                "height": "40px",                "opacity": "0.3"   //透明度            }, 1000, function () {                cimg.remove(); //图片消失                $(".dnum").text(i); //购物车数量变化            });

     简单的移动和变化就实现了。

     但是后面又想,每次刷新购物车的数量重新归0好像不符合事实,于是就想着如何实现刷新页面时,不让购物车的数量发生变化,查了资料,总结了三种方法:

(1)保存到数据库;

(2)通过cookie方法;

(3)通过h5的localStorage方法;

     最后我决定采用第三种方法,因为想试试h5的新方法(出于好奇心理~~,也是因为刚好看到这个方法,就试试看),localStorage 方法存储的数据没有时间限制。第二天、第二周或下一年之后,数据依然可用。我的代码具体实现:localStorage.getItem。
  

     好了,所有该讲的都讲完了,附上jq的所有代码,喜欢的就点个赞:

var i = 0;$(function(){    var inum = 0;    if(localStorage.getItem("inum")!==null){        inum = localStorage.getItem("inum");    }    $(".dnum").text(inum);    $(".godadd").click(function(){        if (!$(this).find("a").hasClass("bg")) {            i++;            $(this).find("a").addClass("bg");            var img = $(this).parent().find(".godpic").find("img");            var cimg = img.clone();            var imgtop = img.offset().top;            var imgleft = img.offset().left;            var cartop = $("#godcar").offset().top;            var carleft = $("#godcar").offset().left;            cimg.appendTo($("body")).css({                "position": "absolute",                "opacity": "0.7",                "top": imgtop,                "left": imgleft            }).animate({                "top": cartop,                "left": carleft,                "width": "40px",                "height": "40px",                "opacity": "0.3"            }, 1000, function () {                cimg.remove();                $(".dnum").text(i);                localStorage.setItem("inum", i);            });        }    });});

最终效果图:

HTML代码实现简易购物车

聪明的你学会了吗,赶快实践起来吧!

HTML代码实现简易购物车HTML代码实现简易购物车HTML代码实现简易购物车HTML代码实现简易购物车HTML代码实现简易购物车HTML代码实现简易购物车HTML代码实现简易购物车

以上就是HTML代码实现简易购物车的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1545996.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 17:44:40
下一篇 2025年12月21日 17:44:52

相关推荐

  • 实例详解HTML如何实现文件间自由切换

    本次的这篇文章主要是和大家分享了实例详解HTML如何实现文件间自由切换,有需要的小伙伴可以看一下。 代码很简单(大道至简嘛)。 先创建一个文件,文件名嘛随便,第二个文件名就不能随便了,因为到时候要调用第二个文件。 建好第一个文件后,用记事本打开文件加代码↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓(记得改文件后…

    2025年12月21日
    000
  • webpack对html文件的处理

    本篇文章给大家分享的是关于webpack对html文件的处理 ,步骤都很详细,有需要的朋友可以参考一下 为什么去处理html文件 我们所有的方法都打包到了dist的文件夹下面,而我们的html是在自己定义的文件夹下面,如果自己手动再去一个一个src引入这些dist文件夹下的js,那么也有些太不靠谱了…

    2025年12月21日 好文分享
    000
  • html的基础 理论

    本篇文章给大家分享的是关于html基础 理论知识,内容很不错,有感兴趣的朋友可以看一下 HTML 语义化 HTML标签的语义化是指:通过使用包含语义的标签(如h1-h6)恰当地表示文档结构 css命名的语义化是指:为html标签添加有意义的class 为什么需要语义化: 立即学习“前端免费学习笔记(…

    好文分享 2025年12月21日
    000
  • 关于html、js的一些用法小技巧

    本篇文章给大家分享的内容是关于html、js的一些用法小技巧,有着一定的参考价值,有需要的朋友可以参考一下 一、Form实现Ajax提交表单 function xxx() { var opts = { url : ‘/xxx.do’, type : ‘post’, dataType : ‘json’…

    好文分享 2025年12月21日
    000
  • HTML调用PHP

    html本身是无法处理动态请求,要完成这个,一般是用javascript。在生成静态网页,可以根据数据库id给html页面生成一个相对应的javascript文件引用。比如页面是123.html,那就在这个页面生成一个。 然后在click.php这个页面就按照php的语法去处理操作数据库就行。 静态…

    好文分享 2025年12月21日
    000
  • HTML如何将网页设计自动适应屏幕宽度

    今天本文主要和大家谈谈HTML如何将网页设计自动适应屏幕宽度 ,需要的朋友可以参考下,希望能帮助到大家。 允许网页宽度自动调整 “自适应网页设计”到底是怎么做到的?其实并不难。 首先,在网页代码的头部,加入一行viewport元标签。 viewport是网页默认的宽度和高度,上面这行代码的意思是,网…

    好文分享 2025年12月21日
    000
  • html如何实现字体大小的自适应

    本文主要和大家分析html如何实现字体大小的自适应,需要的朋友可以参考下,希望能帮助到大家。下面跟随小编一起来看一下吧。 <!DOCTYPE html 菜鸟教程(runoob.com) table { font-size: 1vw;} 一行三列: 10010010010010010010010…

    好文分享 2025年12月21日
    000
  • 前端html的实例分享

    本文主要和大家分享前端html的基本用法和实例详解,希望能帮助到大家。 代码要求: 代码如下: Document.body {width: 560px;height: 260px;border: 1px solid black;padding: 20px;font-size: 14px;line-h…

    2025年12月21日
    000
  • 动态生成的HTML标签如何实现绑定事件

    动态用js往HTML生成标签之后如何对生成的HTML标签绑定事件;尝试了很多种方法之后就是绑定不上;今天跟随小编一起来看解决方案吧。 不成功的案例: $(“#id”).change(function(){ console.log(‘需要执行的事情’);}); 发现用上述的方法,对用JS生成的HTML…

    好文分享 2025年12月21日
    000
  • HTML关于结构语义化的问题

    本文主要为大家分享一篇HTML关于结构语义化的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧。 为什么要web语义化?        首先,人可以通过视觉的划分判断内容的语义,搜索引擎看到的只是代码。搜索引擎只能通过标签来判断内容的语义。因为页面的很大一部分流量是来自搜索引擎的…

    2025年12月21日
    000
  • HTML如何实现定位position

    本文主要为大家分享一篇HTML如何实现定位position的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧。 一、css定位(posotioning)属性允许你对元素进行定位, position属性值:      static(默认值):元素框正常生成。块状元素生成一个人矩形框…

    2025年12月21日 好文分享
    000
  • HTML与CSS中背景相关属性

    这次给大家带来html与css中背景相关属性,使用html与css中背景相关属性的注意事项有哪些,下面就是实战案例,一起来看一下。 一. 背景尺寸属性 1.什么是背景尺寸属性 背景尺寸属性是CSS3中新增的一个属性, 专门用于设置背景图片大小 background-size:xxxx; 取值: 1.…

    好文分享 2025年12月21日
    000
  • HTML和XML的区别分析

    在刚开始接触php或者HTML的时候,我们会遇到HTML和XML,可是它们之间有什么区别呢?本文我们主要和大家分享HTML和XML的区别分析,希望能帮助到大家。 一、HTML叫做超文本标记语言; xml是可扩展标记语言;它没有标签集(tagset),也没有语法规则(grammatical rule)…

    好文分享 2025年12月21日
    000
  • 几种关于html和css的使用方法

    本文主要和大家介绍了几种关于html和css的使用方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 html使用方法篇 一:颜色代码 如果你想使用某种颜色,取得它的颜色值即可。比如,您想改变某些文字的颜色,您可以使用下面的代码:改变#符号后的代码即…

    好文分享 2025年12月21日
    000
  • 几个HTML基础知识点

    对于新手来说,一份详细的基础知识点是必要的。本文给大家归纳总结了几个HTML基础知识点,需要的朋友可以参考下,希望能帮助到大家。 HTML 标题 html 标题(heading)是通过 – 等标签进行定义的。 This is a headingThis is a headingThis is a h…

    2025年12月21日
    000
  • HTML与CSS中的过渡模块

    这次给大家带来HTML与CSS中的过渡模块,HTML与CSS中过渡模块的注意事项有哪些,下面就是实战案例,一起来看一下。  a标签的伪类选择器  a标签 1.通过我们的观察发现a标签存在一定的状态 1.1默认状态, 从未被访问过 1.2被访问过的状态 1.3鼠标长按状态 1.4鼠标悬停在a标签上状态…

    2025年12月21日
    000
  • HTML与CSS中2D转换模块

    这次给大家带来html与css中2d转换模块,html与css中2d转换模块的注意事项有哪些,下面就是实战案例,一起来看一下。 一. 2D转换模块 2D转换模块 立即学习“前端免费学习笔记(深入)”; /*其中deg是单位, 代表多少度*/ transform: rotate(45deg);/*第一…

    2025年12月21日 好文分享
    000
  • HTML与CSS中的动画模块

    这次给大家带来html与css中的动画模块,使用html与css中的动画模块注意事项有哪些,下面就是实战案例,一起来看一下。 一. 动画模块 1.过渡和动画之间的异同 1.1不同点 过渡必须人为的触发才会执行动画 动画不需要人为的触发就可以执行动画 立即学习“前端免费学习笔记(深入)”; 1.2相同…

    好文分享 2025年12月21日
    000
  • HTML与CSS中的3D转换模块

    这次给大家带来html与css中的3d转换模块,使用html与css中的3d转换模块注意事项有哪些,下面就是实战案例,一起来看一下。 文中的img标签![](images/jacky/xin.png) 全部变成了macdown格式 一. 什么是2D和3D 1.什么是2D和3D 2D就是一个平面, 只…

    2025年12月21日
    000
  • sublime怎样快速的创建html头部代码

    这次给大家带来sublime怎样快速的创建html头部代码,sublime快速创建html头部代码的注意事项有哪些,下面就是实战案例,一起来看一下。 html5快捷键:html:5 Document xhtml1.1快捷键:html:xxs Document xhtml1.0快捷键:html:xs …

    好文分享 2025年12月21日
    000

发表回复

登录后才能评论
关注微信