热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php购物车页面如何做,HTML代码实现简易购物车

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

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

1、用html实现内容;

2、用css修饰外观;

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

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

  • 1.png
  • ¥25.00
  • 《飞鸟集》中很多诗歌是用孟加拉文创作的,这部诗集最早由郑振铎先生译介到中国。
  • 加入购物车
  • 2.png
  • ¥56.00
  • 本书主要介绍了如何使用现有的Web 相关技术构建Android 应用程序。
  • 加入购物车
  • 3.png
  • ¥37.00
  • 用文字打败时间。冯唐最畅销作品,杂文才是其销量最好、最受欢迎的作品。
  • 加入购物车
  • 1.png
  • ¥25.00
  • 《飞鸟集》中很多诗歌是用孟加拉文创作的,这部诗集最早由郑振铎先生译介到中国。
  • 加入购物车
  • 2.png
  • ¥56
  • 本书主要介绍了如何使用现有的Web 相关技术构建Android 应用程序。
  • 加入购物车
  • 3.png
  • ¥37.00
  • 用文字打败时间。冯唐最畅销作品,杂文才是其销量最好、最受欢迎的作品。
  • 加入购物车

0

car.jpg

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

加入购物车

中,我用到了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);

});

}

});

});

最终效果图:

5470b66c29ac52af8c8d56b962d9cc9a.png

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



推荐阅读
  • 本文详细探讨了JavaScript中的作用域链和闭包机制,解释了它们的工作原理及其在实际编程中的应用。通过具体的代码示例,帮助读者更好地理解和掌握这些概念。 ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • Python 内存管理机制详解
    本文深入探讨了Python的内存管理机制,涵盖了垃圾回收、引用计数和内存池机制。通过具体示例和专业解释,帮助读者理解Python如何高效地管理和释放内存资源。 ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 本文介绍如何使用 Android 的 Canvas 和 View 组件创建一个简单的绘图板应用程序,支持触摸绘画和保存图片功能。 ... [详细]
  • Appium + Java 自动化测试中处理页面空白区域点击问题
    在进行移动应用自动化测试时,有时会遇到某些页面没有返回按钮,只能通过点击空白区域返回的情况。本文将探讨如何在Appium + Java环境中有效解决此类问题,并提供详细的解决方案。 ... [详细]
  • 本文详细介绍了JSP的三大指令:page、include和taglib,重点探讨了静态包含与动态包含的区别及其应用场景,并解释了如何使用taglib指令引入第三方标签库。 ... [详细]
  • 2018-2019学年第六周《Java数据结构与算法》学习总结
    本文总结了2018-2019学年第六周在《Java数据结构与算法》课程中的学习内容,重点介绍了非线性数据结构——树的相关知识及其应用。 ... [详细]
  • 实用正则表达式有哪些
    小编给大家分享一下实用正则表达式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 解决TensorFlow CPU版本安装中的依赖问题
    本文记录了在安装CPU版本的TensorFlow过程中遇到的依赖问题及解决方案,特别是numpy版本不匹配和动态链接库(DLL)错误。通过详细的步骤说明和专业建议,帮助读者顺利安装并使用TensorFlow。 ... [详细]
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • 探讨在 Vue 框架中遇到的数据更新延迟或失败的问题,并提供解决方案。 ... [详细]
  • 本文主要介绍了线油书的部分资料及其对相关领域的启示与影响。通过详细的数据分析和案例研究,探讨了线油书在未来的发展潜力。 ... [详细]
  • 动画队列的设计目的是为了确保一系列任务能够按照预定顺序执行,每个任务只有在其前一个任务完成后才开始。这些任务既可以是同步的,也可以是异步的。本文将探讨jQuery动画系统中的队列机制,并介绍如何使用队列来优化动画效果。 ... [详细]
author-avatar
用户19910071
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有