AngularJS 实现购物车全选反选功能


Posted in Javascript onOctober 24, 2017

废话不多说了,直接给大家贴代码了,具体代码如下所示; 

<!DOCTYPE html>
<html lang="en" ng-app="testMo">
<head>
 <meta charset="UTF-8">
 <title></title>
 <link rel="stylesheet" href="css/bootstrap.css" rel="external nofollow" >
 <style>
 .div1{
  margin: 20px;
 }
 </style>
</head>
<body>
<div ng-controller="testCtrl" class="div1">
 <h4>angularJS--购物车实现全选/取消全选</h4>
 <button type="button" class="btn btn-info" ng-click="addProduct()">添加商品</button>
 <button type="button" class="btn btn-danger" ng-click="deleteProduct()">删除商品</button>
 <br><br>
 <table class="table table-bordered table-responsive" >
 <thead>
 <td>操作</td>
 <td>check状态</td>
 <td>商品名称</td>
 <td>单价</td>
 <td>数量</td>
 <td>小计</td>
 </thead>
 <tr ng-repeat="p in cart" >
  <td><input type="checkbox" ng-checked="p.checked" ng-click="echoChange(p.id,p.checked,selectAll)"></td>
  <td>{{p.checked}}||{{p.checked}}</td>
  <td>{{p.name}}</td>
  <td>单价:¥{{p.price}}</td>
  <td>数量:<input type="number" ng-model="p.count" min="0" value="p.count"></td>
  <td>小计:¥{{p.sum}}</td>
 </tr>
 </table>
 <br>
 <input type="checkbox" ng-model="selectAll" ng-click="selectAllClick(selectAll)"><span ng-hide="selectAll" >全选</span><span ng-show="selectAll">取消全选</span>
 <br><br>
 已选择<span>{{jishuqi}}</span>件商品,总金额:<span>¥{{ sumTotal }}</span>
</div>
<script src="../js/angular.js"></script>
<script>
 angular.module('testMo',['ng']).controller('testCtrl',function($scope){
// $scope.p1=new Object();
// $scope.p1.price=10;
// $scope.p1.count=1;
 //购物车应该是一个数组
 $scope.selectAll=false;//全选默认为false
 $scope.cart=[{id:0,name:'商品0',price:10,count:5,sum:10,checked:false}];
 $scope.addProduct= function (){
  var p=new Object();
  p.id=$scope.cart.length;
  p.name='商品'+ p.id
  p.price=Math.floor(Math.random()*100);//对数值向下取整
  p.count=1;
  p.sum= p.price* p.count;
  p.checked=false;
  $scope.cart.push({id: p.id,name: p.name,price:p.price,count: p.count,sum: p.sum,checked: p.checked});
  console.log($scope.cart);
 }
 //删除商品
 $scope.deleteProduct= function (){
  $scope.cart.pop();//删除数组中的最后的一个元素,并且返回这个元素,会改变数组里的元素
 }
 //全选按钮check的点击事件
 $scope.selectAllClick= function (sa) {
  for(var i=0;i<$scope.cart.length;i++){
  $scope.cart[i].checked=sa;
  }
 }
 //单个数据的check事件
 $scope.echoChange=function(id,ch,se){
  $scope.cart[id].checked=!ch;
  //当所有都选中时,全选也要被勾选
  var cc=0;//计算当前数组中checked为真的数目
  for(var i=0;i<$scope.cart.length;i++){
//  if($scope.cart[i].checked==true){
//   cc++;
//  }
  $scope.cart[i].checked?cc++:cc;
  }
  $scope.selectAll=(cc==$scope.cart.length);//当为真的数目=数组长度时,证明全部勾选
//  console.log($scope.selectAll);
 }
 //监控数据
 $scope.$watch('cart',function(newValue,oldValue,scope){
  $scope.sumTotal=0; //总计
  $scope.jishuqi=0; //计数器
  for(var i in newValue) {
  var sumN = newValue[i].count * newValue[i].price; //计算出新的结果
  $scope.cart[i].sum = sumN.toFixed(2); //保留两位小数并且把它赋值给元数据;
  if (newValue[i].checked) {
   $scope.sumTotal += sumN;
   $scope.jishuqi++;
//   console.log($scope.sumTotal);
//   console.log($scope.jishuqi);
  }
  }
 },true);
 /*$watch简介:在digest执行时,如果watch观察的的value与上一次执行时不一样时,就会被触发。
  AngularJS内部的watch实现了页面随model的及时更新。
  $watch方法在用的时候主要是手动的监听一个对象,但对象发生变化时触发某个事件。
  $watch(watchFn,watchAction,deepWatch);
  如果不加第三个参数,那么只会监听cart数组,只有当cart引用改变时才会触发,因此当需要监听一些引用对象时需要把第三个参数设置成true。
  */
 });
