jiangchengfeiyi-xiaochengxu/pages/store-home/main/main.vue
2024-11-01 19:56:26 +08:00

340 lines
6.5 KiB
Vue

<template>
<view class="flex-row relative page">
<view class="flex-row items-center section pos_8">
<text class="text">商品</text>
<view class="flex-row items-center section_2 ml-15">
<image class="image"
:src="sousuokuang" />
<input class="text-wrapper ml-3" placeholder="请输入内容" />
</view>
</view>
<view class="flex-col justify-start items-center image-wrapper pos_1">
<image class="shrink-0 image_2"
src="" />
</view>
<view class="flex-col justify-start section_3 pos_9">
<view class="flex-col group">
<view class="flex-col items-center list-item mt-5" v-for="(item, index) in sort" :key="index">
<image class="image_3"
:src="item.imgurl" />
<text class="font_4 mt-3">{{ item.name }}</text>
</view>
</view>
</view>
<view class="flex-col justify-start section_4 pos_4">
<view class="flex-col items-start section_5">
<text class="font_2">材料包</text>
<text class="font_3 text_3 mt-6">提供材料自行DIY</text>
</view>
</view>
<view class="flex-col pos_5">
<scroll-view scroll-y class="scrollable-content">
<view class="flex-row section_9 list-item_2 mt-5" v-for="(item, index) in product_list" :key="index" @click="tap">
<image class="self-center image_4"
:src="item.imgurl" />
<view class="flex-col items-start self-center group_3">
<text class="font_2 text_5">{{ item.product_name }}</text>
<text class="font_3 mt-13">{{ item.detail }}</text>
<text class="font mt-13">{{ item.value }}</text>
</view>
<image class="self-start image_5"
:src="add_img" />
</view>
</scroll-view>
</view>
</view>
</template>
<script setup>
import {
ref,onMounted, toRaw
} from 'vue';
import img1 from '@/pages/store-home/main/img/cailiaobao.png';
import img2 from '@/pages/store-home/main/img/shouchiwu.png';
import img3 from '@/pages/store-home/main/img/toushi.png';
import img4 from '@/pages/store-home/main/img/dingzhi.png';
import img5 from '@/pages/store-home/main/img/jifenduihuan.png';
import product_img from '@/pages/store-home/main/img/shangpingtupian.png';
import add_img from '@/pages/store-home/main/img/tianjia.png';
import sousuokuang from '@/pages/store-home/main/img/sousuokuang.png';
const sort =ref([
{
name:'',
imgurl:'',
id: ''
}
])
onMounted(() => {
// Getproduct_list(),
Getsort()
})
const goodsId=ref([])
const Getsort = async ()=>{
const res = await uni.request({
url:'http://localhost:9092/api/category/list',
method:'POST',
})
console.log(res.data.data);
goodsId.value = res.data.data
console.log(goodsId.value[0].id)
if(res.data.data != null){
for(let key in res.data.data) {
sort.value[key] = {
name : res.data.data[key].typeName,
imgurl : res.data.data[key].typeUrl,
id : res.data.data[key].id
}
}
}
// console.log(sort,2132131)
// console.log(sort._rawValue[0].id)
}
// const Getproduct_list = async()=>{
// const res = await uni.request({
// url:'http://localhost:9092/api/category/list/type',
// method:'POST',
// })
// if(res.data.data == ){
// }
// }
const product_list = ref([{
product_name: "",
detail: "",
value: "",
imgurl: "",
id:""
}
])
const product_type = [{
type: "材料包",
detail: "提供材料自行DIY"
}]
const tap =()=> {
uni.navigateTo({
url: '../../../pages/store-home/ProductDetails/ProductDetails'
})
}
</script>
<style lang="scss" scoped>
.scrollable-content {
height: 56vh;
/* 100px 是头部和底部的高度之和 */
}
.ml-15 {
margin-left: 28.13rpx;
}
.ml-3 {
margin-left: 5.63rpx;
}
.mt-3 {
margin-top: 5.63rpx;
text-align: center;
}
.mt-13 {
margin-top: 24.38rpx;
}
.mt-5 {
margin-top: 9.38rpx;
}
.page {
background-color: #f5f5dc;
// height: 1413.75rpx;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100vh;
overflow: hidden;
}
.section {
padding: 22.5rpx 39.28rpx 16.88rpx;
background-color: #f7de98;
}
.pos_8 {
position: absolute;
left: 0;
right: 0;
top: 0;
}
.text {
color: #c1651a;
font-size: 37.5rpx;
font-family: STFangsong;
line-height: 36.19rpx;
}
.section_2 {
padding: 5.63rpx 15rpx 8.44rpx;
background-color: #ffffff;
border-radius: 28.13rpx;
height: 63.75rpx;
width: 500.69rpx;
}
.image {
width: 50.63rpx;
height: 50.63rpx;
}
.text-wrapper {
margin-right: 17.42rpx;
}
.font {
font-size: 26.25rpx;
font-family: STFangsong;
line-height: 18rpx;
color: #ff0000;
}
.image-wrapper {
background-color: #ffffff;
border-radius: 28.13rpx;
overflow: hidden;
border: solid 9.38rpx #ffffff;
}
.pos_1 {
position: absolute;
left: 22.5rpx;
right: 24.38rpx;
top: 118.13rpx;
}
.image_2 {
width: 91.25vw;
height: 37.5vw;
}
.section_3 {
padding: 8.44rpx 5.63rpx 750rpx;
background-color: #f7de98;
width: 151.88rpx;
}
.pos_9 {
position: absolute;
left: 0;
top: 440.63rpx;
}
.group {
margin: auto;
width: 137.81rpx;
}
.list-item {
padding: 11.25rpx 0 9.94rpx;
background-color: #fffef8;
border-radius: 9.38rpx;
}
.list-item:first-child {
margin-top: 0;
}
.image_3 {
border-radius: 0rpx 9.38rpx 9.38rpx 0rpx;
width: 60rpx;
height: 60rpx;
}
.font_4 {
font-size: 25rpx;
font-family: STFangsong;
line-height: 28.26rpx;
color: #c1651a;
}
.section_4 {
padding-bottom: 879.38rpx;
background-color: #f8e8c1;
border-radius: 0rpx 18.75rpx 0rpx 0rpx;
width: 600.13rpx;
}
.pos_4 {
position: absolute;
right: 0;
top: 440.63rpx;
}
.section_5 {
padding: 18.06rpx 16.24rpx 14.94rpx;
background-color: #fffef8;
border-radius: 0rpx 18.75rpx 0rpx 0rpx;
width: 598.13rpx;
}
.font_2 {
font-size: 30rpx;
font-family: STFangsong;
line-height: 28.26rpx;
color: #000000;
}
.font_3 {
font-size: 22.5rpx;
font-family: STFangsong;
line-height: 21.56rpx;
color: #727272;
}
.text_3 {
line-height: 21.15rpx;
}
.pos_5 {
position: absolute;
right: 15rpx;
top: 543.75rpx;
}
.section_9 {
padding: 20.63rpx 22.88rpx 22.5rpx;
background-color: #fffef8;
border-radius: 9.38rpx;
right: 13.13rpx;
}
.list-item_2:first-child {
margin-top: 0;
}
.image_4 {
border-radius: 9.38rpx;
width: 131.25rpx;
height: 131.25rpx;
}
.group_3 {
margin-left: 24.84rpx;
}
.text_5 {
line-height: 28.65rpx;
}
.image_5 {
margin: 75rpx 5.63rpx 0 107.96rpx;
border-radius: 9.38rpx;
width: 56.25rpx;
height: 56.25rpx;
}
@import url(../../../common/css/global.css);
</style>