Update swiper implementation and configuration

This commit is contained in:
wangqiao
2025-08-27 15:45:40 +08:00
parent 9acc229704
commit 7413b1a74d
3 changed files with 386 additions and 458 deletions

View File

@ -11,13 +11,7 @@ export default defineNuxtConfig({
debug: process.env.NODE_ENV === 'development', // 开启详细调试日志 debug: process.env.NODE_ENV === 'development', // 开启详细调试日志
ssr: true, ssr: true,
modules: [ modules: ['@unocss/nuxt', '@pinia/nuxt', '@element-plus/nuxt', 'pinia-plugin-persistedstate/nuxt', 'nuxt-swiper'],
'@unocss/nuxt',
'@pinia/nuxt',
'@element-plus/nuxt',
'pinia-plugin-persistedstate/nuxt',
'nuxt-swiper',
],
css: ['@unocss/reset/tailwind.css', 'element-plus/dist/index.css', '~/assets/scss/app.scss'], css: ['@unocss/reset/tailwind.css', 'element-plus/dist/index.css', '~/assets/scss/app.scss'],
vite: { vite: {
css: { css: {
@ -74,8 +68,7 @@ export default defineNuxtConfig({
{ name: 'viewport', content: 'width=device-width, initial-scale=1' }, { name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ {
name: 'description', name: 'description',
content: content: '图夕夕是一家图纸素材分享交易平台提供AutoCAD/ProE/Creo/CATIA/UG/inventor/CAXA/等建筑图纸的素材下载及免费教程。',
'图夕夕是一家图纸素材分享交易平台提供AutoCAD/ProE/Creo/CATIA/UG/inventor/CAXA/等建筑图纸的素材下载及免费教程。',
}, },
{ name: 'keywords', content: '图纸,图纸下载,设计素材,图纸大全,设计图纸,,工程图纸,cad图纸' }, { name: 'keywords', content: '图纸,图纸下载,设计素材,图纸大全,设计图纸,,工程图纸,cad图纸' },
{ name: 'author', content: '图夕夕' }, { name: 'author', content: '图夕夕' },
@ -86,8 +79,7 @@ export default defineNuxtConfig({
}, },
{ {
property: 'og:description', property: 'og:description',
content: content: '图夕夕是一家图纸素材分享交易平台提供AutoCAD/ProE/Creo/CATIA/UG/inventor/CAXA/等建筑图纸的素材下载及免费教程。',
'图夕夕是一家图纸素材分享交易平台提供AutoCAD/ProE/Creo/CATIA/UG/inventor/CAXA/等建筑图纸的素材下载及免费教程。',
}, },
{ property: 'og:type', content: 'website' }, { property: 'og:type', content: 'website' },
{ property: 'og:url', content: 'https://www.xlcig.cn' }, { property: 'og:url', content: 'https://www.xlcig.cn' },
@ -96,7 +88,16 @@ export default defineNuxtConfig({
// robots meta // robots meta
{ name: 'robots', content: 'index, follow' }, { name: 'robots', content: 'index, follow' },
], ],
link: [{ rel: 'icon', type: 'image/x-icon', href: '/favicon2.ico' }], link: [
{ rel: 'icon', type: 'image/x-icon', href: '/favicon2.ico' },
{ rel: 'stylesheet', type: 'text/css', href: 'https://unpkg.com/swiper@8/swiper-bundle.css' },
],
script: [
{
type: 'text/javascript',
src: 'https://unpkg.com/swiper@8/swiper-bundle.js',
},
],
}, },
}, },

View File

@ -2,7 +2,9 @@
<KlNavTab /> <KlNavTab />
<div class="ml-auto mr-auto mt-[20px] w-[1440px]"> <div class="ml-auto mr-auto mt-[20px] w-[1440px]">
<div class="flex items-center"> <div class="flex items-center">
<div class="box-border h-[60px] w-[1019px] flex items-center justify-between border border-[#EEEEEE] rounded-[12px] border-solid bg-[#FFFFFF] px-[27px] py-[24px]"> <div
class="box-border h-[60px] w-[1019px] flex items-center justify-between border border-[#EEEEEE] rounded-[12px] border-solid bg-[#FFFFFF] px-[27px] py-[24px]"
>
<div class="text-[20px] text-[#333333] font-normal"> {{ detail?.title }}</div> <div class="text-[20px] text-[#333333] font-normal"> {{ detail?.title }}</div>
<div class="flex items-center"> <div class="flex items-center">
<img :src="detail?.ownedUserIdInfo?.avatar" alt="" srcset="" class="h-[30px] w-[30px] rd-[50%]" /> <img :src="detail?.ownedUserIdInfo?.avatar" alt="" srcset="" class="h-[30px] w-[30px] rd-[50%]" />
@ -35,12 +37,14 @@
<div class="ma-auto mt-[21px] flex"> <div class="ma-auto mt-[21px] flex">
<div class="w-[1019px]"> <div class="w-[1019px]">
<div> <div>
<ThumBnail :data="detail?.coverImages" :type="detail?.type" @change-swiper="changeSwiper" @next-swiper="nextSwiper"></ThumBnail> <ThumBnail :data="detail?.coverImages" :type="detail?.type"></ThumBnail>
</div> </div>
<div class="mb-[20px] mt-[34px] flex items-center text-[16px] text-[#333333] font-normal"> <div class="mb-[20px] mt-[34px] flex items-center text-[16px] text-[#333333] font-normal">
<div class="h-[24px] w-[4px] rounded-[1px] bg-[#1A65FF]"></div><span class="ml-[10px]">{{ detail?.title }}描述</span></div <div class="h-[24px] w-[4px] rounded-[1px] bg-[#1A65FF]"></div><span class="ml-[10px]">{{ detail?.title }}描述</span></div
> >
<div class="box-border min-h-[90px] w-[1019px] border border-[#EEEEEE] rounded-[6px] border-solid bg-[#FFFFFF] pa-[24px] text-[14px] text-[#333333] font-normal"> <div
class="box-border min-h-[90px] w-[1019px] border border-[#EEEEEE] rounded-[6px] border-solid bg-[#FFFFFF] pa-[24px] text-[14px] text-[#333333] font-normal"
>
{{ detail?.description }} {{ detail?.description }}
</div> </div>
<div id="section1" class="mb-[20px] mt-[34px] flex items-center text-[16px] text-[#333333] font-normal"> <div id="section1" class="mb-[20px] mt-[34px] flex items-center text-[16px] text-[#333333] font-normal">
@ -188,7 +192,6 @@
const route = useRoute() const route = useRoute()
const id = route.params.id as string const id = route.params.id as string
// 获取详情 // 获取详情
// const detail = ref<ProjectRespVO>({} as ProjectRespVO) // const detail = ref<ProjectRespVO>({} as ProjectRespVO)
@ -197,15 +200,14 @@
return res.data return res.data
}) })
console.log('==', detail.value); console.log('==', detail.value)
if (!detail.value) { if (!detail.value) {
throw createError({ throw createError({
statusCode: 404, statusCode: 404,
statusMessage: 'Page Not Found', statusMessage: 'Page Not Found',
fatal: true fatal: true,
}); })
} }
// const init = () => { // const init = () => {
@ -227,7 +229,7 @@
const [{ data: mainWork }, { data: userInfo }, { data: relationRecommend }] = await Promise.all([ const [{ data: mainWork }, { data: userInfo }, { data: relationRecommend }] = await Promise.all([
getMainWork({ id: detail.value?.id, limit: 10, memberId: detail.value?.ownedUserId }), getMainWork({ id: detail.value?.id, limit: 10, memberId: detail.value?.ownedUserId }),
getUserInfo({ id: detail.value?.id }), getUserInfo({ id: detail.value?.id }),
getRelationRecommend({ type: detail.value?.type, projectType: detail.value?.projectType[0] }) getRelationRecommend({ type: detail.value?.type, projectType: detail.value?.projectType[0] }),
]) ])
// 获取最新发布 // 获取最新发布
@ -259,13 +261,6 @@
// }) // })
// } // }
const changeSwiper = (index: number) => {
console.log(index)
}
const nextSwiper = (val: any) => {
console.log(val)
}
const handleDownloadPreview = (item: any) => { const handleDownloadPreview = (item: any) => {
// 预览pdf // 预览pdf
navigateTo(`/pdf-preview?url=${item.url}`) navigateTo(`/pdf-preview?url=${item.url}`)
@ -372,4 +367,3 @@
downloadFile(url, name) downloadFile(url, name)
} }
</script> </script>