</script>
</body>
</html>

PS:下面给大家分享angularjs 购物车的代码,具体代码如下所示:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>购物车</title>
  <script type="text/javascript" src="js/angular.js"></script>
</head>
<body ng-app="product" ng-controller="productController">
<center>
<h2>商品列表</h2>
<div class="container">
  <!--导航栏-->
  <nav>
    <div >
      <div id="bs-example-navbar-collapse-1">
        <div>
          <input type="text" ng-model="search" placeholder="产品名称">   
           产品价格:
          <select>
            <option>0-1000</option>
            <option>1000-2000</option>
            <option>2000-5000</option>
          </select>   
          <input type="button" style="background:#FF0000" value="全部删除" ng-click="removeAll()">
        </div>
      </div>
    </div>
  </nav><br />
  <table border="1 solid" cellpadding="10" cellspacing="0">
    <thead>
    <tr>
      <th ng-click="sortProduct('id')">
        产品编号
        <span></span>
      </th>
      <th ng-click="sortProduct('name')">
        产品名称
        <span></span>
      </th>
      <th ng-click="sortProduct( 'price')">
        产品价格
        <span></span>
      </th>
      <th>
        操作
        <span></span>
      </th>
    </tr>
    </thead>
    <tbody>
    <tr ng-repeat="item in productList | filter:{ 'name':search} | orderBy:(orderSign+orderColumn) ">
      <td>
        {{item.id}}
      </td>
      <td>
        {{item.name}}
      </td>
      <td>
        {{item.price | currency:'(RMB)'}}
      </td>
      <td>
         <input type="button" style="background:#FF0000" value="删除"  ng-click="delProduct(item.name)">
      </td>
    </tr>
    </tbody>
  </table>
</div>
<script>
  angular.module('product',[])
    .factory('productList',function(){
      return [
        { id:910,name:"imac",price:15400 },
        { id:80,name:"iphone",price:5400 },
        { id:29,name:"ipad",price:14200 },
        { id:500,name:"ipad air",price:23400 },
        { id:1200,name:"ipad mini",price:22000},
        { id:100,name:"android",price:9990 }
      ]
    })
    .controller('productController',function($scope,productList){
      /*$scope.search = "ipad";//定义一个变量
      alert($scope.search);*/
      $scope.productList=productList
      $scope.orderColumn='name'; //排序字段
      $scope.orderSign='-';   //为空时正序 为负号时倒序
      $scope.sortProduct=function(sortColumn){ //点击列标题排序事件
        $scope.orderColumn=sortColumn;//觉得按照那一列进行排序
        if($scope.orderSign=="-"){
          $scope.orderSign="";
        }else{
          $scope.orderSign='-';
        }
      };
      //删除产品
      $scope.delProduct = function(name){
        //alert(name);
        if(name!=""){
          if(confirm("是否删除"+name+"商品") ){
            var p;
            for (index in $scope.productList) {
              p = $scope.productList[index];
              if(p.name == name){
                $scope.productList.splice(index,1);
              }
            }
          }
        }
      }
      //清空购物车
$scope.removeAll = function(){
if(confirm("你确定要清空购物车所有商品吗?")){
$scope.productList = [];
}
}
    });
</script>
</center>
</body>
</html>

好了,代码到此结束。

总结

