Browse Source

上拉加载更多

lzm_web
Linzm 7 months ago
parent
commit
f2a24a0004
  1. 2
      components.d.ts
  2. 4
      src/views/badge/myOrder.vue
  3. 153
      src/views/badge/record.vue

2
components.d.ts vendored

@ -24,7 +24,9 @@ declare module '@vue/runtime-core' { @@ -24,7 +24,9 @@ declare module '@vue/runtime-core' {
VanDivider: typeof import('vant/es')['Divider']
VanField: typeof import('vant/es')['Field']
VanIcon: typeof import('vant/es')['Icon']
VanImage: typeof import('vant/es')['Image']
VanList: typeof import('vant/es')['List']
VanPullRefresh: typeof import('vant/es')['PullRefresh']
VanStepper: typeof import('vant/es')['Stepper']
}
}

4
src/views/badge/myOrder.vue

@ -30,7 +30,7 @@ function getOrder() { @@ -30,7 +30,7 @@ function getOrder() {
loading.value = true
badgeApi.getMyOrder({
page: page.value,
pageSize: 10,
size: 30,
status: 0,
}).then(res => {
if(page.value === 1) {
@ -38,7 +38,7 @@ function getOrder() { @@ -38,7 +38,7 @@ function getOrder() {
} else {
orders.value.push(...res.list)
}
if(res.list.length < 10) {
if(res.total <= orders.value.length) {
finished.value = true
} else {
page.value++

153
src/views/badge/record.vue

@ -5,6 +5,7 @@ @@ -5,6 +5,7 @@
</div>
<div class="record-container">
<div class="record-note">可点击效果图进行下单打印</div>
<van-pull-refresh v-model="refreshing" @refresh="onRefresh">
<van-list
v-model:loading="loading"
:finished="finished"
@ -14,7 +15,7 @@ @@ -14,7 +15,7 @@
<div class="record-images" v-if="images.length > 0">
<div class="record-image-item" v-for="item in images" :key="item.id">
<block v-if="item.status == 1" @click="goPreview(item)">
<img :src="item.path" :alt="item.name" style="width: 100%; height: 100%; object-fit: cover; border-radius: 50%;">
<img :src="item.path" :alt="item.name" class="record-image">
<div class="record-image-item-shadow"></div>
</block>
<div v-else-if="item.status == 0" class="record-image-item-loading">
@ -25,49 +26,67 @@ @@ -25,49 +26,67 @@
</div>
</div>
</div>
<div v-else-if="loading && page.value === 1" class="record-image-item-loading">
加载中...
</div>
<div v-else class="record-image-item-null">
<img src="@/assets/badge/null-data.png" alt="暂无数据">
</div>
</van-list>
</van-pull-refresh>
</div>
</div>
</template>
<script setup lang="ts">
import { useRouter } from 'vue-router';
import * as badgeApi from '@/api/badge';
import { onMounted, ref } from 'vue';
import { onMounted, ref, onUnmounted } from 'vue';
const router = useRouter();
const images = ref([]);
onMounted(() => {
getList();
});
const page = ref(1)
const loading = ref(false)
const finished = ref(false)
const page = ref(1);
const loading = ref(false);
const finished = ref(false);
const error = ref(null);
const refreshing = ref(false);
//
async function getList() {
//
console.log(loading.value, finished.value);
if (loading.value || finished.value) return;
function getList() {
if(loading.value) return
loading.value = true
loading.value = true;
error.value = null;
badgeApi.getLogOage({
try {
// API
const res = await badgeApi.getLogOage({
page: page.value,
size: 100,
}).then(res => {
if(page.value === 1) {
images.value = res.list
size: 20,
});
if (page.value === 1) {
images.value = res.list || [];
} else {
images.value.push(...res.list)
images.value.push(...(res.list || []));
}
if(res.total <= images.value.length) {
finished.value = true
//
if (!res.list || res.list.length < 20) {
finished.value = true;
} else {
page.value++
page.value++;
}
} catch (err: any) {
error.value = err.message || '获取数据失败';
console.error('获取设计记录失败', err);
} finally {
loading.value = false;
}
}).finally(() => {
loading.value = false
})
}
//
function goPreview(item) {
router.push({
path: '/badge/preview',
@ -77,53 +96,85 @@ function goPreview(item) { @@ -77,53 +96,85 @@ function goPreview(item) {
key: item.num,
prod_id: item.prod_id
},
})
});
}
//
function onLoad() {
getList()
loading.value = false;
getList();
}
const router = useRouter();
//
async function onRefresh() {
refreshing.value = true;
page.value = 1;
finished.value = false;
await getList();
refreshing.value = false;
}
//
function goBack() {
router.push('/badge');
}
//
onMounted(() => {
getList();
});
//
onUnmounted(() => {
loading.value = false;
finished.value = false;
page.value = 1;
});
</script>
<style scoped>
.header {
.header {
display: flex;
align-items: center;
height: 40px;
font-size: 14px;
color: #999;
padding: 16px 16px 0 16px;
}
.back-icon {
}
.back-icon {
margin-right: 8px;
color: #222;
font-size: 16px;
cursor: pointer;
}
.record-container {
}
.record-container {
padding: 16px;
}
.record-note {
}
.record-note {
font-size: 12px;
color: #999;
margin-bottom: 16px;
}
.record-images {
}
.record-images {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 16px;
}
.record-image-item {
}
.record-image-item {
width: 100%;
padding-bottom: 100%;
position: relative;
overflow: hidden;
cursor: pointer;
border-radius: 12px;
}
.record-image-item img {
}
.record-image {
position: absolute;
top: 0;
left: 0;
@ -131,18 +182,20 @@ function goBack() { @@ -131,18 +182,20 @@ function goBack() {
height: 100%;
border-radius: 50%;
object-fit: cover;
}
.record-image-item-shadow {
}
.record-image-item-shadow {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
object-fit: cover;
box-shadow: inset 2px 2px 4px rgba(255, 255, 255, 0.5),inset -2px -2px 4px rgba(0, 0, 0, 0.2);
box-shadow: inset 2px 2px 4px rgba(255, 255, 255, 0.5), inset -2px -2px 4px rgba(0, 0, 0, 0.2);
border-radius: 50%;
}
.record-image-item-loading {
}
.record-image-item-loading {
position: absolute;
top: 0;
left: 0;
@ -155,15 +208,17 @@ function goBack() { @@ -155,15 +208,17 @@ function goBack() {
border-radius: 50%;
font-size: 16px;
color: #999;
}
.record-image-item-null {
}
.record-image-item-null {
height: 50vh;
display: flex;
justify-content: center;
align-items: center;
}
.record-image-item-null img {
}
.record-image-item-null img {
width: 80vw;
height: 200px;
}
}
</style>
Loading…
Cancel
Save