View File

@ -1,74 +1,32 @@
<template> <template>
<div <div class="box-border h-[631px] w-[1019px] border border-[#EEEEEE] rounded-[12px] border-solid bg-[#FFFFFF] pa-[30px]">
class="box-border h-[631px] w-[1019px] border border-[#EEEEEE] rounded-[12px] border-solid bg-[#FFFFFF] pa-[30px]" <div style="--swiper-navigation-color: #fff; --swiper-pagination-color: #fff" class="swiper mySwiper2">
> <div class="swiper-wrapper">
<ClientOnly> <div class="swiper-slide" v-for="(item, index) in props.data" :key="index">
<swiper <img :src="item.url" />
:style="{ </div>
'--swiper-navigation-color': '#666', </div>
'--swiper-pagination-color': '#666', <div class="swiper-button-next"></div>
}" <div class="swiper-button-prev"></div>
:space-between="10" </div>
disabled-class=""
:thumbs="{ swiper: thumbsSwiper }"
:modules="modules"
class="mySwiper2"
@swiper="onSwiper"
@slide-change="changeSwiper"
>
<swiper-slide v-for="(item, index) in props.data" :key="index"
><el-image fit="cover" :src="item.url"
/></swiper-slide>
<div class="swiper-button-prev color-[#fff]" @click="handlePrev"></div
><!--左箭头如果放置在swiper外面需要自定义样式-->
<div class="swiper-button-next color-[#fff]" @click="handleNext"></div
><!--右箭头如果放置在swiper外面需要自定义样式-->
</swiper>
</ClientOnly>
</div> </div>
<div class="mb-[20px] mt-[34px] flex items-center text-[16px] text-[#333333] font-normal"> <div class="mb-[20px] mt-[34px] flex items-center text-[16px] text-[#333333] font-normal">
<div class="h-[24px] w-[4px] rounded-[1px] bg-[#1A65FF]"></div <div class="h-[24px] w-[4px] rounded-[1px] bg-[#1A65FF]"></div>
><span class="ml-[10px]">{{ <span class="ml-[10px]">{{ props.type === 1 ? '图纸' : props.type === 2 ? '文本' : '模型' }}</span>
props.type === 1 ? '图纸' : props.type === 2 ? '文本' : '模型' </div>
}}</span></div <div class="box-border h-[126px] w-[1019px] border border-[#EEEEEE] rounded-[6px] border-solid bg-[#FFFFFF] pa-[23px]">
> <div thumbsSlider="" class="swiper mySwiper">
<div <div class="swiper-wrapper">
class="box-border h-[126px] w-[1019px] border border-[#EEEEEE] rounded-[6px] border-solid bg-[#FFFFFF] pa-[23px]" <div class="swiper-slide" v-for="(item, index) in props.data" :key="index">
> <img :src="item.url" />
<ClientOnly> </div>
<swiper </div>
:space-between="10"
:slides-per-view="4"
:free-mode="true"
:watch-slides-progress="true"
:modules="modules"
class="mySwiper"
@swiper="setThumbsSwiper"
>
<swiper-slide v-for="(item, index) in props.data" :key="index">
<div class="Thumbs">
<el-image fit="cover" :src="item.url" />
</div> </div>
</swiper-slide>
</swiper>
</ClientOnly>
</div> </div>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import type { PropType } from 'vue' import type { PropType } from 'vue'
import { ref, watch, nextTick } from 'vue' import { ref, watch, nextTick, onMounted } from 'vue'
import { Swiper, SwiperSlide } from 'swiper/vue'
import 'swiper/css'
import 'swiper/css/free-mode'
import 'swiper/css/navigation'
import 'swiper/css/thumbs'
// import required modules
import { FreeMode, Navigation, Thumbs } from 'swiper/modules'
const modules = [FreeMode, Navigation, Thumbs]
const props = defineProps({ const props = defineProps({
data: { data: {
@ -81,50 +39,25 @@
}, },
}) })
const emit = defineEmits(['changeSwiper', 'nextSwiper']) onMounted(() => {
// Initialize Swiper
const thumbsSwiper = ref<any>(null) var swiper = new Swiper('.mySwiper', {
const useSwiper = ref<any>(null) spaceBetween: 10,
const activeIndex = ref<number>(0) slidesPerView: 4,
freeMode: true,
watch( watchSlidesProgress: true,
() => props.data, })
(value) => { var swiper2 = new Swiper('.mySwiper2', {
if (value.length) { spaceBetween: 10,
nextTick(() => { navigation: {
const thumb_active = document.querySelector(`.mySwiper .swiper-slide`) nextEl: '.swiper-button-next',
thumb_active?.classList.add('swiper-slide-thumb-active') prevEl: '.swiper-button-prev',
},
thumbs: {
swiper: swiper,
},
})
}) })
}
}
)
const setThumbsSwiper = (swiper: any) => {
thumbsSwiper.value = swiper
}
const handlePrev = () => {
if (activeIndex.value === 0 || props.data.length === 0) {
emit('nextSwiper', false)
}
useSwiper.value.slidePrev()
}
const handleNext = () => {
if (activeIndex.value === props.data.length - 1 || props.data.length === 0) {
emit('nextSwiper', true)
}
useSwiper.value.slideNext()
}
const onSwiper = (swiper: any) => {
useSwiper.value = swiper
}
const changeSwiper = (e: any) => {
activeIndex.value = e.activeIndex
emit('changeSwiper', e.activeIndex)
}
</script> </script>
<style scoped> <style scoped>