VUE2.0实现购物车和地址选配功能学习第四节
第四节 v-on实现金额动态计算
用¥金额 进行格式处理,可以使用原生js进行转换,但是在vuei,使用filter过滤器更加方便
注:
1.es6语法=>和import等
好处在于res参数后的function函数内的this作用域,不弄在外部声明变量了。
methods:{
cartView:function(){
let _this=this;
this.$http.get("data/cartData.json",{"id":123}).then( res=>{
this.productList =res.body.result.productList;
this.totalMoney=res.body.result.totalMoney;
}); }}
2.全局过滤器:可以在任何页面使用
html:{{item.productPrice*item.productQuentity | money('元')}}
js:
       Vue.filter("money",function (value,type) {
             return"¥"+value.toFixed(2)+type;
          })
代码:
<ul class="cart-item-list">
<li v-for="(item,index) in productList">
<!--v-for="item in productList"这是vue1.0的用法-->
<div class="cart-tab-1">
<!-- 单选 -->
<div class="cart-item-check">
<a href="javascipt:;" class="item-check-btn">
<svg class="icon icon-ok"><use xlink:href="#icon-ok"></use></svg>
</a>
</div>
<!-- 商品图片 -->
<div class="cart-item-pic">
<img v-bind:src="item.productImage" alt="烟">
<!--src="{{item.productImage}}"貌似不能使用-->
<!--v-bind是比较好的办法,浏览器解析字符串直接写src会报错什么的-->
</div>
<!-- 商品名称 -->
<div class="cart-item-title">
<div class="item-name">{{item.productName+":"+index}}</div>
<!--{{item.productName+":"+index}}-->
</div>
<!-- 赠品 -->
<div class="item-include">
<dl>
<dt>赠送:</dt>
<dd v-for="part in item.parts" v-text="part.partsName"></dd>
</dl>
</div>
</div>
<!-- 单价 -->
<div class="cart-tab-2">
<div class="item-price">{{item.productPrice | formatMoney}}</div>
</div>
<div class="cart-tab-3">
<div class="item-quantity">
<div class="select-self select-self-open">
<div class="quentity">
<a href="javascript:;">-</a>
<input type="text" v-model="item.productQuentity">
<!--双向数据绑定功能,实现总金额实时变化功能-->
<a href="javascript:;">+</a>
</div>
</div>
<div class="item-stock">有货</div>
</div>
</div>
<div class="cart-tab-4">
<!-- 总金额 -->
<div class="item-price-total">{{item.productPrice*item.productQuentity | formatMoney}}</div>
</div>
<!-- 删除功能 --> <div class="cart-tab-5">
<div class="cart-item-opration">
<a href="javascript:;" class="item-edit-btn">
<svg class="icon icon-del"><use xlink:href="#icon-del"></use></svg>
</a>
</div>
</div> </li>
</ul>js:
/**
* Created by zs1414030853 on 2017/2/24.
*/
/*完整vue实例*/
var vm=new Vue({
el:"#app",
data:{
totalMoney:0,
productList:[]
/*初始值*/
}, filters:{
formatMoney:function (value) {
return"¥"+value.toFixed(2);
}
/*局部过滤器只能在实例的范围内使用*/
}, mounted:function () {
this.$nextTick(function () { });/*此时this和vm是等同的,这是mounted和ready的vue1和2的区别*/
this.cartView(); }, methods:{
cartView: function () {
var _this =this;
/* this.$http.jsonp*/
this.$http.get("data/cart.json",{"id":123}).then(function (res) {
_this.productList =res.body.result.productList;
_this.totalMoney=res.body.result.totalMoney;
/*在运行的时候打断点可以查看res等属性和包含的方法值等*/
});
}
} });
VUE2.0实现购物车和地址选配功能学习第四节的更多相关文章
- VUE2.0实现购物车和地址选配功能学习第七节
		第七节 卡片选中,设置默认 1.卡片选中html:<li v-for="(item,index) in filterAddress" v-bind:class="{ ... 
