<template> <view class="pages"> <!-- <view class="search-wrap nomal-bottom"> <view class="search"> <view class="searchTxt"> <uni-search-bar :placeholder="searchtxt" @confirm="search" @input="search" ></uni-search-bar> </view> </view> </view> --> <!-- 搜索 结束 --> <mescroll-body class="wrap" ref="mescrollRef" @init="mescrollInit" @down="downCallback" @up="upCallback" :down="downOption" :up="upOption"> <view class="results write-radius"> <view v-for="(item,index) in dataList" :key="index" @click="productdetails(item.id)" class="results-item"> <view class="results-item-img-wrap"><image :src="$getimg+item.pic|miniImg(50)+'/thumbnail/358x358'" mode="scaleToFill" class="results-item-img cover-img"></image></view> <view class="results-item-info"> <view class="results-item-info-til">{{item.name}}</view> <view class="results-item-info-brand">{{item.brandName}}</view> <!-- <view class="results-item-info-addr">{{item.placeOfProduction}}</view> --> <view class="results-item-info-label"> <text v-if="item.postage" class="postage">包邮</text> </view> <view class="item-spec f-ellipsis"> <text>规格:</text><text>{{item.spec}}</text> </view> <view class="results-item-info-company f-ellipsis">{{item.compName}}</view> <view class="results-item-info-price"> <text class="rmb">¥</text> <text class="price">{{item.price}}</text> <text class="unit">/{{item.unit}}</text> <!-- <text class="minsell">4000斤起售</text> --> </view> </view> </view> </view> </mescroll-body> </view> </template> <script> // 引入mescroll-mixins.js import MescrollMixin from "@/components/mescroll-uni/mescroll-mixins.js"; // 引入mescroll-body组件 (如已在main.js注册全局组件,则省略此步骤) import MescrollBody from "@/components/mescroll-uni/mescroll-body.vue"; // 注意.vue后缀不能省 import uniSearchBar from '@/components/uni-search-bar/uni-search-bar.vue' export default { mixins: [MescrollMixin], // 使用mixin components: { MescrollBody, uniSearchBar, }, data() { return { title:'', searchtxt:'产品名称', params:{ token:'', keyword:'', subjectId:'', }, mescroll: null, // mescroll实例对象 (此行可删,mixins已默认) // 下拉刷新的配置(可选, 绝大部分情况无需配置) downOption: { // ... }, // 上拉加载的配置(可选, 绝大部分情况无需配置) upOption: { page: { size: 10 // 每页数据的数量,默认10 }, noMoreSize: 5, // 配置列表的总数量要大于等于5条才显示'-- END --'的提示 empty: { tip: '暂无相关数据' } }, // 列表数据 dataList:[], } }, onShow() { let serf = this; //检查登录,获取token // let loginRes = this.checkLogin('/pages/index/index', '2'); // if(!loginRes){return false;} // serf.params.token=loginRes[0]; }, onReady() { uni.setNavigationBarTitle({ title: this.title }); }, onLoad(option) { console.log('option',option); if(option.subjectId){ this.params.subjectId = option.subjectId; this.searchtxt = option.name; } if(option.title){ this.title = option.title } // if(option.keyword){ // this.params.keyword = option.keyword; // this.searchtxt = option.keyword; // } // console.log(this.params.keyword); }, methods: { //搜索 search(e) { console.log(e); this.params.keyword = e.value; this.params.subjectId = ''; this.searchtxt = e.value; this.downCallback(); // this.poorList = []; // this.params.farmerName = e.value; // this.pagination = Object.assign(this.pagination,{"farmerName":e.value}); // this.pagination.pageNo = 1; // this.getPoorList(this.pagination) }, /*mescroll组件初始化的回调,可获取到mescroll对象 (此处可删,mixins已默认)*/ mescrollInit(mescroll) { this.mescroll = mescroll; }, downCallback(){ this.mescroll.resetUpScroll(); // 重置列表为第一页 (自动执行 page.num=1, 再触发upCallback方法 ) }, /*上拉加载的回调*/ upCallback(page) { let pageNum = page.num; // 页码, 默认从1开始 let pageSize = page.size; // 页长, 默认每页10条 this.params = Object.assign(this.params,{pageNum:pageNum,pageSize:pageSize}); this.$api.http.get(this.config.apiBaseurl+'/home/subjectProductList',{params: this.params}).then(data => { if(data.data.code=='1001'){ // uni.redirectTo({ // url:'/pages/login/login?backpage=/pages/index/index'+'&backtype='+2, // }); }; console.log('data',JSON.parse(JSON.stringify(data))); // 接口返回的当前页数据列表 (数组) let curPageData = data.data.data; console.log('curPageData',JSON.parse(JSON.stringify(curPageData))); // 接口返回的当前页数据长度 (如列表有26个数据,当前页返回8个,则curPageLen=8) let curPageLen = curPageData.length; // 接口返回的总页数 (如列表有26个数据,每页10条,共3页; 则totalPage=3) let totalPage = data.data.data.totalPage; // 接口返回的总数据量(如列表有26个数据,每页10条,共3页; 则totalSize=26) let totalSize = data.data.data.total; // 接口返回的是否有下一页 (true/false) // let hasNext = data.xxx; console.log('totalPage',totalPage,'curPageLen',curPageLen); //设置列表数据 if(page.num == 1) this.dataList = []; //如果是第一页需手动置空列表 this.dataList = this.dataList.concat(curPageData); //追加新数据 // 请求成功,隐藏加载状态 //方法一(推荐): 后台接口有返回列表的总页数 totalPage this.mescroll.endByPage(curPageLen, totalPage); //方法二(推荐): 后台接口有返回列表的总数据量 totalSize // this.mescroll.endBySize(curPageLen, totalSize); // setTimeout(()=>{ // this.mescroll.endSuccess(curPageLen) // },20) }).catch(err => { this.mescroll.endErr() console.log(err) }); }, //跳转详情 productdetails(id){ uni.navigateTo({ url:`/pages/product/product?id=${id}` }) }, } } </script> <style scoped> @import url("./subject.css"); </style>