angularjs实现简单的购物车功能


Posted in Javascript onSeptember 21, 2017

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

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <style>
    *{
      margin: 0;
      padding: 0;
      margin-left: 10px;
    }
    li{
      list-style: none;
    }
    .add,.reduce{
      display: inline-block;
      width: 20px;
      height: 20px;
      border: 1px solid #000;
      text-align: center;
    }
    .line{
      border-bottom: 1px solid #000;
    }
  </style>
  <script src="angular-1.5.5/angular.min.js"></script>
  <script>
    var myapp=angular.module("myapp",[]);
    myapp.controller("myCtrl",function($scope){
      $scope.cart=[
        {
          "shopName":"趣艺工坊",
          "checked":false,
          "goods":[
            {
              "goodsName":"纯手工制作木质时钟精致家具装饰摆件",
              "pic":"images/cart_01.jpg",
              "price":150.00,
              "number":1,
              "checked":false
            },
            {
              "goodsName":"木质蓝牙音箱包邮实木家具装饰摆件",
              "pic":"images/cart_02.jpg",
              "price":119.00,
              "number":2,
              "checked":true
            },
            {
              "goodsName":"装饰木雕,独特趣味设计家具装饰摆件",
              "pic":"images/cart_03.jpg",
              "price":120.00,
              "number":0,
              "checked":false
            }
          ]
        },
        {
          "shopName":"邻街纸艺",
          "checked":false,
          "goods":[
            {
              "goodsName":"纯手工制作木质时钟精致家具装饰摆件",
              "pic":"images/cart_04.jpg",
              "price":89.00,
              "number":2,
              "checked":true
            },
            {
              "goodsName":"木质蓝牙音箱包邮实木家具装饰摆件",
              "pic":"images/cart_05.jpg",
              "price":189.00,
              "number":1,
              "checked":false
            }
          ]
        },
        {
          "shopName":"纸来我往",
          "checked":true,
          "goods":[
            {
              "goodsName":"纯手工制作木质时钟精致家具装饰摆件",
              "pic":"images/cart_06.jpg",
              "price":289.00,
              "number":3,
              "checked":true
            }
          ]
        }

      ];
      //点击加减按钮,数量加减;点击删除按钮,删除商品
      $scope.reduce=function(goods){
        goods.number--;
        if (goods.number<=0) goods.number=0;
        $scope.totalMoney();
      };
      $scope.add=function(kind){
        kind.number++;
        $scope.totalMoney();
      };
      $scope.delete=function(item,index){
        item.goods.splice(index,1)
      };
      /*总金额计算*/
      $scope.totalMoney=function(){
        var total=0;
        for(var i=0;i<$scope.cart.length;i++){
          for(var j=0;j<$scope.cart[i].goods.length;j++){
            if($scope.cart[i].goods[j].checked){
              total+=$scope.cart[i].goods[j].price*$scope.cart[i].goods[j].number;
            }
          }
        }
        return total;
      };
      /*商铺选择*/
      $scope.shopChecked=function(item){
        if(item.checked==true){
          for(var i=0;i<item.goods.length;i++){
            item.goods[i].checked=true
          }
        }else {
          for(var i=0;i<item.goods.length;i++){
            item.goods[i].checked=false;
          }
        }
      };
      /*全部选择*/
      $scope.allChecked=function(){
        if($scope.allCheck){
          for(var i=0;i<$scope.cart.length;i++){
            $scope.cart[i].checked=true;
            for(var j=0;j<$scope.cart[i].goods.length;j++){
              $scope.cart[i].goods[j].checked=true;
            }
          }
        }else {
          for(var i=0;i<$scope.cart.length;i++){
            $scope.cart[i].checked=false;
            for(var j=0;j<$scope.cart[i].goods.length;j++){
              $scope.cart[i].goods[j].checked=false;
            }
          }
        }
      };
    })
  </script>
</head>
<body ng-app="myapp" ng-controller="myCtrl">
<div><input type="checkbox" ng-model="allCheck" ng-click="allChecked()">总金额:<span>{{ totalMoney() | currency:"¥"}}</span></div>
<div ng-repeat="item in cart" class="line">
  <div><input type="checkbox" ng-model="item.checked" ng-click="shopChecked(item)"><span>{{item.shopName}}</span></div>
  <ul>
    <li ng-repeat="kind in item.goods">
      <input type="checkbox" ng-model="kind.checked"><span>{{kind.goodsName}}</span>
      <p>{{kind.price}}</p>
      <p><span class="add" ng-click="add(kind)">+</span>{{kind.number}}<span class="reduce" ng-click="reduce(kind)">-</span></p>
      <p ng-click="delete(item,$index)">删除</p>
    </li>
  </ul>