- VUE2.0实现购物车和地址选配功能学习第六节
		第六节 地址列表过滤和展开所有的地址 html:<li v-for="(item,index) in filterAddress">js: new Vue({ el:' ... 
- VUE2.0实现购物车和地址选配功能学习第五节
		第五节 单件商品金额计算和单选全选功能 1.vue精髓在于操作data模型来改变dom,渲染页面,而不是直接去改变dom 2.加减改变总金额功能: html:<div class="c ... 
- VUE2.0实现购物车和地址选配功能学习第三节
		第三节 使用v-for渲染商品列表 1.使用vue-resource插件引入json数据 (注:在谷歌中调试打断点-- ,console还可以输出vm,res等属性列表,或者productList等一 ... 
- VUE2.0实现购物车和地址选配功能学习第二节
		第二节 创建VUE实例 购物车项目计划: 1.创建一个vue实例 2.通过v-for指令渲染产品数据 3.使用filter对金额和图片进行格式化 4.使用v-on实现产品金额动态计算 5.综合演示 ① ... 
- VUE2.0实现购物车和地址选配功能学习第一节(来源--慕课网河畔一角)
		第一节 vue知识 vue-resource:和后台交互的一个插件,实现get.post和jsonp等功能.(替代jQuery) vue特点: 1.易用:通过创建vue实例,{{}}绑定数据十分方便 ... 
- 关于慕课网《使用vue2.0实现购物车和地址选配功能》的总结
		视频学习网址:http://www.imooc.com/learn/796 源码打包:https://codeload.github.com/fachaoshao/Vue-ShoppingCart/z ... 
- vue2.0实现购物车功能
		购物车功能是一件比较繁琐的事情,逻辑功能太多,今天就用vue2.0实现一个简单的购物车功能,数据都本地自己写的假数据 功能列表: 1.全选和单选结算 2.减少和增加数量 3.商品的删除 界面搭建以及布 ... 
- vue购物车和地址选配(三)
		参考资料:vue.js官网 项目演示: 项目源代码: 核心代码及踩坑 删除: new Vue({ el:'#app', data:{ productlist:[], totalMoney:0, che ... 
随机推荐
- SQL四种语言
			1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema ... 
- C语言的指针使用
			今天老师总结了一下指针内容,感觉对理解指针有帮助, 1.大家在使用指针的时候容易忽略掉指针所在的位置. 假如定义一个变量int a=10: int *p: p=&a; //p中存放变量 ... 
- hdu-3790-最短路径问题(dijkstra算法)
			题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3790 这题cin会超时i 关于解决cin超时的问题 在main函数开头加上 ios::sync_wit ... 
- Flash安全的一些总结
			整理了下Flash安全相关的知识,后面会再完善 一.先来说crossdomain.xml这个文件 flash如何跨域通信,全靠crossdomain.xml这个文件.这个文件配置在服务端,一般为根目录 ... 
- javascript获取整数随机数
			javascript获取整数随机数 // 从4到10的随机数,|0是生成正整数 var numBars = Math.random()*6+4|0; 也可以通过右移0位(或者左移0位)进行取整 var ... 
- 查看Eclipse版本号,及各个版本区别
			查看Eclipse版本号,及各个版本区别 参考:http://blog.csdn.net/gaojinshan/article/details/38903043 查看Eclipse版本号的方法:1.找 ... 
- Canvas rotate- 旋转
			Canvas rotate- 旋转 <!DOCTYPE html> <html lang="en"> <head> <meta chars ... 
- js数组快速排序
			<script type="text/javascript"> var arr = [1, 2, 3, 54, 22, 1, 2, 3]; function quick ... 
- 抓取QQ空间相册
			某天,想下载某人的相册,发现一张一张下载,工作量巨大,所以写了这个工具. 使用到的工具 Fiddler(抓包工具) python(脚本语言) intellij 步骤 分析包 获取相册分类链接信息 打开 ... 
- 【js 编程艺术】小制作四
			1. html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <t ... 
