JavaScript面向?qū)ο缶帉戀徫镘嚬δ?/h1>
更新時間:2016年08月19日 14:28:08 作者:yu.l
這篇文章主要為大家詳細介紹了JavaScript面向?qū)ο缶帉戀徫镘嚬δ艿南嚓P(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
之前的項目中需要一個購買數(shù)據(jù)商品并付款的功能,剛開始一直不敢使用面向?qū)ο蟮膶懛ǎ饕菦]有理清思路,而且那時的數(shù)據(jù)商品比較的復(fù)雜,就一直沒敢動,在網(wǎng)上也找些面向?qū)ο蟮膶懛ǎ阉悸防砬逡槐?,就想自己試著寫寫?nbsp;
接下來我會一步一步分析,面向?qū)ο蟮膶懛ㄟ^程。整個流程大致分為:
1、先定義好一個商品列表的數(shù)據(jù)形式和商品總數(shù)集,類似:
var data = [{name: 'name', unitPrice: 10, num: 2}];
var total = {type: 0, totalNum: 0, price: 0};
很明顯在 data 數(shù)組里 name 表示單個商品名稱,unitPrice 表示單個商品單價,num 表示單個商品數(shù)量;在 total 對象里 type 表示商品種類、totalNum 表示商品總數(shù)量、price 表示商品總價。
2、創(chuàng)建一個購物車的函數(shù)對象 ShoppingCart,并設(shè)置它的相應(yīng)屬性,如下:
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};
}
用一個 info 來把單個商品的名稱、單價、數(shù)量保存起來,然后需要把這個 info 放到 data 數(shù)組里并且計算商品總數(shù)集 total,所以就需要設(shè)置這個函數(shù)對象的兩個方法。就在 this.info 下面添加兩個方法:
this.add();
this.getTotal();
這里要說明一下,為什么要把這兩個方法放在函數(shù)對象的原型里,當(dāng) new 一個實例化對象時,就需要馬上添加這個商品信息和計算商品總數(shù)集,所以沒必要再用這個實例化對象調(diào)用這兩個方法。
然后使用對象的 prototype 屬性,把方法都放在這個屬性里來調(diào)用,如下:
ShoppingCart.prototype = {
// 添加商品
add: function() {
var _this = this;
data.push(_this.info);
},
// 商品總數(shù)集
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 屬性里再添加刪除商品的方法,刪除商品需要依據(jù)一個標(biāo)識來刪除指定的商品,這里我通過 name 值來刪除,這時就需要一個方法去 date 數(shù)組里找對應(yīng)這個 name 的商品,如下:
// 刪除商品
delect: function () {
var _this = this;
data.splice(_this.check(_this.name), 1);
_this.getTotal();
},
// 根據(jù)名稱查商品
check: function (name) {
for (var i = 0; i < data.length; i++) {
if (name == data[i].name) return i;
}
}
4、修改單個商品數(shù)量,如下:
// 修改單個商品的數(shù)量
changeNum: function (num) {
var _this = this;
if (num == 0) {
_this.delect();
return;
}
var _index = _this.check(_this.name);
data[_index].num = num;
_this.getTotal();
}
這里需要傳一個參數(shù),來設(shè)置指定的商品的數(shù)量。
整體代碼如下:
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 數(shù)組初始化數(shù)據(jù)可以是從后臺傳過來的數(shù)據(jù),但是必須數(shù)據(jù)形式和定義的一樣,并且要調(diào)用一下 getTotal 這個方法獲取商品總數(shù)集。
最后就是簡單的 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 打印出來看看結(jié)果\(^o^)/~
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- js購物車實現(xiàn)思路及代碼(個人感覺不錯)
- js實現(xiàn)簡單的購物車有圖有代碼
- Javascript操縱Cookie實現(xiàn)購物車程序
- JavaScript編寫一個簡易購物車功能
- 原生js模擬淘寶購物車項目實戰(zhàn)
- js實現(xiàn)仿購物車加減效果
- 使用Angular.js實現(xiàn)簡單的購物車功能
- 基于JavaScript實現(xiàn)添加到購物車效果附源碼下載
- JS+HTML5實現(xiàn)的前端購物車功能插件實例【附demo源碼下載】
- JS高仿拋物線加入購物車特效實現(xiàn)代碼
- js繪制購物車拋物線動畫
- JS實現(xiàn)的簡單拖拽購物車功能示例【附源碼下載】
相關(guān)文章
-
使用iframe window的scroll方法控制iframe頁面滾動
在頁面中如何控制內(nèi)嵌的iframe滾動呢?方法是使用iframe window的scroll方法,大家可以參考下面的示例 2014-03-03
-
JavaScript中valueOf函數(shù)與toString方法深入理解
基本上,所有JS數(shù)據(jù)類型都擁有valueOf和toString這兩個方法,null除外。它們倆解決javascript值運算與顯示的問題,本文將詳細介紹,有需要的朋友可以參考下 2012-12-12
-
echarts餅圖自定義設(shè)置顏色的3種實現(xiàn)方式
ECharts餅圖的顏色可以通過多種方式進行設(shè)置,下面這篇文章主要給大家介紹了關(guān)于echarts餅圖自定義設(shè)置顏色的3種實現(xiàn)方式,文中通過代碼介紹的非常詳細,需要的朋友可以參考下 2024-02-02
-
javascript showModalDialog,open取得父窗口的方法
showModalDialog,open取得父窗口的代碼,需要的朋友可以參考下。 2010-03-03
最新評論
之前的項目中需要一個購買數(shù)據(jù)商品并付款的功能,剛開始一直不敢使用面向?qū)ο蟮膶懛ǎ饕菦]有理清思路,而且那時的數(shù)據(jù)商品比較的復(fù)雜,就一直沒敢動,在網(wǎng)上也找些面向?qū)ο蟮膶懛ǎ阉悸防砬逡槐?,就想自己試著寫寫?nbsp;
接下來我會一步一步分析,面向?qū)ο蟮膶懛ㄟ^程。整個流程大致分為:
1、先定義好一個商品列表的數(shù)據(jù)形式和商品總數(shù)集,類似:
var data = [{name: 'name', unitPrice: 10, num: 2}]; var total = {type: 0, totalNum: 0, price: 0};
很明顯在 data 數(shù)組里 name 表示單個商品名稱,unitPrice 表示單個商品單價,num 表示單個商品數(shù)量;在 total 對象里 type 表示商品種類、totalNum 表示商品總數(shù)量、price 表示商品總價。
2、創(chuàng)建一個購物車的函數(shù)對象 ShoppingCart,并設(shè)置它的相應(yīng)屬性,如下:
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}; }
用一個 info 來把單個商品的名稱、單價、數(shù)量保存起來,然后需要把這個 info 放到 data 數(shù)組里并且計算商品總數(shù)集 total,所以就需要設(shè)置這個函數(shù)對象的兩個方法。就在 this.info 下面添加兩個方法:
this.add();
this.getTotal();
這里要說明一下,為什么要把這兩個方法放在函數(shù)對象的原型里,當(dāng) new 一個實例化對象時,就需要馬上添加這個商品信息和計算商品總數(shù)集,所以沒必要再用這個實例化對象調(diào)用這兩個方法。
然后使用對象的 prototype 屬性,把方法都放在這個屬性里來調(diào)用,如下:
ShoppingCart.prototype = { // 添加商品 add: function() { var _this = this; data.push(_this.info); }, // 商品總數(shù)集 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 屬性里再添加刪除商品的方法,刪除商品需要依據(jù)一個標(biāo)識來刪除指定的商品,這里我通過 name 值來刪除,這時就需要一個方法去 date 數(shù)組里找對應(yīng)這個 name 的商品,如下:
// 刪除商品 delect: function () { var _this = this; data.splice(_this.check(_this.name), 1); _this.getTotal(); }, // 根據(jù)名稱查商品 check: function (name) { for (var i = 0; i < data.length; i++) { if (name == data[i].name) return i; } }
4、修改單個商品數(shù)量,如下:
// 修改單個商品的數(shù)量 changeNum: function (num) { var _this = this; if (num == 0) { _this.delect(); return; } var _index = _this.check(_this.name); data[_index].num = num; _this.getTotal(); }
這里需要傳一個參數(shù),來設(shè)置指定的商品的數(shù)量。
整體代碼如下:
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 數(shù)組初始化數(shù)據(jù)可以是從后臺傳過來的數(shù)據(jù),但是必須數(shù)據(jù)形式和定義的一樣,并且要調(diào)用一下 getTotal 這個方法獲取商品總數(shù)集。
最后就是簡單的 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 打印出來看看結(jié)果\(^o^)/~
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js購物車實現(xiàn)思路及代碼(個人感覺不錯)
- js實現(xiàn)簡單的購物車有圖有代碼
- Javascript操縱Cookie實現(xiàn)購物車程序
- JavaScript編寫一個簡易購物車功能
- 原生js模擬淘寶購物車項目實戰(zhàn)
- js實現(xiàn)仿購物車加減效果
- 使用Angular.js實現(xiàn)簡單的購物車功能
- 基于JavaScript實現(xiàn)添加到購物車效果附源碼下載
- JS+HTML5實現(xiàn)的前端購物車功能插件實例【附demo源碼下載】
- JS高仿拋物線加入購物車特效實現(xiàn)代碼
- js繪制購物車拋物線動畫
- JS實現(xiàn)的簡單拖拽購物車功能示例【附源碼下載】
相關(guān)文章
使用iframe window的scroll方法控制iframe頁面滾動
在頁面中如何控制內(nèi)嵌的iframe滾動呢?方法是使用iframe window的scroll方法,大家可以參考下面的示例2014-03-03JavaScript中valueOf函數(shù)與toString方法深入理解
基本上,所有JS數(shù)據(jù)類型都擁有valueOf和toString這兩個方法,null除外。它們倆解決javascript值運算與顯示的問題,本文將詳細介紹,有需要的朋友可以參考下2012-12-12echarts餅圖自定義設(shè)置顏色的3種實現(xiàn)方式
ECharts餅圖的顏色可以通過多種方式進行設(shè)置,下面這篇文章主要給大家介紹了關(guān)于echarts餅圖自定義設(shè)置顏色的3種實現(xiàn)方式,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-02-02javascript showModalDialog,open取得父窗口的方法
showModalDialog,open取得父窗口的代碼,需要的朋友可以參考下。2010-03-03