Compare commits
	
		
			2 Commits
		
	
	
		
			6ccb1eb099
			...
			40057b3ca4
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 40057b3ca4 | ||
|  | 99f58f7aff | 
| @ -1,5 +1,7 @@ | ||||
| // router/index.js
 | ||||
| import { createRouter, createWebHistory } from 'vue-router'; | ||||
| import { setupRouterGuards } from './router-guards'; | ||||
| 
 | ||||
| const routes = [ | ||||
|     { | ||||
|         path: '/', | ||||
| @ -42,4 +44,5 @@ router.beforeEach((to, from, next) => { | ||||
|     } | ||||
|     next() | ||||
| }); | ||||
| setupRouterGuards(router); | ||||
| export default router; | ||||
|  | ||||
							
								
								
									
										6
									
								
								src/router/router-guards.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								src/router/router-guards.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,6 @@ | ||||
| // router/router-guards.js
 | ||||
| export function setupRouterGuards (router) { | ||||
|     router.afterEach(() => { | ||||
|         window.scrollTo(0, 0); | ||||
|     }); | ||||
| } | ||||
| @ -1,5 +1,7 @@ | ||||
| <template> | ||||
|   <div class="page-container"> | ||||
|     <n-divider class="divider1" vertical /> | ||||
|     <n-divider class="divider5" vertical /> | ||||
|     <header className="header flex items-center justify-between"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
| @ -74,7 +76,7 @@ | ||||
|               moveRefs[3].value = el; | ||||
|             } | ||||
|           " | ||||
|           class="absolute bottom-[-424px] right-[0px]" | ||||
|           class="absolute bottom-[-376px] right-[0px] z-4" | ||||
|         > | ||||
|           <img | ||||
|             src="@/assets/image/businessintroduction/375/bg-2.png" | ||||
| @ -543,17 +545,14 @@ | ||||
|               凭借前沿的传播策略,精准狙击全球受众心智。深度整合顶级媒体资源,让曝光量呈指数级突破,全方位塑造全球品牌影响力,引领文艺潮流走向世界舞台中央 | ||||
|             </div> | ||||
|           </div> | ||||
|           <div class="mt-[46px] mb-[246px] px-[108px]"> | ||||
|             <div | ||||
|             class="mt-[140px] mb-[175px] carousel-container px-[80px] py-[40px]" | ||||
|           > | ||||
|             <div ref="carouselTrack" class="carousel-track"> | ||||
|               <div | ||||
|                 v-for="(item, idx) in getVisibleItems()" | ||||
|               v-for="(item, idx) in state.marqueeArr" | ||||
|               :key="idx" | ||||
|                 class="carousel-item" | ||||
|               class="w-full flex flex-wrap justify-center carousel-item" | ||||
|             > | ||||
|               <img class="carousel-image" :src="item.imgUrl" /> | ||||
|                 <div class="carousel-title"> | ||||
|               <div class="carousel-title w-full"> | ||||
|                 <div>{{ item.title }}</div> | ||||
|               </div> | ||||
|               <div class="carousel-subtitle"> | ||||
| @ -562,7 +561,6 @@ | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <section | ||||
| @ -570,7 +568,7 @@ | ||||
|         className="flex flex-wrap justify-center" | ||||
|       > | ||||
|         <img | ||||
|           class="w-[580px] h-[55px] my-[85px]" | ||||
|           class="w-[891px] h-[87px] mt-[61px] mb-[56px]" | ||||
|           src="@/assets/image/image-footer.png" | ||||
|           alt="logo" | ||||
|         /> | ||||
| @ -580,6 +578,7 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { NDivider } from "naive-ui"; | ||||
| import { onUnmounted, ref, onMounted, reactive, nextTick } from "vue"; | ||||
| import gsap from "gsap"; | ||||
| import { ScrollTrigger } from "gsap/ScrollTrigger"; | ||||
| @ -629,15 +628,8 @@ const state = reactive({ | ||||
|   ], | ||||
| }); | ||||
| 
 | ||||
