angularJS: shop chart
<!DOCTYPE html><html ng-app="app"><head> <meta charset="utf-8"> <link href="http://cdn.bootcss.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet"> <style type="text/css"> body { font-family: "Arial", "Microsoft YaHei", "黑体", "宋体", sans-serif; } </style></head><body> <div class="container" ng-controller="firstController"> <table class="table"> <thead> <tr> <th>产品编号</th> <th>产品名称</th> <th>购买数量</th> <th>产品单价</th> <th>产品总价</th> <th>操作</th> </tr> </thead> <tbody> <tr ng-repeat="item in Product"> <td>{{item.id}}</td> <td>{{item.name}}</td> <td> <button type="button" class="btn" ng-click="reduce($index)">-</button> <input type="text" name="" value="" placeholder="" ng-model="item.quantity"> <button type="button" class="btn" ng-click="add($index)">+</button> </td> <td>{{item.price}}</td> <td>{{item.quantity*item.price}}</td> <td> <button type="button" class="btn btn-danger" ng-click="remove($index)">移除</button> </td> </tr> <tr> <td>总价格:{{totalPrice()}} 元</td> <td colspan="4">总购买数:{{totalQuantity()}}</td> <td> <button type="button" class="btn btn-danger" ng-click="removeall()">清空购物车</button> </td> </tr> </tbody> </table> </div> <script src="http://cdn.bootcss.com/angular.js/1.4.0-rc.2/angular.min.js"></script> <script type="text/javascript"> angular.module('app', []).controller('firstController', function($scope) { $scope.Product = [{ id: 1000, name: "iPhone 6 Plus", quantity: 1, price: 6888 }, { id: 1001, name: "iPhone 6", quantity: 1, price: 5288 }, { id: 1002, name: "iPhone 5s", quantity: 1, price: 4188 }, { id: 1003, name: "iPhone 5c", quantity: 1, price: 3288 }]; $scope.totalPrice = function() { var total = 0; angular.forEach($scope.Product, function(item) { total += item.quantity * item.price; }); return total; } $scope.totalQuantity = function() { var total = 0; angular.forEach($scope.Product, function(item) { total += parseInt(item.quantity); }); return total; } $scope.remove = function(index) { $scope.Product.splice(index, 1); } $scope.removeall = function() { var index; for (index = $scope.Product.length - 1; index >= 0; index--) { $scope.remove(index); } } $scope.reduce = function(index) { if ($scope.Product[index].quantity != 1) { $scope.Product[index].quantity--; } else { var ans = confirm("是否移除该产品?"); if (ans) { $scope.remove(index); } else { $scope.Product[index].quantity = 1; } } } $scope.add = function(index) { $scope.Product[index].quantity++; } $scope.$watch('Product', function(newValue, oldValue) { angular.forEach(newValue, function(item, key) { if (item.quantity < 1) { var ans = confirm("是否移除该产品?"); if (ans) { $scope.remove(key); } else { item.quantity = oldValue[key].quantity; } return; } }); }, true); }); </script></body></html>angularJS: shop chart的更多相关文章
- [D3 + AngularJS] 15. Create a D3 Chart as an Angular Directive
Integrating D3 with Angular can be very simple. In this lesson, you will learn basic integration as ...
- ECharts 初识(基于MVC+jQuery+Angularjs实现的Demo)
一.背景: 我们这行做web开发的,很多时候都需要做数据统计报表,现在我所使用的是来自百度团队的ECharts.官方网址:http://echarts.baidu.com/ 我们知 ...
- 在AngularJS中的使用Highcharts图表控件
一.Highcharts简介 Highcharts是一款非常好用的前端图表控件,正如其中文网介绍的那样:功能强大.开源.美观.图表丰富.兼容绝大多数浏览器的纯js图表库. 如果你的项目是基于jquer ...
- angularjs结合d3js实现资源展示
转载请注明出处: 转载自Bin's Blog: angularjs & d3 实现资源展示( http://www.wenbin.cf/post/27/ ) angularjs结合d3js实 ...
- Ionic中使用Chart.js进行图表展示以及在iOS/Android中的性能差异
Angular Chart 简介 在之前的文章中介绍了使用 Ionic 开发跨平台(iOS & Android)应用中遇到的一些问题的解决方案. 在更新0.1.3版本的过程中遇到了需要使用图表 ...
- angularJS之$watch的一个小介绍
现在最近公司项目使用angularJS进行开发:以前也接触过但是不多,趁着现在熟悉回来. 如题,angular中$watch也是我们在开发的时候需要的各种监听: $watch接收3个参数,第一个是对象 ...
- AngularJS in Action读书笔记6(实战篇)——bug hunting
这一系列文章感觉写的不好,思维跨度很大,原本是由于与<Angularjs in action>有种相见恨晚而激发要写点读后感之类的文章,但是在翻译或是阐述的时候还是会心有余而力不足,零零总 ...
- AngularJS引入Echarts的Demo
最近要用到图表展示,想了想,还是首选Echarts,HighCharts和D3.js备用吧, 而项目中也用到了AngularJS,所以需要把Echarts引入到AngularJs中一起使用, 试了试, ...
- AngularJs基础总结(1.4版本)
注明:现在用的是最新的1系列1.4版本. 一.细节方面入手: 1,ng-app根节点,一般别写在html上面,最多也就写在body就行了,因为我们难免会忘记这个写在哪里,然后复制一些案例代码却总报错. ...
随机推荐
- Oracle merge into
Oracle中Merge into用法总结 文件来源:(http://blog.csdn.net/yuzhic/article/details/1896878) 有一个表T,有两个字段a.b,我们想在 ...
- CentOS下使用Postfix + Dovecot + Dnsmasq搭建极简局域网邮件系统
背景 开发环境为局域网,工作内容需要经常查看邮件文件(*.eml),可恶的Foxmail必须验证账户才能进入主界面,才能打开eml文件查看. 无奈搭一个局域网内的邮件系统吧.极简搭建,仅用于通过Fox ...
- Unity3D 装备系统学习Inventory Pro 2.1.2 基础篇
前言 前一篇 Unity3D 装备系统学习Inventory Pro 2.1.2 总结 基本泛泛的对于Inventory Pro 这个插件进行了讲解,主要是想提炼下通用装备系统结构和类体系.前两天又读 ...
- 转载:谈谈Unicode编码,简要解释UCS、UTF、BMP、BOM等名词
转载: 谈谈Unicode编码,简要解释UCS.UTF.BMP.BOM等名词 这是一篇程序员写给程序员的趣味读物.所谓趣味是指可以比较轻松地了解一些原来不清楚的概念,增进知识,类似于打RPG游戏的升级 ...
- JavaScriptSerializer使用条件
JavaScriptSerializer使用条件:需先引用组件:System.Web.Extensions 类全称:System.Web.Script.Serialization.JavaScript ...
- apache 集成ssl 配置 https 证书
http://zhangge.net/4890.html 后面遇到 问题点一: it`s work 是因为没配置ssl访问站点路径 /alidata/server/httpd/conf/extra/ ...
- Linux操作系统备份之三:通过二进制拷贝(dd)方式实现Linux操作系统数据的备份
前面有两篇文章,<Linux操作系统备份之一:使用LVM快照实现Linux操作系统数据的在线备份>和<Linux操作系统备份之二:通过tar拷贝分区实现Linux操作数据的在线备份& ...
- 关于header跳转之后的乱码
http://www.360doc.com/content/11/0603/19/7052474_121495648.shtml 问题:不同网站的跳转出现乱码,不同编码的页面传递参数也出现乱码 搞清楚 ...
- CheckBox 半选中状态
<input type='checkbox' />可以半选中,这个特性,很多浏览器都支持,包括Firefox,Chrome和IE 用 input.indeterminate 这个属性来获取 ...
- python与ruby的差别
1.引用文件差别 Ruby:同一目录下的文件,如/usr/local/ruby/foo.rb与/usr/local/ruby/bar.rb两个文件.如果直接在foo.rb中 require 'bar' ...