1. data(){
  2.        return {
  3.            goodsList:[], // 商品列表
  4.            priceFilter:[ // 价格区间数组
  5.                {
  6.                    startPrice:'0.00',
  7.                    endPrice:'100.00'
  8.                },
  9.                {
  10.                    startPrice:'100.00',
  11.                    endPrice:'500.00'
  12.                },
  13.                {
  14.                    startPrice:'500.00',
  15.                    endPrice:'1000.00'
  16.                },
  17.                {
  18.                    startPrice:'1000.00',
  19.                    endPrice:'5000.00'
  20.                }
  21.            ],
  22.            priceChecked:'all', // 选中的价格区间
  23.            filterBy:false, // 控制价格菜单的显示
  24.            overLayFlag:false, // 遮罩的显示
  25.  
  26.            sortFlag:true, // 排序:默认升序
  27.            page:1, // 当前第一页
  28.            pageSize:8, // 一页有8条数据
  29.  
  30.            busy:true, // 滚动加载插件默认禁用
  31.  
  32.            loading:false, // 往下滚动"加载图标"的出现效果
  33.  
  34.            mdShow:false, // 未登录的模态框是否显示
  35.            mdShowCart:false // 已登录的模态框是否显示
  36.        }
  37.    },
  38.    components:{
  39.        NavHeader,
  40.        NavFooter,
  41.        NavBread,
  42.        Modal
  43.    },
  44.    mounted:function(){
  45.        this.getGoodsList();
  46.    },
  47.    methods:{
  48.        getGoodsList(flag){
  49.            var param = {
  50.              page:this.page,
  51.              pageSize:this.pageSize,
  52.              sort:this.sortFlag ? 1 : -1 , // sortFlag为true升序
  53.              priceLevel:this.priceChecked // 点击的价格区间
  54.            }
  55.            this.loading = true;
  56.            axios.get("/goods/list",{
  57.              params:param // 传参
  58.            }).then((res)=>{
  59.                var res = res.data;
  60.                this.loading = false;
  61.                "){
  62.                  if(flag){ // true.商品数据累加
  63.                    this.goodsList = this.goodsList.concat(res.result.list);
  64.  
  65.                    if(res.result.count == 0){ // 0条数据了,就不加载滚动加载方法了
  66.                      this.busy = true; // 禁用
  67.                    }else{
  68.                      this.busy = false; // 启用
  69.                    }
  70.  
  71.                  }else{ // 只加载一页
  72.                    this.goodsList = res.result.list;
  73.                    this.busy = false;
  74.                  }
  75.                }else{
  76.                  this.goodsList = [];
  77.                }
  78.            })
  79.        },
  80.        sortGoods(){ // 点击排序商品
  81.          this.sortFlag = !this.sortFlag;
  82.          this.page = 1; // 点击价格排序后从第一页开始
  83.          this.getGoodsList(); // 重新加载数据
  84.        },
  85.        setPriceFilter(index){ // 点击价格
  86.            this.priceChecked = index;
  87.            this.closePop();
  88.            this.getGoodsList();
  89.        },
  90.        showFilterPop(){ // 点击filterBy出现价格菜单和遮罩
  91.            this.filterBy = true;
  92.            this.overLayFlag = true;
  93.        },
  94.        closePop(){ // 关闭价格菜单和遮罩
  95.            this.filterBy = false;
  96.            this.overLayFlag = false;
  97.        },
  98.        loadMore(){ // 滚动加载插件方法
  99.          this.busy = true; // 滚动就禁用,防止下一个滚动
  100.          setTimeout(() => { // 一个滚动完成之后再滚动加载下一个
  101.            this.page++;
  102.            this.getGoodsList(true); // 滚动加载是累加数据,并不是只显示一页数据,so需要传参去请求数据的地方判断一下
  103.          }, 500);
  104.        },
  105.        addCart(productId){ // 点击加入购物车
  106.          axios.post("/goods/addCart",{ // 接口设置在server/routes/goods.js
  107.            productId:productId
  108.          }).then((res)=>{
  109.            var res = res.data;
  110.            if(res.status==0){
  111.              //alert("加入成功")
  112.              this.mdShowCart = true; // 加入购物车成功,成功的模态框显示
  113.  
  114.              // 购物车数量加1
  115.              this.$store.commit('updateCartCount',1);
  116.            }else{
  117.              // alert("msg:"+res.msg)
  118.              this.mdShow = true; // 未登录模态框显示
  119.            }
  120.          })
  121.        },
  122.        closeModal(){ // 关闭模态框
  123.              this.mdShow = false; // 未登录模态框消失
  124.              this.mdShowCart = false; // 未登录模态框消失
  125.        }
  126.    }

Node.js后端代码

  1. // 查询商品列表数据
  2. /* GET goods page. */
  3. router.get('/list', function(req, res, next) {
  4.    // res.send('hello,goods list'); // 测试路由,连接成功页面出现'hello,goods list'
  5.  
  6.    // express获取请求参数
  7.    let page = parseInt(req.param("page")); // get请求数据拿到数据:res.param()
  8.    let pageSize = parseInt(req.param("pageSize"));
  9.    let priceLevel = req.param("priceLevel"); // 传过来的价格区间
  10.    let sort = req.param("sort");
  11.    let skip = (page-1)*pageSize; // 跳过的数据条数,(分页的公式).
  12.    var priceGt = '',priceLte = '';
  13.    let params = {};
  14.    if(priceLevel != 'all'){ // 价格区间过滤功能
  15.       switch (priceLevel){
  16.          case '0':priceGt=0;priceLte =100;break;
  17.          case '1':priceGt=100;priceLte =500;break;
  18.          case '2':priceGt=500;priceLte =1000;break;
  19.          case '3':priceGt=1000;priceLte =5000;break;
  20.       }
  21.       params = {
  22.          salePrice:{
  23.             $gt:priceGt,
  24.             $lte:priceLte
  25.          }
  26.       }
  27.    }
  28.    let goodsModel = Goods.find(params).skip(skip).limit(pageSize); // 先查询所有,skip(skip)跳过skip条数据,limit(pageSize)一页多少条数据.即分页功能实现
  29.    goodsModel.sort({'salePrice':sort}); // 对价格排序功能
  30.  
  31.    goodsModel.exec(function(err, doc){
  32.       if(err) {
  33.          res.json({
  34.             status:'1',
  35.             msg:err.message
  36.          })
  37.       }else{
  38.          res.json({
  39.             status:'0',
  40.             msg:'',
  41.             result:{
  42.                count:doc.length,
  43.                list:doc
  44.             }
  45.          })
  46.       }
  47.    })
  48.  
  49. });