以上所述是小编给大家介绍的AngularJS 实现购物车全选反选功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Javascript写了一个清除“logo1_.exe”的杀毒工具(可扫描目录)
Feb 09 Javascript
JSON 编辑器实现代码
Dec 06 Javascript
页面中iframe相互传值传参
Dec 13 Javascript
JS+ACTIVEX实现网页选择本地目录路径对话框
Mar 18 Javascript
有关于JS构造函数的重载和工厂方法
Apr 07 Javascript
Flexigrid在IE下不显示数据的处理的解决方法
Oct 24 Javascript
JavaScript上传文件时不用刷新页面方法总结(推荐)
Aug 15 Javascript
vue 动态改变静态图片以及请求网络图片的实现方法
Feb 07 Javascript
jquery 实现拖动文件上传加载进度条功能
Mar 18 jQuery
浅谈Webpack多页应用HMR卡住问题
Apr 24 Javascript
layui实现二维码弹窗、并下载到本地的方法
Sep 25 Javascript
js实现拖动缓动效果
Jan 13 Javascript
React Native时间转换格式工具类分享
Oct 24 #Javascript
vue+vuecli+webpack中使用mockjs模拟后端数据的示例
Oct 24 #Javascript
React Native AsyncStorage本地存储工具类
Oct 24 #Javascript
React Native验证码倒计时工具类分享
Oct 24 #Javascript
详解vue + vuex + directives实现权限按钮的思路
Oct 24 #Javascript
React Native实现地址挑选器功能
Oct 24 #Javascript
Angular js 实现添加用户、修改密码、敏感字、下拉菜单的综合操作方法
Oct 24 #Javascript
You might like
如何开发一个虚拟域名系统
2006/10/09 PHP
php.ini 中文版
2006/10/28 PHP
PHP 判断常量,变量和函数是否存在
2009/04/26 PHP
微信公众平台开发关注及取消关注事件的方法
2014/12/23 PHP
PHP模板引擎Smarty自定义变量调解器用法
2016/04/11 PHP
thinkphp 框架数据库切换实现方法分析
2020/05/18 PHP
使用jquery给input和textarea设定ie中的focus
2008/05/29 Javascript
Javascript客户端将指定区域导出到Word、Excel的代码
2008/10/22 Javascript
js操作时间(年-月-日 时-分-秒 星期几)
2010/06/20 Javascript
一个简单的JavaScript Map实例(分享)
2016/08/03 Javascript
jQuery表单事件实例代码分享
2016/08/18 Javascript
bootstrap 下拉多选框进行多选传值问题代码分析
2017/02/14 Javascript
webpack配置的最佳实践分享
2017/04/21 Javascript
react开发教程之React 组件之间的通信方式
2017/08/12 Javascript
vue技术分享之你可能不知道的7个秘密
2018/04/09 Javascript
JavaScript轮播停留效果的实现思路
2018/05/24 Javascript
bootstrap select2插件用ajax来获取和显示数据的实例
2018/08/09 Javascript
JavaScript数组、json对象、eval()函数用法实例分析
2019/02/21 Javascript
js基础之事件捕获与冒泡原理
2019/10/09 Javascript
如何实现echarts markline标签名显示自己想要的
2020/07/20 Javascript
js实现简单抽奖功能
2020/11/24 Javascript
举例讲解Python程序与系统shell交互的方式
2015/04/09 Python
关于Python数据结构中字典的心得
2017/12/04 Python
python主线程捕获子线程的方法
2018/06/17 Python
python中的Elasticsearch操作汇总
2019/10/30 Python
Tensorflow不支持AVX2指令集的解决方法
2020/02/03 Python
html5基础教程常用技巧整理
2013/08/20 HTML / CSS
巴西食品补充剂在线零售商:Músculos na Web
2017/08/07 全球购物
Jimmy Choo美国官网:周仰杰鞋子品牌
2018/06/08 全球购物
瑞典耳机品牌:URBANISTA
2019/12/03 全球购物
ktv总经理岗位职责
2014/02/17 职场文书
研究生考核个人自我鉴定
2014/03/27 职场文书
程序员求职信
2014/04/16 职场文书
2015暑假假期总结
2015/07/13 职场文书
小学三年级班主任工作经验交流材料
2015/11/02 职场文书
关于flex 上下文中自动 margin的问题(完整例子)
2021/05/20 HTML / CSS