Update swiper implementation and configuration
This commit is contained in:
@ -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',
|
||||||
|
},
|
||||||
|
],
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|||||||
@ -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>
|
||||||
|
|
||||||
@ -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>
|
||||||
|
|||||||
Reference in New Issue
Block a user