| const carouselTrack = ref(null); | ||||
| let carouselAnimation = null; // 存储 GSAP 动画实例 | ||||
| 
 | ||||
| const getVisibleItems = () => { | ||||
|   const items = state.marqueeArr; | ||||
|   // 复制两组用于无缝滚动 | ||||
|   return [...items, ...items]; | ||||
| }; | ||||
| 
 | ||||
| // 监听窗口大小变化 | ||||
| onMounted(() => { | ||||
|   ctx = gsap.context(() => { | ||||
| @ -668,32 +660,6 @@ onMounted(() => { | ||||
|         }); | ||||
|       } | ||||
|     }); | ||||
| 
 | ||||
|     // 初始化轮播动画 | ||||
|     nextTick(() => { | ||||
|       if (carouselTrack.value) { | ||||
|         const firstItem = carouselTrack.value.querySelector(".carousel-item"); | ||||
|         if (!firstItem) return; | ||||
| 
 | ||||
|         const itemWidth = firstItem.offsetWidth; | ||||
|         const itemMargin = parseInt( | ||||
|           window.getComputedStyle(firstItem).marginRight | ||||
|         ); | ||||
|         const slideWidth = itemWidth + itemMargin; | ||||
|         const totalWidth = slideWidth * state.marqueeArr.length; | ||||
| 
 | ||||
|         // 创建无限滚动动画 | ||||
|         carouselAnimation = gsap.to(carouselTrack.value, { | ||||
|           x: -totalWidth, | ||||
|           duration: 20, | ||||
|           ease: "none", | ||||
|           repeat: -1, | ||||
|           onRepeat: () => { | ||||
|             gsap.set(carouselTrack.value, { x: 0 }); | ||||
|           }, | ||||
|         }); | ||||
|       } | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| @ -816,11 +782,6 @@ const goToSection = (i) => { | ||||
|   bottom: -80px; | ||||
|   right: 0; | ||||
| } | ||||
| .carousel-container { | ||||
|   width: 96%; | ||||
|   overflow: hidden; | ||||
|   position: relative; | ||||
| } | ||||
| 
 | ||||
| .arrow-btn { | ||||
|   cursor: pointer; | ||||
| @ -838,18 +799,14 @@ const goToSection = (i) => { | ||||
| } | ||||
| 
 | ||||
| .carousel-item { | ||||
|   width: 785px; | ||||
|   margin-right: 73px; | ||||
|   flex: 0 0 auto; | ||||
|   display: block; // 改为 block 布局 | ||||
|   padding: 23px 20px 40px; | ||||
|   border-radius: 30px; | ||||
|   box-shadow: 0 8px 35px 3px rgba(0, 0, 0, 0.16); | ||||
|   margin-top: 154px; | ||||
|   padding: 46px 36px 118px 51px; | ||||
|   border-radius: 61px; | ||||
|   box-shadow: 0 15px 75px 5px rgba(0, 0, 0, 0.16); | ||||
| } | ||||
| 
 | ||||
| .carousel-image { | ||||
|   width: 748px; | ||||
|   height: 563px; | ||||
|   width: 1623px; | ||||
|   object-fit: cover; | ||||
|   display: block; | ||||
| } | ||||
| @ -860,19 +817,35 @@ const goToSection = (i) => { | ||||
| } | ||||
| 
 | ||||
| .carousel-title { | ||||
|   font-size: 50px; | ||||
|   text-align: left; | ||||
|   font-size: 92px; | ||||
|   font-weight: 500; | ||||
|   margin-top: 48px; | ||||
|   margin-top: 87px; | ||||
| } | ||||
| 
 | ||||
| .carousel-subtitle { | ||||
|   margin-top: 23px; | ||||
|   margin-top: 51px; | ||||
|   color: #455363; | ||||
|   font-size: 40px; | ||||
|   font-size: 72px; | ||||
| } | ||||
| 
 | ||||
| // 添加一个通用的溢出控制类 | ||||
| .overflow-hidden { | ||||
|   overflow: hidden; | ||||
| } | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 64px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   right: 60px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,5 +1,7 @@ | ||||
| <template> | ||||
|   <div class="page-container"> | ||||
|     <n-divider class="divider1" vertical /> | ||||
|     <n-divider class="divider5" vertical /> | ||||
|     <header className="header flex items-center justify-between"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
| @ -68,7 +70,7 @@ | ||||
|               moveRefs[3].value = el; | ||||
|             } | ||||
|           " | ||||
|           class="absolute bottom-[-290px] right-[0px]" | ||||
|           class="absolute bottom-[-290px] right-[0px] z-4" | ||||
|         > | ||||
|           <img | ||||
|             src="@/assets/image/businessintroduction/768/bg-2.png" | ||||
| @ -412,7 +414,7 @@ | ||||
|           </div> | ||||
|         </div> | ||||
| 
 | ||||
|         <div class="absolute bottom-[262px] right-[0px]"> | ||||
|         <div class="absolute bottom-[262px] right-[0px] z-4"> | ||||
|           <img | ||||
|             src="@/assets/image/businessintroduction/768/bg-5.png" | ||||
|             class="h-[361px]" | ||||
| @ -531,7 +533,7 @@ | ||||
|             </div> | ||||
|           </div> | ||||
|           <div | ||||
|             class="mt-[140px] mb-[175px] carousel-container px-[80px] py-[40px]" | ||||
|             class="mt-[140px] mb-[175px] carousel-container px-[80px] py-[40px] z-4" | ||||
|           > | ||||
|             <div ref="carouselTrack" class="carousel-track"> | ||||
|               <div | ||||
| @ -567,6 +569,7 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { NDivider } from "naive-ui"; | ||||
| import { onUnmounted, ref, onMounted, reactive, nextTick } from "vue"; | ||||
| import gsap from "gsap"; | ||||
| import { ScrollTrigger } from "gsap/ScrollTrigger"; | ||||
| @ -856,4 +859,21 @@ const goToSection = (i) => { | ||||
| .overflow-hidden { | ||||
|   overflow: hidden; | ||||
| } | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   color: #eff1f6; | ||||
|   left: 142px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   color: #eff1f6; | ||||
|   right: 142px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,5 +1,7 @@ | ||||
| <template> | ||||
|   <div class="page-container"> | ||||
|     <n-divider class="divider1" vertical /> | ||||
|     <n-divider class="divider5" vertical /> | ||||
|     <header className="header flex items-center justify-between"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
| @ -60,7 +62,7 @@ | ||||
|             src="@/assets/image/companyprofil/375/image-q.png" | ||||
|           /> | ||||
|         </div> | ||||
|         <div class="w-[1920px] absolute bottom-[-160px]"> | ||||
|         <div class="w-[1920px] absolute bottom-[-160px] z-4"> | ||||
|           <img | ||||
|             src="@/assets/image/companyprofil/375/icon-lang.png" | ||||
|             alt="logo" | ||||
| @ -204,7 +206,7 @@ | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <div class="icon-langmul"> | ||||
|           <div class="icon-langmul z-4"> | ||||
|             <img | ||||
|               class="w-[1205px]" | ||||
|               src="@/assets/image/companyprofil/375/icon-langmul.png" | ||||
| @ -415,6 +417,7 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { NDivider } from "naive-ui"; | ||||
| import { onUnmounted, ref, onMounted, reactive, nextTick } from "vue"; | ||||
| import gsap from "gsap"; | ||||
| import { ScrollTrigger } from "gsap/ScrollTrigger"; | ||||
| @ -884,4 +887,19 @@ const handleCarouselClick = (item, event) => { | ||||
| .overflow-hidden { | ||||
|   overflow: hidden; | ||||
| } | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 64px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   right: 60px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,5 +1,7 @@ | ||||
| <template> | ||||
|   <div class="page-container"> | ||||
|     <n-divider class="divider1" vertical /> | ||||
|     <n-divider class="divider5" vertical /> | ||||
|     <header className="header flex items-center justify-between"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
| @ -62,7 +64,7 @@ | ||||
|             /> | ||||
|           </div> | ||||
|         </div> | ||||
|         <div class="w-[1920px] absolute bottom-[-660px]"> | ||||
|         <div class="w-[1920px] absolute bottom-[-660px] z-4"> | ||||
|           <img | ||||
|             src="@/assets/image/companyprofil/768/icon-lang.png" | ||||
|             alt="logo" | ||||
| @ -161,7 +163,9 @@ | ||||
|               src="@/assets/image/companyprofil/768/icon-lun.png" | ||||
|             /> | ||||
| 
 | ||||
|             <div class="w-full mt-[50px] text-[#10253E] text-[45px]"> | ||||
|             <div | ||||
|               class="w-full mt-[50px] text-[#10253E] text-[45px] font-semibold" | ||||
|             > | ||||
|               纵横全球 多元领航 | ||||
|             </div> | ||||
|             <div class="mt-[38px] text-[#455363] text-[40px] w-[1345px]"> | ||||
| @ -175,7 +179,9 @@ | ||||
|               src="@/assets/image/companyprofil/768/icon-love.png" | ||||
|             /> | ||||
| 
 | ||||
|             <div class="w-full mt-[50px] text-[#10253E] text-[45px]"> | ||||
|             <div | ||||
|               class="w-full mt-[50px] text-[#10253E] text-[45px] font-semibold" | ||||
|             > | ||||
|               深耕粉丝 构筑生态 | ||||
|             </div> | ||||
|             <div class="mt-[38px] text-[#455363] text-[40px] w-[1345px]"> | ||||
| @ -188,7 +194,9 @@ | ||||
|               src="@/assets/image/companyprofil/768/icon-p.png" | ||||
|             /> | ||||
| 
 | ||||
|             <div class="w-full mt-[50px] text-[#10253E] text-[45px]"> | ||||
|             <div | ||||
|               class="w-full mt-[50px] text-[#10253E] text-[45px] font-semibold" | ||||
|             > | ||||
|               广纳贤才 团队进阶 | ||||
|             </div> | ||||
|             <div class="mt-[38px] text-[#455363] text-[40px] w-[1345px]"> | ||||
| @ -196,7 +204,7 @@ | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <div class="icon-langmul"> | ||||
|           <div class="icon-langmul z-4"> | ||||
|             <img | ||||
|               class="w-[846px] h-[216px]" | ||||
|               src="@/assets/image/companyprofil/768/icon-langmul.png" | ||||
| @ -355,7 +363,7 @@ | ||||
|             </div> | ||||
|           </div> | ||||
|           <div | ||||
|             class="mt-[73px] mb-[253px] carousel-container px-[80px] py-[40px]" | ||||
|             class="mt-[73px] mb-[253px] carousel-container px-[80px] py-[40px] z-4" | ||||
|           > | ||||
|             <div | ||||
|               ref="carouselTrack" | ||||
| @ -407,6 +415,7 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { NDivider } from "naive-ui"; | ||||
| import { onUnmounted, ref, onMounted, reactive, nextTick } from "vue"; | ||||
| import gsap from "gsap"; | ||||
| import { ScrollTrigger } from "gsap/ScrollTrigger"; | ||||
| @ -872,4 +881,21 @@ const handleCarouselClick = (item, event) => { | ||||
| .overflow-hidden { | ||||
|   overflow: hidden; | ||||
| } | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   color: #eff1f6; | ||||
|   left: 142px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   color: #eff1f6; | ||||
|   right: 142px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,5 +1,7 @@ | ||||
| <template> | ||||
|   <div class="page-container"> | ||||
|     <n-divider class="divider1" vertical /> | ||||
|     <n-divider class="divider5" vertical /> | ||||
|     <header className="header flex items-center justify-between"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
| @ -354,6 +356,7 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { NDivider } from "naive-ui"; | ||||
| import { | ||||
|   onUnmounted, | ||||
|   ref, | ||||
| @ -365,12 +368,12 @@ import { | ||||
| import { useHome } from "@/store/home/index.js"; | ||||
| import { useRoute, useRouter } from "vue-router"; | ||||
| 
 | ||||
| const router = useRouter(); | ||||
| const state = reactive({ | ||||
|   pageTitleNo: "", | ||||
| }); | ||||
| 
 | ||||
| const { currentTab } = useHome(); | ||||
| const router = useRouter(); | ||||
| const route = useRoute(); | ||||
| onBeforeMount(() => { | ||||
|   state.pageTitleNo = route.query.titleNo; | ||||
| @ -443,4 +446,19 @@ const handleTabClick = (tab) => { | ||||
|   text-indent: 2em; // Adjust the value as needed for the desired indent | ||||
|   line-height: 143px; | ||||
| } | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 64px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   right: 60px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,5 +1,7 @@ | ||||
| <template> | ||||
|   <div class="page-container"> | ||||
|     <n-divider class="divider1" vertical /> | ||||
|     <n-divider class="divider5" vertical /> | ||||
|     <header className="header flex items-center justify-between"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
| @ -354,6 +356,7 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { NDivider } from "naive-ui"; | ||||
| import { | ||||
|   onUnmounted, | ||||
|   ref, | ||||
| @ -363,18 +366,22 @@ import { | ||||
|   onBeforeMount, | ||||
| } from "vue"; | ||||
| import { useHome } from "@/store/home/index.js"; | ||||
| import { useRoute } from "vue-router"; | ||||
| const state = reactive({ | ||||
|   pageTitleNo: "", | ||||
| }); | ||||
| 
 | ||||
| const { currentTab } = useHome(); | ||||
| import { useRoute, useRouter } from "vue-router"; | ||||
| const router = useRouter(); | ||||
| const route = useRoute(); | ||||
| const { currentTab } = useHome(); | ||||
| onBeforeMount(() => { | ||||
|   state.pageTitleNo = route.query.titleNo; | ||||
| }); | ||||
| onMounted(() => {}); | ||||
| onUnmounted(() => {}); | ||||
| const handleTabClick = (tab) => { | ||||
|   currentTab.value = tab; | ||||
|   router.push("/" + tab); | ||||
| }; | ||||
| </script> | ||||
| 
 | ||||
| <style scoped lang="scss"> | ||||
| @ -436,4 +443,21 @@ onUnmounted(() => {}); | ||||
|   line-height: 110px; | ||||
|   color: #10253e; | ||||
| } | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   color: #eff1f6; | ||||
|   left: 116px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   color: #eff1f6; | ||||
|   right: 116px; | ||||
|   width: 1px; | ||||
|   height: 100%; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,5 +1,8 @@ | ||||
| <template> | ||||
|   <div class="page-container"> | ||||
|     <n-divider class="divider1" vertical /> | ||||
|     <div class="divider3"></div> | ||||
|     <n-divider class="divider5" vertical /> | ||||
|     <header className="header flex items-center justify-between"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
| @ -47,11 +50,6 @@ | ||||
|         className="panel" | ||||
|         style="background-color: rgba(248, 249, 255, 1)" | ||||
|       > | ||||
|         <n-divider class="divider1" vertical /> | ||||
|         <div class="divider2" style=""></div> | ||||
|         <div class="divider3" style=""></div> | ||||
|         <div class="divider4" style=""></div> | ||||
|         <n-divider class="divider5" vertical /> | ||||
|         <div class="parallax-bg" style="margin-top: 210px"> | ||||
|           <img | ||||
|             ref="secondImage" | ||||
| @ -70,11 +68,6 @@ | ||||
|       </section> | ||||
| 
 | ||||
|       <section className="panel" style="background-color: #fff"> | ||||
|         <n-divider class="divider1" vertical /> | ||||
|         <div class="divider2" style=""></div> | ||||
|         <div class="divider3" style=""></div> | ||||
|         <div class="divider4" style=""></div> | ||||
|         <n-divider class="divider5" vertical /> | ||||
|         <div class="parallax-bg" style="margin-top: 70px"></div> | ||||
|         <div class="content3 mt-[348px]"> | ||||
|           <div class="text-[#8B59F7] text-[40px]"> | ||||
| @ -86,7 +79,7 @@ | ||||
|           </div> | ||||
|           <n-marquee auto-fill> | ||||
|             <div style="display: flex" class="mt-[190px]"> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px]"> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px] w-[500px]"> | ||||
|                 <img | ||||
|                   class="w-[475px] h-[475px]" | ||||
|                   src="@/assets/image/jj1.png" | ||||
| @ -104,7 +97,7 @@ | ||||
|                   {{ t("home.section3.features.data.desc") }} | ||||
|                 </div> | ||||
|               </div> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px]"> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px] w-[500px]"> | ||||
|                 <img | ||||
|                   class="w-[475px] h-[475px]" | ||||
|                   src="@/assets/image/jj2.png" | ||||
| @ -122,7 +115,7 @@ | ||||
|                   {{ t("home.section3.features.ai.desc") }} | ||||
|                 </div> | ||||
|               </div> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px]"> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px] w-[500px]"> | ||||
|                 <img | ||||
|                   class="w-[475px] h-[475px]" | ||||
|                   src="@/assets/image/jj3.png" | ||||
| @ -140,7 +133,7 @@ | ||||
|                   {{ t("home.section3.features.cloud.desc") }} | ||||
|                 </div> | ||||
|               </div> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px]"> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px] w-[500px]"> | ||||
|                 <img | ||||
|                   class="w-[475px] h-[475px]" | ||||
|                   src="@/assets/image/jj4.png" | ||||
| @ -158,7 +151,7 @@ | ||||
|                   {{ t("home.section3.features.cooperation.desc") }} | ||||
|                 </div> | ||||
|               </div> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px]"> | ||||
|               <div class="text-[#455363] text-[40px] mr-[83px] w-[500px]"> | ||||
|                 <img | ||||
|                   class="w-[475px] h-[475px]" | ||||
|                   src="@/assets/image/jj5.png" | ||||
| @ -182,11 +175,6 @@ | ||||
|       </section> | ||||
| 
 | ||||
|       <section className="panel" style="background-color: #f8f9ff"> | ||||
|         <n-divider class="divider1" vertical /> | ||||
|         <div class="divider2" style=""></div> | ||||
|         <div class="divider3" style=""></div> | ||||
|         <div class="divider4" style=""></div> | ||||
|         <n-divider class="divider5" vertical /> | ||||
|         <div class="parallax-bg" style="height: 100% !important"></div> | ||||
|         <div class="content4 mt-[408px]"> | ||||
|           <div class="text-[#8B59F7] text-[40px]"> | ||||
| @ -1058,7 +1046,7 @@ watch( | ||||
| 
 | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   z-index: 9; | ||||
|   left: 22px; | ||||
|   width: 4px; | ||||
|   height: 100%; | ||||
| @ -1066,7 +1054,7 @@ watch( | ||||
| 
 | ||||
| .divider3 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   z-index: 9; | ||||
|   left: 400px; | ||||
|   height: 100%; | ||||
|   background-image: linear-gradient(to bottom, #e6eaee 50%, transparent 50%); | ||||
| @ -1076,7 +1064,7 @@ watch( | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   z-index: 9; | ||||
|   right: 22px; | ||||
|   height: 100%; | ||||
| } | ||||
| @ -1207,16 +1195,6 @@ watch( | ||||
|   pointer-events: none; | ||||
| } | ||||
| 
 | ||||
| .divider3, | ||||
| .divider4 { | ||||
|   :deep(.n-divider) { | ||||
|     border-left: none; | ||||
|     background-image: linear-gradient(to bottom, #e6eaee 50%, transparent 50%); | ||||
|     background-size: 10px 60px; | ||||
|     background-repeat: repeat-y; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .container { | ||||
|   display: grid; | ||||
|   grid-template-columns: repeat(2, 1fr); | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user