时间:2021-05-26
之前的项目中需要一个购买数据商品并付款的功能,刚开始一直不敢使用面向对象的写法,主要是没有理清思路,而且那时的数据商品比较的复杂,就一直没敢动,在网上也找些面向对象的写法,把思路理清一遍,就想自己试着写写。
接下来我会一步一步分析,面向对象的写法过程。整个流程大致分为:
1、先定义好一个商品列表的数据形式和商品总数集,类似:
很明显在 data 数组里 name 表示单个商品名称,unitPrice 表示单个商品单价,num 表示单个商品数量;在 total 对象里 type 表示商品种类、totalNum 表示商品总数量、price 表示商品总价。
2、创建一个购物车的函数对象 ShoppingCart,并设置它的相应属性,如下:
用一个 info 来把单个商品的名称、单价、数量保存起来,然后需要把这个 info 放到 data 数组里并且计算商品总数集 total,所以就需要设置这个函数对象的两个方法。就在 this.info 下面添加两个方法:
this.add();
this.getTotal();
这里要说明一下,为什么要把这两个方法放在函数对象的原型里,当 new 一个实例化对象时,就需要马上添加这个商品信息和计算商品总数集,所以没必要再用这个实例化对象调用这两个方法。
然后使用对象的 prototype 属性,把方法都放在这个属性里来调用,如下:
ShoppingCart.prototype = { // 添加商品 add: function() { var _this = this; data.push(_this.info); }, // 商品总数集 getTotal: function () { total.type = data.length; total.totalNum = 0; total.price = 0; for (var i = 0; i < data.length; i++) { total.totalNum += data[i].num; total.price += data[i].num * data[i].unitPrice; } }}3、有添加就会有删除单个商品,就在 prototype 属性里再添加删除商品的方法,删除商品需要依据一个标识来删除指定的商品,这里我通过 name 值来删除,这时就需要一个方法去 date 数组里找对应这个 name 的商品,如下:
// 删除商品delect: function () { var _this = this; data.splice(_this.check(_this.name), 1); _this.getTotal();},// 根据名称查商品check: function (name) { for (var i = 0; i < data.length; i++) { if (name == data[i].name) return i; }}4、修改单个商品数量,如下:
// 修改单个商品的数量changeNum: function (num) { var _this = this; if (num == 0) { _this.delect(); return; } var _index = _this.check(_this.name); data[_index].num = num; _this.getTotal();}这里需要传一个参数,来设置指定的商品的数量。
整体代码如下:
var data = new Array;var total = {type: 0, totalNum : 0, price:0};function ShoppingCart (name, unitPrice, num) { this.name = name; this.unitPrice = unitPrice; this.num = num; this.info = {name: this.name,unitPrice: this.unitPrice,num: this.num}; this.add(); this.getTotal();}ShoppingCart.prototype = { add: function() { var _this = this; data.push(_this.info); }, getTotal: function () { total.type = data.length; total.totalNum = 0; total.price = 0; for (var i = 0; i < data.length; i++) { total.totalNum += data[i].num; total.price += data[i].num * data[i].unitPrice; } }, delect: function () { var _this = this; data.splice(_this.check(_this.name), 1); _this.getTotal(); }, changeNum: function (num) { var _this = this; if (num == 0) { _this.delect(); return; } var _index = _this.check(_this.name); data[_index].num = num; _this.getTotal(); }, check: function (name) { for (var i = 0; i < data.length; i++) { if (name == data[i].name) return i; } }}这个 data 数组初始化数据可以是从后台传过来的数据,但是必须数据形式和定义的一样,并且要调用一下 getTotal 这个方法获取商品总数集。
最后就是简单的 new 一个个实例化,例如:
var goods1 = new ShoppingCart('123', 100, 2 )var goods2 = new ShoppingCart('456', 10, 3 )var goods3 = new ShoppingCart('789', 1, 4 )goods2.delect();good3.changeNum(2)goods2 = new ShoppingCart('1234', 11, 1 )goods2.changeNum(0)自行可以把 data 和 total 打印出来看看结果\(^o^)/~
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了java实现购物车功能的具体代码,供大家参考,具体内容如下1需要实现1、实现淘淘商城的购物车功能2购物车功能2.1功能说明1、商品加入购物车
淘宝购物车惊喜券主要是针对已加入购物车但还未下单的商品,在其购物车页面向消费者系统推送商品优惠券,主要就是为了刺激消费,那淘宝购物车惊喜券在哪领?下面来我们就来
本文实例讲述了PHP实现的购物车类。分享给大家供大家参考。具体分析如下:该购物车类是基于CodeIgniter的购物车类仿写实现的。购物车基本功能如下:1)将物
本文实例讲述了php实现仿写CodeIgniter的购物车类。分享给大家供大家参考。具体如下:这里仿写CodeIgniter的购物车类购物车基本功能:1)将物品
增加购物车功能。用户在选择适合自己的商品之后,可以将选购的商品添加到购物车,最后通过购物车中的结算功能,统一对选择的单个或多个商品进行结算。用户在确认订单之后就