</div>

</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js判断FCKeditor内容是否为空的两种形式
May 14 Javascript
JS对字符串编码的几种方式使用指南
May 14 Javascript
JavaScript重载函数实例剖析
May 13 Javascript
jQuery获取剪贴板内容的方法
Jun 16 Javascript
Vuex2.0+Vue2.0构建备忘录应用实践
Nov 30 Javascript
Vue组件库发布到npm详解
Feb 17 Javascript
vue2.0 路由模式mode=&quot;history&quot;的作用
Oct 18 Javascript
vue + typescript + video.js实现 流媒体播放 视频监控功能
Jul 07 Javascript
layui禁用侧边导航栏点击事件的解决方法
Sep 25 Javascript
vue 中几种传值方法(3种)
Nov 12 Javascript
JS数组及对象遍历方法代码汇总
Jun 16 Javascript
javascript+Canvas实现画板功能
Jun 23 Javascript
JS实现前端缓存的方法
Sep 21 #Javascript
JS基于正则表达式实现的密码强度验证功能示例
Sep 21 #Javascript
jQuery实现的简单动态添加、删除表格功能示例
Sep 21 #jQuery
详解react服务端渲染(同构)的方法
Sep 21 #Javascript
详解node单线程实现高并发原理与node异步I/O
Sep 21 #Javascript
删除table表格行的实例讲解
Sep 21 #Javascript
js对象实例详解(JavaScript对象深度剖析,深度理解js对象)
Sep 21 #Javascript
You might like
php 模拟 asp.net webFrom 按钮提交事件的思路及代码
2013/12/02 PHP
php发送与接收流文件的方法
2015/02/11 PHP
php框架CodeIgniter主从数据库配置方法分析
2018/05/25 PHP
php实现微信支付之退款功能
2018/05/30 PHP
JS控制弹出新页面窗口位置和大小的方法
2015/03/02 Javascript
Css3制作变形与动画效果
2015/07/24 Javascript
AngularJS手动表单验证
2016/02/01 Javascript
jQuery的each循环用法简单示例
2016/06/12 Javascript
JS正则获取HTML元素的方法
2017/03/31 Javascript
jQuery:unbind方法的使用详解
2017/08/14 jQuery
使用JS动态显示文本
2017/09/09 Javascript
jQuery+CSS实现的table表格行列转置功能示例
2018/01/08 jQuery
nodeJs实现基于连接池连接mysql的方法示例
2018/02/10 NodeJs
Vue.js实现的购物车功能详解
2019/01/27 Javascript
vue使用localStorage保存登录信息 适用于移动端、PC端
2019/05/27 Javascript
JavaScript对象原型链原理详解
2020/02/05 Javascript
用js编写留言板
2020/03/17 Javascript
uni-app从安装到卸载的入门教程
2020/05/15 Javascript
如何在 ant 的table中实现图片的渲染操作
2020/10/28 Javascript
[01:00:49]DOTA2-DPC中国联赛 正赛 Ehome vs iG BO3 第二场 1月31日
2021/03/11 DOTA
详解Matplotlib绘图之属性设置
2019/08/23 Python
使用pyqt5 tablewidget 单元格设置正则表达式
2019/12/13 Python
英国花园药房: The Garden Pharmacy
2017/12/28 全球购物
马歇尔耳机官网:Marshall Headphones
2020/02/04 全球购物
Java基础知识面试要点
2016/07/29 面试题
园林设计师自荐信
2013/11/18 职场文书
大学生入党思想汇报
2014/01/14 职场文书
2014年财务工作总结范文
2014/11/11 职场文书
建党伟业的观后感
2015/06/01 职场文书
运动会800米赞词
2015/07/22 职场文书
《大禹治水》教学反思
2016/02/22 职场文书
《小蝌蚪找妈妈》教学反思
2016/02/23 职场文书
nginx简单配置多个server的方法
2021/03/31 Servers
javascript代码简写的几种常用方式汇总
2021/08/23 Javascript
Python办公自动化解决world文件批量转换
2021/09/15 Python
介绍一下28个JS常用数组方法
2022/05/06 Javascript