Vue nodejs商城项目-商品列表页面组件的更多相关文章

  1. Vue nodejs商城项目-商品列表价格过滤和加入购物车功能

    一.价格过滤功能 GoodsList.vue >>点击价格区间时发送请求 methods:{     getGoodsList(flag){         var param = {   ...

  2. Vue nodejs商城项目-商品的分页、排序、筛选

    .分页 ,要查第3页的数据,则跳过2*8条数据,然后返回8条数据. 在实现滚动加载时,页面刚一加载完成并不需要请求所有数据,当用户下拉到页面底部时,再去请求数据并拼接到商品数据列表中. 通过vue-i ...

  3. 12 Flutter仿京东商城项目 商品列表页面请求数据、封装Loading Widget、上拉分页加载更多

    ProductList.dart import 'package:flutter/material.dart'; import '../services/ScreenAdaper.dart'; imp ...

  4. 11 Flutter仿京东商城项目 商品列表页面二级筛选导航布局

    ProductList.dart import 'package:flutter/material.dart'; import '../services/ScreenAdaper.dart'; imp ...

  5. Vue nodejs商城项目-项目概述

    项目概况 用vue2.0 +node.js +MongonDB 做了一个商城系统 技术选型 Vue2.0+node.js+express+MongoDB+axios+vuex 构建工具 Webpack ...

  6. Vue nodejs商城项目-登录模块

    一.登录功能 后端server/routes/users.js var User = require('./../models/users.js');   // 二级路由 // 登录接口 router ...

  7. 商城项目:商品列表ajax加载,ajax加入购物车--五张表的联合查询

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="ProductLists.a ...

  8. 13 Flutter仿京东商城项目 商品列表筛选以及上拉分页加载更多

    ProductList.dart import 'package:flutter/material.dart'; import '../services/ScreenAdaper.dart'; imp ...

  9. Vue nodejs商城项目- 前后端数据传递

    .利用Mongoose查询MongoDB 通过mongoose插件可以简捷地从mondodb中获取数据,首先安装mongoose: cnpm install mongoose --save   使用m ...

随机推荐

  1. IE6,IE7,IE8 css bug搜集及浏览器兼容性问题解决方法汇总

    断断续续的在开发过程中收集了好多的bug以及其解决的办法,都在这个文章里面记录下来了!希望以后解决类似问题的时候能够快速解决,也希望大家能在留言里面跟进自己发现的ie6 7 8bug和解决办法! 1: ...

  2. [转]<加密算法c#>——— 3DES加密之ECB模式 和 CBC模式

    本文转自:http://www.cnblogs.com/qq278360339/archive/2013/06/05/3119222.html 最近 一个项目.net 要调用JAVA的WEB SERV ...

  3. C#字符串替换_无视大小写

    C#里的string.Replace是不能无视大小写的. 首先想到的是正则表达式,在网上查了下,果然有用正则表达式配合一些逻辑运算,实现无视大小写的字符串替换方法.但是正则表达式的方法用起来很麻烦,实 ...

  4. IIS发布常见错误-HTTP 错误 404.0 - Not-Found

    错误信息:HTTP 错误 404.0 - Not-Found 错误代码:0x80070002 原 因:IIS配置错误. 解决方法:我配置IIS时漏掉了下面几项,一定要记得勾选.

  5. Sass学习笔记(三)

    一.Sass的控制命令 二.Sass的函数功能 sass中除了可以定义变量,还自备了一系列函数功能,主要包括:字符串函数.数字函数.列表函数.颜色函数.Instrospection函数.三元函数等.当 ...

  6. IO流之File类

    IO概述: 程序数据都是在内存中,程序运行结束,这些数据将清空,数据都都不能保存下来,下次程序启动的时候,想再把这些数据读出来继续使用,把数据持久化存储,就需要把内存中的数据存储到内存以外的其他持久化 ...

  7. 深入理解JavaScript函数

    本篇文章主要介绍了"深入理解JavaScript函数",主要涉及到JavaScript函数方面的内容,对于深入理解JavaScript函数感兴趣的同学可以参考一下. JavaScr ...

  8. wx.grid

    wxPython控件学习之wx.grid.Grid (包括对GridCellEditor和GridCelRender的扩展,以支持更多的grid cell 样式, 以GridCellColorEdit ...

  9. 快速开始Python/WSGI应用程序

    快速开始Python-wsig应用程序 官方参考文档 安装 uwsgi 安装 pip install uwsgi uwsgi --version # 查看 uwsgi 版本 测试 uwsgi 是否正常 ...

  10. 什么是PDM?

    PDM的含义 PDM的中文名称为产品数据管理(Product Data Management). PDM是一门用来管理所有与产品相关信息(包括零件信息.配置.文档.CAD文件.结构.权限信息等)和所有 ...