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

HTML
<div ng-app="app">
<div class="l-header">
<div class="l-cart">
<div class="l-cart-count" ng-click="showCart = !showCart">{{ calculateTotalProducts() }}</div>
<div class="l-cart-items" ng-show="showCart">
<div ng-show="cart.length">
<ul>
<li ng-repeat="item in cart">
<div class="l-cart-item-name">{{ item.product.name }}</div>
<div class="l-cart-item-quantity">
<input type="number" ng-model="item.quantity" ng-change="removeIfZero(item)" />
</div>
<div class="l-cart-item-subtotal">{{ item.quantity * item.product.price | currency }}</div>
<div class="remove-item">
<img src="https://cdn3.iconfinder.com/data/icons/cleaning-icons/512/Trash_Can-512.png" ng-click="removeFromCart(item)">
</div>
</li>
</ul>
<div class="l-cart-total">total <b>{{ calculateTotalPrice() | currency }}</b></div>
</div>
<div class="l-cart-empty" ng-hide="cart.length">tu carrito está vacío</div>
</div>
</div>
</div>
<ul class="l-stock">
<li class="l-product" ng-repeat="product in stock" ng-click="addToCart(product)" ng-class="{'is-on-cart': isProductOnCart(product)}">
<div class="l-product-name">{{ product.name }}</div>
<div class="l-product-price">{{ product.price | currency }}</div>
</li>
</ul>
</div>
CSS:
body color #333 padding 60px 10px 10px 10px font-family Arial, Helvetica, sans-serif user-select none .is-red color red !important .l-header display flex justify-content flex-end align-items center position fixed top 0 right 0 left 0 height 30px padding 10px background-color #2c3e50 .l-cart position relative .l-cart-count font-size 12px font-weight 700 width 30px line-height 30px text-align center color #ecf0f1 background-color #27ae60 border-radius 50% cursor pointer .l-cart-items position absolute top 100% right 0 width 270px margin 10px -10px 0 0 padding 10px font-size 12px background-color #ecf0f1 &:before content "" position absolute bottom 100% right 15px margin 0 0 -2px 0 border 10px solid transparent border-bottom-color #ecf0f1 li display flex align-items center padding-bottom 10px margin-bottom 10px .l-cart-item-name flex 1 overflow hidden white-space nowrap text-overflow ellipsis .l-cart-item-quantity width 30px margin 0 10px input display block border none padding 5px margin 0 width 100% text-align right appearance none &:focus outline none background-color #ffc &::-webkit-outer-spin-button, &::-webkit-inner-spin-button -webkit-appearance none margin 0 .l-cart-item-subtotal color #000 width 70px text-align right .remove-item img width:30px height:30px margin 0 10px text-align center .l-cart-total margin-top 10 padding-top 10px text-align right border-top 1px solid #bdc3c7 b font-weight 700 font-size 1.4em .l-cart-empty text-align center font-size 1.4em color #95a5a6 .l-stock & > li float left margin 0 10px 10px 0 &:after content "" clear both .l-product display flex color #fff cursor pointer & > div padding 10px .l-product-name background-color #2980b9 .l-product-price background-color #3498db .is-on-cart .l-product-name background-color #27ae60 .l-product-price background-color #2ecc71
JS
/**
* Esta función genera productos aleatoriamente
* (http://marak.com/faker.js/)
**/
function fetchStock () {
var i = 0,
stock = [],
total = faker.random.number({min: 10, max: 30});
for (i = 0; i < total; i++) {
stock.push({
name : faker.commerce.productName(),
price: faker.random.number({min: 1, max: 500})
});
}
return stock;
};
/**
* Aquí empieza nuestro código Angular...
**/
var app = angular.module('app', []);
app.run(function ($rootScope) {
var cart = [],
stock = fetchStock();
var addToCart = function (product) {
var item = cart.find(function (item) {
return item.product === product;
});
if (item) {
item.quantity++;
} else {
cart.push({
product : product,
quantity: 1
});
}
};
var removeFromCart = function (item) {
var index = cart.indexOf(item);
cart.splice(index, 1);
};
var removeIfZero = function (item) {
if (item.quantity < 1) {
removeFromCart(item);
}
};
var calculateTotalPrice = function () {
return cart.reduce(function (sum, item) {
return sum + item.quantity * item.product.price;
}, 0);
};
var calculateTotalProducts = function () {
return cart.reduce(function (sum, item) {
return sum + item.quantity;
}, 0);
};
var isProductOnCart = function (product) {
return cart.some(function (item) {
return item.product === product;
});
};
angular.extend($rootScope, {
stock: stock,
cart: cart,
addToCart: addToCart,
removeFromCart: removeFromCart,
removeIfZero: removeIfZero,
calculateTotalPrice: calculateTotalPrice,
calculateTotalProducts: calculateTotalProducts,
isProductOnCart: isProductOnCart
});
});
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# IONIC
# 购物车
# js购物车实现思路及代码(个人感觉不错)
# Javascript操纵Cookie实现购物车程序
# 简单的前端js+ajax 购物车框架(入门篇)
# js实现简单的购物车有图有代码
# 原生js模拟淘宝购物车项目实战
# 如何解决IONIC页面底部被遮住无法向上滚动问题
# ionic隐藏tabs的方法
# Ionic默认的Tabs模板使用实例
# ionic组件ion-tabs选项卡切换效果实例
# 郁闷!ionic中获取ng-model绑定的值为undefined如何解决
# 大家分享
# 具体内容
# 大家多多
# addToCart
# isProductOnCart
# stock
# est
# vac
# CSS
# padding
# color
相关文章:
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
建站之星安装后界面空白如何解决?
如何通过FTP服务器快速搭建网站?
建站主机选哪种环境更利于SEO优化?
自助网站制作软件,个人如何自助建网站?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
PHP 500报错的快速解决方法
上海网站制作网站建设公司,建筑电工证网上查询系统入口?
建站之星伪静态规则如何正确配置?
Java解压缩zip - 解压缩多个文件或文件夹实例
为什么Go需要go mod文件_Go go mod文件作用说明
如何用PHP快速搭建高效网站?分步指南
建站之星后台密码如何安全设置与找回?
佛山企业网站制作公司有哪些,沟通100网上服务官网?
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
如何在香港服务器上快速搭建免备案网站?
Swift中switch语句区间和元组模式匹配
宁波免费建站如何选择可靠模板与平台?
制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?
北京制作网站的公司,北京铁路集团官方网站?
C#怎么使用委托和事件 C# delegate与event编程方法
如何快速查询网站的真实建站时间?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
简易网站制作视频教程,使用记事本编写一个简单的网页html文件?
公司门户网站制作流程,华为官网怎么做?
教学网站制作软件,学习*后期制作的网站有哪些?
如何通过老薛主机一键快速建站?
网站制作软件有哪些,制图软件有哪些?
青岛网站建设如何选择本地服务器?
黑客入侵网站服务器的常见手法有哪些?
建站之星代理商如何保障技术支持与售后服务?
小捣蛋自助建站系统:数据分析与安全设置双核驱动网站优化
如何快速搭建高效WAP手机网站吸引移动用户?
高防服务器:AI智能防御DDoS攻击与数据安全保障
如何解决VPS建站LNMP环境配置常见问题?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
测试制作网站有哪些,测试性取向的权威测试或者网站?
,购物网站怎么盈利呢?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
如何在阿里云通过域名搭建网站?
如何用美橙互联一键搭建多站合一网站?
如何在万网主机上快速搭建网站?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
如何选择香港主机高效搭建外贸独立站?
济南网站制作的价格,历城一职专官方网站?
如何自定义建站之星模板颜色并下载新样式?
如何快速搭建高效香港服务器网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。