Vue nodejs商城项目-商品的分页、排序、筛选
、分页
,要查第3页的数据,则跳过2*8条数据,然后返回8条数据。
在实现滚动加载时,页面刚一加载完成并不需要请求所有数据,当用户下拉到页面底部时,再去请求数据并拼接到商品数据列表中。
通过vue-infinite-scroll插件实现滚动加载,在框架末尾插入加载div,并且可以在其中放入加载动画
- <div v-infinite-scroll="loadMore" infinite-scroll-disabled="busy" infinite-scroll-distance="10">
- <img v-if="showLoading" src="../../static/loading-svg/loading-spinning-bubbles.svg">//加载动画
- </div>
通过busy可以控制是否启用加载,在loadMore函数中定义你的加载操作,然后通过setTimeout按时间间隔响应加载请求
- new Vue({
- el: '#app',
- data: {
- data: [],
- busy: false
- },
- methods: {
- loadMore(){//滚动加载插件
- this.busy = true;
- setTimeout(() => {
- this.page++;
- this.getGoodsList(true);
- }, 1000);
- }
- }
- });
2、排序
商品按价格排序主要是利用nodejs的mongoose中的sort函数对数据库查询结果按price关键字排序,之后返回给前端。在前端发送排序请求:
- sortPrice(){//按价格排序
- this.sortFlag=this.sortFlag==1?-1:1;
- this.page=1;
- this.getGoodsList();
- }
为升序,-1降序,排序之后需要将页码置1,然后再去请求商品列表
3、按价格筛选
后端根据前端请求的最大值(priceGt)、最小值(priceLt)去数据库中查询指定价位之间的商品并返回给前端,利用mongoose的查询find函数中的params参数中设置$gt,$lt查询指定区间的商品
- let params={
- salePrice:{$gt:req.query.priceGt,$lt:req.query.priceLt}
- };
商品前端请求:
- getGoodsList(split){
- let param={//get请求的参数
- pageSize:this.pageSize,
- page:this.page,
- sortFlag:this.sortFlag,
- priceGt:this.priceGt,
- priceLt:this.priceLt
- };
- this.showLoading=true; //启用加载svg动画
- axios.get("/goods",{
- params:param
- }).then(response =>{
- let res=response.data;
- if(res.status==0){
- if(split){ //split==true,需要滚动追加页数
- this.goodsList=this.goodsList.concat(res.result.list);
- 条数据,禁用滚动
- this.busy=true;
- }else{
- this.busy = false;
- }
- }else{
- this.goodsList=res.result.list;
- }
- }else{
- console.log("从服务器请求数据失败!");
- }
- });
服务器端处理:
- router.get('/',(req,res,next)=>{
- //获取请求参数
- let pageSize=parseInt(req.query.pageSize);
- let page=parseInt(req.query.page);
- let sortFlag=req.query.sortFlag;
- let skipPiece=(page-1)*pageSize;//分页查询,跳过前面skip条数据
- let params={
- salePrice:{$gt:req.query.priceGt,$lt:req.query.priceLt}
- };
- //利用goods模板调用mongooseAPI进行数据库查询、排序、跳到指定页
- let goodsModel=goods.find(params).sort({'salePrice':sortFlag}).skip(skipPiece).limit(pageSize);
- goodsModel.exec((err,goodsDoc)=>{
- "use strict";
- if (err){
- res.json({
- status:1,
- msg:err.message
- })
- }else {
- res.json({//利用res将数据返回给get请求
- status:0,
- msg:'',
- result:{
- count:goodsDoc.length,
- list:goodsDoc
- }
- })
- }
- })
- });
Vue nodejs商城项目-商品的分页、排序、筛选的更多相关文章
- Vue nodejs商城项目-商品列表价格过滤和加入购物车功能
一.价格过滤功能 GoodsList.vue >>点击价格区间时发送请求 methods:{ getGoodsList(flag){ var param = { ...
- Vue nodejs商城项目-商品列表页面组件
data(){ return { goodsList:[], // 商品列表 priceFilter:[ // 价格区间数组 ...
- Vue nodejs商城项目-项目概述
项目概况 用vue2.0 +node.js +MongonDB 做了一个商城系统 技术选型 Vue2.0+node.js+express+MongoDB+axios+vuex 构建工具 Webpack ...
- Vue nodejs商城项目- 前后端数据传递
.利用Mongoose查询MongoDB 通过mongoose插件可以简捷地从mondodb中获取数据,首先安装mongoose: cnpm install mongoose --save 使用m ...
- Vue nodejs商城项目-登录模块
一.登录功能 后端server/routes/users.js var User = require('./../models/users.js'); // 二级路由 // 登录接口 router ...
- Vue nodejs商城项目-搭建express框架环境
1.express-project 搭建express框架环境 安装express generator生成器 通过生成器自动创建项目 配置分析 安装 cnpm i -g express-generat ...
- 11 Flutter仿京东商城项目 商品列表页面二级筛选导航布局
ProductList.dart import 'package:flutter/material.dart'; import '../services/ScreenAdaper.dart'; imp ...
- 13 Flutter仿京东商城项目 商品列表筛选以及上拉分页加载更多
ProductList.dart import 'package:flutter/material.dart'; import '../services/ScreenAdaper.dart'; imp ...
- 12 Flutter仿京东商城项目 商品列表页面请求数据、封装Loading Widget、上拉分页加载更多
ProductList.dart import 'package:flutter/material.dart'; import '../services/ScreenAdaper.dart'; imp ...
随机推荐
- 理解Windows注册表
理解Windows注册表 注意 完之前先备份reg 前言 在Windows 3.x之前, Windows都是使用.ini文件来保存配置信息的, 但是.ini文件的大小最大只能为64KB, 为了突破这个 ...
- MATLAB中的概率论与数理统计
概率论与数理统计 产生随机数 binornd poissrnd exprnd unidrnd normrnd 概率密度函数(pdf) binopdf poisspdf geopdf unidpdf n ...
- spring 依赖注入总结--为什么官方推荐构造器注入
一 公司小伙伴使用了构造器注入,说是spring的官方推荐.但是,我问了三个问题,他都答不出来,感觉能写篇博文. 官方为什么推荐构造器注入? 构造器注入和属性注入的区别是啥? 你知道有几种注入方式吗? ...
- asp.net5中使用NLog进行日志记录
asp.net5中提供了性能强大的日志框架,本身也提供了几种日志记录方法,比如记录到控制台或者事件中等,但是,对大部分程序员来说,更喜欢使用类似log4net或者Nlog这种日志记录方式,灵活而强大. ...
- UML建模—EA创建Use Case(用例图)
用例图主要用来描述“用户.需求.系统功能单元”之间的关系.它展示了一个外部用户能够观察到的系统功能模型图. 1.新建用例图 2.用例图工具: 3.一个简单用例: 用例图所包含的元素如下: 1. Act ...
- 项目搭建系列之二:SpringMVC框架下配置MyBatis
1.什么是MyBatis? MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis ...
- Spring-boot2.0.1.BUILD-SNAPSHOT整合Elasticsearch报failed to load elasticsearch nodes错误解决办法
spring-boot整合es的application.properties的默认配置为: spring.data.elasticsearch.cluster-nodes=localhost:9200 ...
- 关于Java中用Double型运算时精度丢失的问题
注:转自 https://blog.csdn.net/bleach_kids/article/details/49129943 在使用Java,double 进行运算时,经常出现精度丢失的问题,总是在 ...
- PAT 1051 Pop Sequence
#include <cstdio> #include <cstdlib> #include <vector> using namespace std; bool p ...
- 编写可维护的 Gruntfile.js
load-grunt-tasks 插件 首先介绍下 load-grunt-tasks 这个插件. 我们一般都会把所有用到的插件以及插件的配置写到 Gruntfile.js 里面,对于小项目来说这个文件 ...