You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
76 lines
1.6 KiB
76 lines
1.6 KiB
<template>
|
|
<su-swiper
|
|
:list="imgList"
|
|
:dotStyle="'tag'"
|
|
imageMode="widthFix"
|
|
dotCur="bg-mask-40"
|
|
:seizeHeight="300"
|
|
:autoplay="true"
|
|
:interval="3000"
|
|
/>
|
|
</template>
|
|
|
|
<-- <script setup>
|
|
import { computed } from 'vue';
|
|
import sheep from '@/sheep';
|
|
|
|
|
|
const imgList = computed(() =>
|
|
props.data.list.map((item) => ({
|
|
...item,
|
|
src: sheep.$url.cdn(item.src),
|
|
poster: sheep.$url.cdn(item.poster),
|
|
})),
|
|
);
|
|
</script> -->
|
|
|
|
<script setup>
|
|
import sheep from '@/sheep';
|
|
import { onLoad } from '@dcloudio/uni-app';
|
|
import { reactive } from 'vue';
|
|
|
|
const state = reactive({
|
|
imgList: [],
|
|
});
|
|
// 获取公告列表
|
|
async function getNoticeList() {
|
|
let { code, data: { data }, msg } = await sheep.$api.announcement.list();
|
|
if (code === 1) {
|
|
state.noticeData = data;
|
|
} else {
|
|
state.noticeData = [];
|
|
}
|
|
}
|
|
|
|
function onDetail(orderId) {
|
|
sheep.$router.go('/pages/announcement/detail', {
|
|
id: orderId,
|
|
});
|
|
}
|
|
|
|
onLoad(async (options) => {
|
|
// 非法参数
|
|
if (!options.id) {
|
|
state.imgList = [];
|
|
return;
|
|
}
|
|
state.goodsId = options.id;
|
|
// 加载商品信息
|
|
sheep.$api.goods.detail(state.goodsId).then((res) => {
|
|
state.skeletonLoading = false;
|
|
if (res.code === 1) {
|
|
state.goodsInfo = res.data;
|
|
state.goodsSwiper = formatGoodsSwiper(state.goodsInfo.images);
|
|
} else {
|
|
// 未找到商品
|
|
state.goodsInfo = null;
|
|
}
|
|
});
|
|
const { code, data } = await sheep.$api.coupon.listByGoods(state.goodsId);
|
|
if (code === 1) {
|
|
state.couponInfo = data;
|
|
}
|
|
});
|
|
</script>
|
|
|
|
<style></style>
|
|
|