博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Vue2.0开发购物车实例
阅读量:4086 次
发布时间:2019-05-25

本文共 4304 字,大约阅读时间需要 14 分钟。

前言

虽然Vue最强大的是组件化开发,但是其实多页面开发也蛮适合的。看了慕课网的使用Vue2.0开发购物车的教程之后,自己也实现了一遍。http://www.imooc.com/article/16454

初始化package.json

使用npm init命令来自动生成package.json文件。

会依次让你输入:

  • name: 你的项目名称(默认会使用你的文件夹名称,不更改的话直接回车跳过)
  • version: 版本号(默认1.0.0,不更改直接回车跳过)
  • description: 项目描述(可为空,不写直接回车跳过)
  • entry point: 入口文件(默认为index.js)
  • test command: 测试命令行(回车跳过)
  • git repository: git仓库地址(回车跳过)
  • keywords: 关键字
  • author: 作者
  • license: 所用协议
    接下来会让你预览package.json文件,输入yes即可生成package.json文件

因为该项目会用到vue,axios(在Vue2.0中取代vue-resource)和http-server(用来将文件夹转为服务器,避免跨域问题),

因此再使用以下命令,在package.json中把上面三个库引入进来

npm install vue --save-devnpm install axios --save-devnpm install http-server --save-dev

这样在项目文件夹下就会出现"node_modules"文件夹,我们需要的三个库也会下载下来了

同时,package.json文件中会多出以下这段内容:

"devDependencies": {
"axios": "^0.15.3", "http-server": "^0.9.0", "vue": "^2.1.10" }

这样,下次就可以直接使用npm install来安装所需的依赖的

接下来,再在package.json中修改"scripts",增加以下内容:

"scripts": {
"start":"http-server -a localhost -p 8080"}

这样就可以通过npm start的方式来启动项目了,在浏览器输入localhost:8080即可访问

附上http-server的参数说明:

-p 端口号 (默认 8080)
-a IP 地址 (默认 0.0.0.0)
-d 显示目录列表 (默认 'True')
-i 显示 autoIndex (默认 'True')
-e or --ext 如果没有提供默认的文件扩展名(默认 'html')
-s or --silent 禁止日志信息输出
--cors 启用 CORS via the Access-Control-Allow-Origin header
-o 在开始服务后打开浏览器
-c 为 cache-control max-age header 设置Cache time(秒) , e.g. -c10 for 10 seconds (defaults to '3600'). 禁用 caching, 则使用 -c-1.
-U 或 --utc 使用UTC time 格式化log消息
-P or --proxy Proxies all requests which can't be resolved locally to the given url. e.g.: -P 
-S or --ssl 启用 https
-C or --cert ssl cert 文件路径 (default: cert.pem)
-K or --key Path to ssl key file (default: key.pem).
-r or --robots Provide a /robots.txt (whose content defaults to 'User-agent: *\nDisallow: /')
-h or --help 打印以上列表并退出

购物车

在Vue的生命周期钩子函数中,mounted就相当于jQuery的.ready方法,但是使用mounted并不能保证钩子函数中的this.$el在document中,为此还需要引入Vue.nextTick/vm.$nextTick,见

所以购物车的初始化方法如下:

mounted:function(){
var _this = this; this.$nextTick(function(){
axios.get('http://localhost:8080/data/cartData.json') .then( // 使用箭头函数的话,this的作用域并不会变,还是指向vmCart // (retObj)=>{
// if(retObj.status == 200){
// this.totalMoney = retObj.data.result.totalMoney; // this.list = retObj.data.result.list; // } // } // 不使用箭头函数的场合 // 如果要使用vmCart实例, // 就必须在mounted钩子函数里再调用一次$nextTick方法才能保证el被render在dom中 function(retObj){
if(retObj.status == 200){
vmCart.list = retObj.data.result.list; } } ) .catch(function(errorObj){
console.log("get data error..."); }) });},

购物车的json数据如下:

{
"productId":"600100002115", "productName":"黄鹤楼香烟", "productPrice":19, "productQuentity":1, "productImage":"img/goods-1.jpg", "parts":[ {
"partsId":"10001", "partsName":"打火机", "img":"img/part-1.jpg" } ]}

可以看到,从服务器返回的数据,都是业务逻辑数据(虽然此处是mock的),并不会包含一些页面上的状态信息,那么如何通过为购物车中的商品增加一些属性来记录诸如是否选中的状态呢?

就需要用到Vue.set方法了,详见

methods:{
selectGood:function(goodObj,index){
if(goodObj.isChecked == void 0){
this.$set(goodObj,"isChecked",true) } else {
goodObj.isChecked = !goodObj.isChecked; } this.isCheckAll(); }}

如上述代码所示,如果产品被选中,同时该产品没有"isChecked"属性,则为其添加该属性,并设为"true"

至于选中的所有产品的价格,可以使用computed属性来计算:

computed:{
totalPrice:function(){
var total = 0; this.list.forEach(function(good){
if(good.isChecked){
total += good.productPrice * good.productQuentity; } }); return total; },},

最后,可以使用filters来为页面上的金额添加单位:

filters:{
Currency:function(val){
return val + " 元"; },}
地址

地址页面的大部分功能和购物车类似

只有一个默认地址的设置,可以采用watch的方法来监控当前默认地址的变化,发现变化之后,把老的默认地址取消即可,
这样就不需要遍历所有的地址,将非当前选中的地址都设为“非默认地址”了

watch:{
currentDefaultAddress:function(newVal,oldVal){
oldVal.isDefault = false; },}

还有一个小技巧是"more"更多地址的设置,目前是通过计算属性来过滤数组的方式:

computed:{
filteAddress:function(){
return this.addressList.slice(0,this.limitNum); },}

默认是指返回指定数量地址,在按了“more”之后,再将limitNum设置为数组的长度,这样就可以显示所有的地址了:

源码

demo


作者: nickylau82 

链接:http://www.imooc.com/article/16454

来源:慕课网

转载地址:http://ykeni.baihongyu.com/

你可能感兴趣的文章
【C#】正则表达式
查看>>
【C#】匹配中文字符串的4种正则表达式分享
查看>>
【C#】正则表达式匹配中文,英文字母和数字及_写法!并控制长度
查看>>
【C#】C#中正则表达式的使用
查看>>
【NGUI】Unity插件NGUI的Button按钮修改为Disabled状态
查看>>
【UGUI】Unity的UGUI实现Button按钮长按状态的判断
查看>>
【NGUI】Unity中给NGUI添加监听事件,Button,Toggle
查看>>
【C#】不可变字符串String的常用方法
查看>>
【Unity】Unity报错success && actual == (UInt64)size
查看>>
【Lua】lua的基本语法
查看>>
【C#】delegate委托的定义和使用方法
查看>>
【C#】Action委托类型
查看>>
【C#】Func委托类型和匿名方法
查看>>
【Unity】场景异步加载的进度条制作
查看>>
【NGUI】通过射线检测被遮挡的物体
查看>>
【Unity】Unity5版本的AssetBundle打包方案之资源打包
查看>>
【Unity】Unity5版本的AssetBundle打包方案之打包Scene场景
查看>>
【C#】匿名方法的终结者——Lambda表达式
查看>>
【C#】简单工厂模式
查看>>
【Unity】使用射线碰撞限制人物主角多次跳跃
查看>>