Compare commits
	
		
			No commits in common. "3a0d06de015c63a9c93334c7991e3ed887480f68" and "9900462ffa5f81191200005560f7b6925d39a153" have entirely different histories.
		
	
	
		
			3a0d06de01
			...
			9900462ffa
		
	
		
							
								
								
									
										50
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										50
									
								
								README.md
									
									
									
									
									
								
							| @ -1,49 +1,5 @@ | ||||
| # Project Name | ||||
| # Vue 3 + Vite | ||||
| 
 | ||||
| 基于 Vue 3 的多语言响应式网站应用 | ||||
| This template should help get you started developing with Vue 3 in Vite. The template uses Vue 3 `<script setup>` SFCs, check out the [script setup docs](https://v3.vuejs.org/api/sfc-script-setup.html#sfc-script-setup) to learn more. | ||||
| 
 | ||||
| ## 功能特点 | ||||
| 
 | ||||
| - 🌐 多语言支持 (英语 & 日语) | ||||
| - 📱 响应式布局 (1440px & 1920px) | ||||
| - 🎨 Naive UI 组件库集成 | ||||
| - 📦 基于 Vite 的现代构建系统 | ||||
| 
 | ||||
| ## 技术栈 | ||||
| 
 | ||||
| - Vue 3 | ||||
| - Naive UI | ||||
| - Vue Router | ||||
| - i18n | ||||
| - Vite | ||||
| 
 | ||||
| ## 项目结构 | ||||
| 
 | ||||
| ## 开发指南 | ||||
| 
 | ||||
| ### 环境要求 | ||||
| 
 | ||||
| - Node.js >= 16 | ||||
| - pnpm >= 8 | ||||
| 
 | ||||
| ### 安装依赖 | ||||
| 
 | ||||
| ```bash | ||||
| pnpm install | ||||
| ``` | ||||
| 
 | ||||
| ### 运行项目 | ||||
| 
 | ||||
| ```bash | ||||
| pnpm run prod | ||||
| ``` | ||||
| 
 | ||||
| ### 构建项目 | ||||
| 
 | ||||
| ```bash | ||||
| pnpm run build-prod | ||||
| ``` | ||||
| 
 | ||||
| ### 部署项目 | ||||
| 
 | ||||
| ```bash | ||||
| Learn more about IDE Support for Vue in the [Vue Docs Scaling up Guide](https://vuejs.org/guide/scaling-up/tooling.html#ide-support). | ||||
|  | ||||
| @ -55,7 +55,7 @@ const handleLanguageChange = (key) => { | ||||
|         {{ languageOptions.find(opt => opt.key === locale)?.label }} | ||||
|       </div> | ||||
|     </n-dropdown> --> | ||||
|     <!-- <AppHeader /> --> | ||||
|     <AppHeader /> | ||||
|     <router-view /> | ||||
|   </n-config-provider> | ||||
| </template> | ||||
|  | ||||
| @ -31,5 +31,47 @@ const handleTabClick = (tab) => { | ||||
| } | ||||
| </script> | ||||
| <style scoped lang="scss"> | ||||
| .header { | ||||
|   width: 100%; | ||||
|   height: 55px; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   align-items: flex-end; | ||||
|   position: fixed; | ||||
|   z-index: 10; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   right: 0; | ||||
|   padding: 0 14rem; | ||||
|   background-color: transparent; | ||||
| } | ||||
| 
 | ||||
| .logo { | ||||
|   img { | ||||
|     width: 108px; | ||||
|     height: 33px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .tabs { | ||||
|   display: flex; | ||||
|   gap: 32px; | ||||
|   margin-right: 32px; | ||||
| } | ||||
| 
 | ||||
| .tab-item { | ||||
|   font-size: 16px; | ||||
|   color: #000000; | ||||
|   cursor: pointer; | ||||
|   transition: color 0.3s ease; | ||||
|   padding: 4px 8px; | ||||
| 
 | ||||
|   &.active { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| 
 | ||||
|   &:hover { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,60 +1,35 @@ | ||||
| <script setup> | ||||
| import { onUnmounted, ref, watch } from 'vue'; | ||||
| import gsap from 'gsap'; | ||||
| import ScrollTrigger from 'gsap/ScrollTrigger'; | ||||
| import { useHome } from '@/store/home/index.js'; | ||||
| 
 | ||||
| import { useI18n } from 'vue-i18n'; | ||||
| import { useTransitionComposable } from '@/composables/transition-composable'; | ||||
| import { useRouter } from "vue-router"; | ||||
| import { NDivider } from 'naive-ui' | ||||
| 
 | ||||
| // 注册 ScrollTrigger 插件 | ||||
| gsap.registerPlugin(ScrollTrigger); | ||||
| const { currentTab } = useHome(); | ||||
| const router = useRouter(); | ||||
| const { transitionState } = useTransitionComposable(); | ||||
| const main = ref(); | ||||
| let ctx; | ||||
| const { t } = useI18n(); | ||||
| const handleTabClick = (tab) => { | ||||
|   currentTab.value = tab; | ||||
|   router.push('/' + tab); | ||||
| } | ||||
| 
 | ||||
| watch( | ||||
|   [() => transitionState.transitionComplete, main], | ||||
|   (newValue) => { | ||||
|     if (newValue && main.value) { | ||||
|       ctx = gsap.context((self) => { | ||||
|         // Text animations from left | ||||
|         gsap.utils.toArray('.text-animate').forEach(text => { | ||||
|           gsap.from(text, { | ||||
|             x: -100, | ||||
|             opacity: 0, | ||||
|             duration: 1, | ||||
|         const boxes = self.selector('.box'); | ||||
|         boxes.forEach((box) => { | ||||
|           gsap.to(box, { | ||||
|             x: 150, | ||||
|             scrollTrigger: { | ||||
|               trigger: text, | ||||
|               start: 'top 80%', | ||||
|               end: 'top 50%', | ||||
|               toggleActions: 'play none none reverse', | ||||
|             } | ||||
|               trigger: box, | ||||
|               start: 'bottom bottom', | ||||
|               end: 'top 20%', | ||||
|               scrub: true, | ||||
|             }, | ||||
|           }); | ||||
|         }); | ||||
| 
 | ||||
|         // Image animations from right | ||||
|         gsap.utils.toArray('.image-animate').forEach(image => { | ||||
|           gsap.from(image, { | ||||
|             x: 100, | ||||
|             opacity: 0, | ||||
|             duration: 1, | ||||
|             scrollTrigger: { | ||||
|               trigger: image, | ||||
|               start: 'top 80%', | ||||
|               end: 'top 50%', | ||||
|               toggleActions: 'play none none reverse', | ||||
|             } | ||||
|           }); | ||||
|         }); | ||||
|       }, main.value); | ||||
|       }, main.value); // <- Scope! | ||||
|     } | ||||
|   }, | ||||
|   { | ||||
| @ -68,35 +43,19 @@ onUnmounted(() => { | ||||
| </script> | ||||
| 
 | ||||
| <template> | ||||
|    <header className="header"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
|       </div> | ||||
|       <div class="tabs"> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'home' }" @click="handleTabClick('home')"> | ||||
|           {{ t('home.nav.home') }} | ||||
|         </div> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'companyprofil' }" @click="handleTabClick('companyprofil')"> | ||||
|           {{ t('home.nav.company') }} | ||||
|         </div> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'business' }" @click="handleTabClick('business')"> | ||||
|           {{ t('home.nav.business') }} | ||||
|         </div> | ||||
|       </div> | ||||
|     </header> | ||||
|   <main ref="main"> | ||||
|   <main> | ||||
| 
 | ||||
|     <div class="head relative"> | ||||
| 
 | ||||
|       <img src="@/assets/image/gk.png" alt="head"> | ||||
| 
 | ||||
|       <div class="absolute top-240px left-510px text-[#10253E] text-[54px] font-bold text-animate"> | ||||
|       <div class="absolute top-240px left-510px text-[#10253E] text-[54px] font-bold"> | ||||
|         领航文艺全周期 | ||||
|       </div> | ||||
|       <div class="absolute top-320px left-510px text-[#10253E] text-[54px] font-bold text-animate"> | ||||
|       <div class="absolute top-320px left-510px text-[#10253E] text-[54px] font-bold"> | ||||
|         创变价值新巅峰 | ||||
|       </div> | ||||
|       <div class="absolute top-420px left-510px text-[#8B59F7] text-[20px] w-[535px] text-animate"> | ||||
|       <div class="absolute top-420px left-510px text-[#8B59F7] text-[20px] w-[535px] "> | ||||
|         FiEE立志成为文艺创作全周期的掌舵人,深度参与从灵感初绽、作品打磨完成,到市场推广宣传、文化广泛传播的每一处关键节点 | ||||
|       </div> | ||||
| 
 | ||||
| @ -109,30 +68,30 @@ onUnmounted(() => { | ||||
|     <div class="bg-[#F8F9FF] "> | ||||
| 
 | ||||
|       <div class="content1 relative flex items-center justify-center z-3 pb-[100px] flex-col"> | ||||
|         <div class="text-[#8B59F7] text-[16px] absolute top-[-30px] left-[505px] text-animate">公司介绍</div> | ||||
|         <div class="text-[#8B59F7] text-[16px] absolute top-[-30px] left-[505px]">公司介绍</div> | ||||
|         <div class="pl-[505px] pr-[480px] flex"> | ||||
| 
 | ||||
|           <div class="w-[411px] mr-[38px] text-animate"> | ||||
|           <div class="w-[411px] mr-[38px]"> | ||||
|             <div class="text-[#10253E] text-[40px]">独树一帜 | ||||
| 
 | ||||
|             </div> | ||||
|             <div class="text-[#10253E] text-[40px]">全周期价值赋能领航者</div> | ||||
|             <div class="text-[#455363] text-[16px] mt-[56px]"> | ||||
|               FiEE彻底打破传统单一服务机构的局限,以行业变革者的姿态,深度融合前沿技术与丰富多元的资源,精心构建起一套贯穿文艺创作从萌芽构思到辉煌绽放全流程的 "全周期" 价值赋能体系。 | ||||
|               FiEE彻底打破传统单一服务机构的局限,以行业变革者的姿态,深度融合前沿技术与丰富多元的资源,精心构建起一套贯穿文艺创作从萌芽构思到辉煌绽放全流程的 “全周期” 价值赋能体系。 | ||||
|               无论你是刚刚踏入文艺殿堂、怀揣梦想的创作新人,还是在文艺道路上摸爬滚打、渴望突破创作瓶颈、攀登更高文艺巅峰的成熟文艺工作者,FiEE都将成为你最坚实的伙伴,一路贴心陪伴,为你的文艺征途遮风挡雨,指引前行的方向。 | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <div class="text-[#10253E] text-[20px] image-animate"> | ||||
|           <div class="text-[#10253E] text-[20px]"> | ||||
|             <img class="w-[465px] h-[415px]" src="@/assets/image/ship.png" alt="company"> | ||||
|           </div> | ||||
| 
 | ||||
|         </div> | ||||
|       </div> | ||||
|       <div class="content2 relative flex items-center justify-center pt-[168px]  bg-[#fff]"> | ||||
|         <div class="text-[#8B59F7] text-[16px] absolute top-[129px] left-[505px] text-animate">团队介绍</div> | ||||
|         <div class="text-[#8B59F7] text-[16px] absolute top-[129px] left-[505px]">公司介绍</div> | ||||
|         <div class="pl-[505px] pr-[490px] flex z-3"> | ||||
|           <div class="w-[412px] mr-[40px] text-animate"> | ||||
|           <div class="w-[412px] mr-[40px]"> | ||||
|             <div class="text-[#10253E] text-[40px]">汇聚精英</div> | ||||
|             <div class="text-[#10253E] text-[40px]">燃文艺创变引擎</div> | ||||
|             <div class="mt-[93px]"> | ||||
| @ -159,7 +118,7 @@ onUnmounted(() => { | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <div class="text-[#455363] text-[16px] flex-1 image-animate"> | ||||
|           <div class="text-[#455363] text-[16px] flex-1"> | ||||
|             <div> | ||||
|               FiEE团队由运营专家、技术精英及国际顾问组成,提供从内容策划到全球推广的全方位支持。通过跨界合作与资源整合,FiEE突破传统边界,探索文艺新表达。依托前沿技术与精准营销,助力作品实现商业价值与社会影响力的双重提升,为文艺繁荣注入持久动力。 | ||||
|             </div> | ||||
| @ -170,74 +129,23 @@ onUnmounted(() => { | ||||
|       </div> | ||||
|       <div class="content3 relative bg-[#fff] pt-[185px]"> | ||||
|         <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="divider2" style=""></div> | ||||
|     <div class="divider3" style=""></div> | ||||
|     <div class="divider4" style=""></div> | ||||
|     <n-divider class="divider5" vertical /> | ||||
|         <img class="absolute top-[95px] z-3 w-[800px] h-[163px] right-[0px]" src="@/assets/image/xlv.png" alt="cl"> | ||||
|         <img class="absolute" src="@/assets/image/xbg.png" alt="cl">  | ||||
|         <div class="relative pl-[505px] pr-[490px] flex z-3 mt-[300px] z-4 flex-col text-animate"> | ||||
|         <div class="relative pl-[505px] pr-[490px] flex z-3 mt-[300px] z-4 flex-col"> | ||||
|           <div class="text-[#8B59F7] text-[16px]">卓越建树</div> | ||||
|           <div class="text-[#10253E] text-[40px]">以开拓之姿,登文艺之巅</div> | ||||
|           <div class="text-[#455363] w-[748px] text-[16px] mt-[30px]"> | ||||
|             长期深耕文艺领域,FiEE持续拓展业务版图,积累了深厚的行业资源,搭建起广泛的合作网络。目前已与多个全球热门自媒体平台深度携手,从多维度助力文艺创作者闪耀国际舞台,绽放独有的艺术光芒。</div> | ||||
|           <div class="text-[#455363] w-[748px] text-[16px]">长期深耕文艺领域,FiEE持续拓展业务版图,积累了深厚的行业资源,搭建起广泛的合作网络。目前已与多个全球热门自媒体平台深度携手,从多维度助力文艺创作者闪耀国际舞台,绽放独有的艺术光芒。</div> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
| 
 | ||||
|   </main> | ||||
|   <footer> | ||||
|     <div class="footer-content"> | ||||
|       <img class="copyright" src="@/assets/image/cp.png" alt="logo" /> | ||||
| 
 | ||||
| 
 | ||||
|     </div> | ||||
|   </footer> | ||||
| </template> | ||||
| <style lang="scss" scoped> | ||||
| .header { | ||||
|   width: 100%; | ||||
|   height: 55px; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   align-items: flex-end; | ||||
|   position: fixed; | ||||
|   z-index: 10; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   right: 0; | ||||
|   padding: 0 14rem; | ||||
|   background-color: transparent; | ||||
| } | ||||
| 
 | ||||
| .logo { | ||||
|   img { | ||||
|     width: 108px; | ||||
|     height: 33px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .tabs { | ||||
|   display: flex; | ||||
|   gap: 32px; | ||||
|   margin-right: 32px; | ||||
| } | ||||
| 
 | ||||
| .tab-item { | ||||
|   font-size: 16px; | ||||
|   color: #000000; | ||||
|   cursor: pointer; | ||||
|   transition: color 0.3s ease; | ||||
|   padding: 4px 8px; | ||||
| 
 | ||||
|   &.active { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| 
 | ||||
|   &:hover { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| } | ||||
| .head { | ||||
|   width: 100%; | ||||
|   background-color: #F8F9FF; | ||||
| @ -305,15 +213,4 @@ onUnmounted(() => { | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
| } | ||||
| .footer-content { | ||||
|   height: 90px; | ||||
|   display: flex; | ||||
|   justify-content: center; | ||||
|   align-items: center; | ||||
| 
 | ||||
|   .copyright { | ||||
|     width: 232px; | ||||
|     height: 22pxpx; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -6,9 +6,7 @@ import { ScrollTrigger } from 'gsap/ScrollTrigger'; | ||||
| import { useHome } from '@/store/home/index.js'; | ||||
| import { useTransitionComposable } from '@/composables/transition-composable'; | ||||
| import { useI18n } from 'vue-i18n'; | ||||
| import { useRouter } from "vue-router"; | ||||
| 
 | ||||
| const router = useRouter(); | ||||
| const { transitionState } = useTransitionComposable(); | ||||
| const main = ref(); | ||||
| const secondImage = ref(null); | ||||
| @ -23,7 +21,6 @@ const { t } = useI18n(); | ||||
| 
 | ||||
| const handleTabClick = (tab) => { | ||||
|   currentTab.value = tab; | ||||
|   router.push('/' + tab); | ||||
| } | ||||
| 
 | ||||
| const goToSection = (i) => { | ||||
| @ -370,35 +367,35 @@ watch( | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|             }) | ||||
|               .to(".content4 > div:nth-child(2)", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.4") | ||||
|               .to(".content4 > div:nth-child(3)", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.4") | ||||
|               // 卡片动画 | ||||
|               .to(".content4 .container > div:first-child .card:first-child", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 duration: 0.8 | ||||
|               }, "-=0.2") | ||||
|               .to(".content4 .container > .right .card:first-child", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 duration: 0.8 | ||||
|               }, "-=0.6") | ||||
|               .to(".content4 .container > div:first-child .card:last-child", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 duration: 0.8 | ||||
|               }, "-=0.6") | ||||
|               .to(".content4 .container > .right .card:last-child", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 duration: 0.8 | ||||
|               }, "-=0.6"); | ||||
|             .to(".content4 > div:nth-child(2)", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|             }, "-=0.4") | ||||
|             .to(".content4 > div:nth-child(3)", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|             }, "-=0.4") | ||||
|             // 卡片动画 | ||||
|             .to(".content4 .container > div:first-child .card:first-child", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               duration: 0.8 | ||||
|             }, "-=0.2") | ||||
|             .to(".content4 .container > .right .card:first-child", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               duration: 0.8 | ||||
|             }, "-=0.6") | ||||
|             .to(".content4 .container > div:first-child .card:last-child", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               duration: 0.8 | ||||
|             }, "-=0.6") | ||||
|             .to(".content4 .container > .right .card:last-child", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               duration: 0.8 | ||||
|             }, "-=0.6"); | ||||
|           }, | ||||
|           onLeave: () => { | ||||
|             // 离开第四幕时显示 | ||||
| @ -409,23 +406,23 @@ watch( | ||||
|                 ease: "power2.in" | ||||
|               } | ||||
|             }) | ||||
|               .to(".content4 .container .card", { | ||||
|                 opacity: 0, | ||||
|                 y: -30, | ||||
|                 stagger: { | ||||
|                   each: 0.1, | ||||
|                   from: "end" | ||||
|                 } | ||||
|               }) | ||||
|               .to([ | ||||
|                 ".content4 > div:nth-child(3)", | ||||
|                 ".content4 > div:nth-child(2)", | ||||
|                 ".content4 > div:nth-child(1)" | ||||
|               ], { | ||||
|                 opacity: 0, | ||||
|                 y: -30, | ||||
|                 stagger: 0.1 | ||||
|               }, "-=0.3"); | ||||
|             .to(".content4 .container .card", { | ||||
|               opacity: 0, | ||||
|               y: -30, | ||||
|               stagger: { | ||||
|                 each: 0.1, | ||||
|                 from: "end" | ||||
|               } | ||||
|             }) | ||||
|             .to([ | ||||
|               ".content4 > div:nth-child(3)", | ||||
|               ".content4 > div:nth-child(2)", | ||||
|               ".content4 > div:nth-child(1)" | ||||
|             ], { | ||||
|               opacity: 0, | ||||
|               y: -30, | ||||
|               stagger: 0.1 | ||||
|             }, "-=0.3"); | ||||
|           }, | ||||
|           onEnterBack: () => { | ||||
|             // 返回第四幕时隐藏 | ||||
| @ -463,34 +460,34 @@ watch( | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|             }) | ||||
|               .to(".content4 > div:nth-child(2)", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.4") | ||||
|               .to(".content4 > div:nth-child(3)", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.4") | ||||
|               .to(".content4 .container > div:first-child .card:first-child", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 duration: 0.8 | ||||
|               }, "-=0.2") | ||||
|               .to(".content4 .container > .right .card:first-child", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 duration: 0.8 | ||||
|               }, "-=0.6") | ||||
|               .to(".content4 .container > div:first-child .card:last-child", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 duration: 0.8 | ||||
|               }, "-=0.6") | ||||
|               .to(".content4 .container > .right .card:last-child", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 duration: 0.8 | ||||
|               }, "-=0.6"); | ||||
|             .to(".content4 > div:nth-child(2)", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|             }, "-=0.4") | ||||
|             .to(".content4 > div:nth-child(3)", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|             }, "-=0.4") | ||||
|             .to(".content4 .container > div:first-child .card:first-child", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               duration: 0.8 | ||||
|             }, "-=0.2") | ||||
|             .to(".content4 .container > .right .card:first-child", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               duration: 0.8 | ||||
|             }, "-=0.6") | ||||
|             .to(".content4 .container > div:first-child .card:last-child", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               duration: 0.8 | ||||
|             }, "-=0.6") | ||||
|             .to(".content4 .container > .right .card:last-child", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               duration: 0.8 | ||||
|             }, "-=0.6"); | ||||
|           }, | ||||
|           onLeaveBack: () => { | ||||
|             // 向上离开第四幕时显示 | ||||
| @ -501,23 +498,23 @@ watch( | ||||
|                 ease: "power2.in" | ||||
|               } | ||||
|             }) | ||||
|               .to(".content4 .container .card", { | ||||
|                 opacity: 0, | ||||
|                 y: 30, | ||||
|                 stagger: { | ||||
|                   each: 0.1, | ||||
|                   from: "end" | ||||
|                 } | ||||
|               }) | ||||
|               .to([ | ||||
|                 ".content4 > div:nth-child(3)", | ||||
|                 ".content4 > div:nth-child(2)", | ||||
|                 ".content4 > div:nth-child(1)" | ||||
|               ], { | ||||
|                 opacity: 0, | ||||
|                 y: 30, | ||||
|                 stagger: 0.1 | ||||
|               }, "-=0.3"); | ||||
|             .to(".content4 .container .card", { | ||||
|               opacity: 0, | ||||
|               y: 30, | ||||
|               stagger: { | ||||
|                 each: 0.1, | ||||
|                 from: "end" | ||||
|               } | ||||
|             }) | ||||
|             .to([ | ||||
|               ".content4 > div:nth-child(3)", | ||||
|               ".content4 > div:nth-child(2)", | ||||
|               ".content4 > div:nth-child(1)" | ||||
|             ], { | ||||
|               opacity: 0, | ||||
|               y: 30, | ||||
|               stagger: 0.1 | ||||
|             }, "-=0.3"); | ||||
|           } | ||||
|         }); | ||||
|       }, main.value); | ||||
| @ -528,24 +525,8 @@ watch( | ||||
| </script> | ||||
| 
 | ||||
| <template> | ||||
|    <header className="header"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
|       </div> | ||||
|       <div class="tabs"> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'home' }" @click="handleTabClick('home')"> | ||||
|           {{ t('home.nav.home') }} | ||||
|         </div> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'companyprofil' }" @click="handleTabClick('companyprofil')"> | ||||
|           {{ t('home.nav.company') }} | ||||
|         </div> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'business' }" @click="handleTabClick('business')"> | ||||
|           {{ t('home.nav.business') }} | ||||
|         </div> | ||||
|       </div> | ||||
|     </header> | ||||
|   <main ref="main"> | ||||
|     <div class="scroll-down" :class="{ hide: !scrollDownVisible }">{{ t('home.scroll.tip') }}</div> | ||||
|    <div class="scroll-down" :class="{ hide: !scrollDownVisible }">{{ t('home.scroll.tip') }}</div> | ||||
|     <section className="panel first-panel"> | ||||
| 
 | ||||
|       <n-carousel autoplay :interval="5000" class="no-hover"> | ||||
| @ -597,8 +578,7 @@ watch( | ||||
|             <div class="text-[#455363] text-[16px]  mt-[31px] mr-[30px]"> | ||||
|               <img class="w-[180px] h-[180px]" src="@/assets/image/jj1.png" alt="logo" /> | ||||
|               <div class="line"></div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ | ||||
|                 t('home.section3.features.data.title') }}</div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ t('home.section3.features.data.title') }}</div> | ||||
|               <div class="text-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.data.desc') }} | ||||
|               </div> | ||||
| @ -606,8 +586,7 @@ watch( | ||||
|             <div class="text-[#455363] text-[16px]  mt-[31px]  mr-[30px]"> | ||||
|               <img class="w-[180px] h-[180px]" src="@/assets/image/jj2.png" alt="logo" /> | ||||
|               <div class="line"></div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ t('home.section3.features.ai.title') | ||||
|                 }}</div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ t('home.section3.features.ai.title') }}</div> | ||||
|               <div class="text-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.ai.desc') }} | ||||
|               </div> | ||||
| @ -615,8 +594,7 @@ watch( | ||||
|             <div class="text-[#455363] text-[16px]  mt-[31px]  mr-[30px]"> | ||||
|               <img class="w-[180px] h-[180px]" src="@/assets/image/jj3.png" alt="logo" /> | ||||
|               <div class="line"></div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ | ||||
|                 t('home.section3.features.cloud.title') }}</div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ t('home.section3.features.cloud.title') }}</div> | ||||
|               <div class="text-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.cloud.desc') }} | ||||
|               </div> | ||||
| @ -624,8 +602,7 @@ watch( | ||||
|             <div class="text-[#455363] text-[16px]  mt-[31px]  mr-[30px]"> | ||||
|               <img class="w-[180px] h-[180px]" src="@/assets/image/jj4.png" alt="logo" /> | ||||
|               <div class="line"></div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ | ||||
|                 t('home.section3.features.cooperation.title') }}</div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ t('home.section3.features.cooperation.title') }}</div> | ||||
|               <div class="text-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.cooperation.desc') }} | ||||
|               </div> | ||||
| @ -633,8 +610,7 @@ watch( | ||||
|             <div class="text-[#455363] text-[16px]  mt-[31px]  mr-[30px]"> | ||||
|               <img class="w-[180px] h-[180px]" src="@/assets/image/jj5.png" alt="logo" /> | ||||
|               <div class="line "></div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ | ||||
|                 t('home.section3.features.promotion.title') }}</div> | ||||
|               <div class="text-[#10253E] text-[20px] max-w-[200px] break-words">{{ t('home.section3.features.promotion.title') }}</div> | ||||
|               <div class="text-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.promotion.desc') }} | ||||
|               </div> | ||||
| @ -715,49 +691,6 @@ watch( | ||||
| </template> | ||||
| 
 | ||||
| <style scoped lang="scss"> | ||||
| .header { | ||||
|   width: 100%; | ||||
|   height: 55px; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   align-items: flex-end; | ||||
|   position: fixed; | ||||
|   z-index: 10; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   right: 0; | ||||
|   padding: 0 14rem; | ||||
|   background-color: transparent; | ||||
| } | ||||
| 
 | ||||
| .logo { | ||||
|   img { | ||||
|     width: 108px; | ||||
|     height: 33px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .tabs { | ||||
|   display: flex; | ||||
|   gap: 32px; | ||||
|   margin-right: 32px; | ||||
| } | ||||
| 
 | ||||
| .tab-item { | ||||
|   font-size: 16px; | ||||
|   color: #000000; | ||||
|   cursor: pointer; | ||||
|   transition: color 0.3s ease; | ||||
|   padding: 4px 8px; | ||||
| 
 | ||||
|   &.active { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| 
 | ||||
|   &:hover { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| } | ||||
| .scroll-down { | ||||
|   position: fixed; | ||||
|   bottom: 50px; | ||||
| @ -775,12 +708,11 @@ watch( | ||||
|   animation: float 2s ease-in-out infinite; | ||||
|   opacity: 1; | ||||
|   transition: opacity 0.3s ease; | ||||
|   min-width: 122px; | ||||
|   height: 38px; | ||||
|   display: flex; | ||||
|   justify-content: center; | ||||
|   align-items: center; | ||||
| 
 | ||||
| min-width: 122px; | ||||
| height: 38px; | ||||
| display: flex; | ||||
| justify-content: center; | ||||
| align-items: center; | ||||
|   &.hide { | ||||
|     opacity: 0; | ||||
|     pointer-events: none; | ||||
| @ -788,25 +720,20 @@ watch( | ||||
| } | ||||
| 
 | ||||
| @keyframes float { | ||||
| 
 | ||||
|   0%, | ||||
|   100% { | ||||
|   0%, 100% { | ||||
|     transform: translate(-50%, 0); | ||||
|   } | ||||
| 
 | ||||
|   50% { | ||||
|     transform: translate(-50%, -10px); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| :deep .n-carousel__dot { | ||||
| :deep .n-carousel__dot{ | ||||
|   background-color: #DDDDDD !important; | ||||
| } | ||||
| 
 | ||||
| :deep .n-carousel__dot--active { | ||||
| :deep .n-carousel__dot--active{ | ||||
|   background-color: #8B59F7 !important; | ||||
| } | ||||
| 
 | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
| @ -870,7 +797,49 @@ watch( | ||||
|   -moz-osx-font-smoothing: grayscale; | ||||
| } | ||||
| 
 | ||||
| .header { | ||||
|   width: 100%; | ||||
|   height: 55px; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   align-items: flex-end; | ||||
|   position: fixed; | ||||
|   z-index: 10; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   right: 0; | ||||
|   padding: 0 10rem; | ||||
|   background-color: transparent; | ||||
| } | ||||
| 
 | ||||
| .logo { | ||||
|   img { | ||||
|     width: 108px; | ||||
|     height: 33px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .tabs { | ||||
|   display: flex; | ||||
|   gap: 32px; | ||||
|   margin-right: 32px; | ||||
| } | ||||
| 
 | ||||
| .tab-item { | ||||
|   font-size: 16px; | ||||
|   color: #000000; | ||||
|   cursor: pointer; | ||||
|   transition: color 0.3s ease; | ||||
|   padding: 4px 8px; | ||||
| 
 | ||||
|   &.active { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| 
 | ||||
|   &:hover { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .panel { | ||||
|   height: 100vh; | ||||
| @ -1032,14 +1001,12 @@ watch( | ||||
|   width: 100%; | ||||
|   padding: 0 23px; | ||||
| } | ||||
| 
 | ||||
| .footer-content { | ||||
| .footer-content{ | ||||
|   height: 90px; | ||||
|   display: flex; | ||||
|   justify-content: center; | ||||
|   align-items: center; | ||||
| 
 | ||||
|   .copyright { | ||||
|   .copyright{ | ||||
|     width: 232px; | ||||
|     height: 22pxpx; | ||||
|   } | ||||
|  | ||||
| @ -21,8 +21,6 @@ let lastScrollTime = 0;  // 添加最后滚动时间记录 | ||||
| const scrollDownVisible = ref(true); | ||||
| const { t } = useI18n(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| const handleTabClick = (tab) => { | ||||
|   currentTab.value = tab; | ||||
|   router.push('/' + tab); | ||||
| @ -92,7 +90,6 @@ const handleWheel = (e) => { | ||||
| 
 | ||||
| // 监听滚轮事件 | ||||
| onMounted(() => { | ||||
|   window.scrollTo(0, 0); | ||||
|   window.addEventListener('wheel', handleWheel, { passive: false }); | ||||
| }); | ||||
| 
 | ||||
| @ -531,22 +528,7 @@ watch( | ||||
| </script> | ||||
| 
 | ||||
| <template> | ||||
|    <header className="header"> | ||||
|       <div class="logo"> | ||||
|         <img src="@/assets/image/logo.png" alt="logo" /> | ||||
|       </div> | ||||
|       <div class="tabs"> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'home' }" @click="handleTabClick('home')"> | ||||
|           {{ t('home.nav.home') }} | ||||
|         </div> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'companyprofil' }" @click="handleTabClick('companyprofil')"> | ||||
|           {{ t('home.nav.company') }} | ||||
|         </div> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'business' }" @click="handleTabClick('business')"> | ||||
|           {{ t('home.nav.business') }} | ||||
|         </div> | ||||
|       </div> | ||||
|     </header> | ||||
| 
 | ||||
|   <main ref="main"> | ||||
|     <div class="scroll-down" :class="{ hide: !scrollDownVisible }">{{ t('home.scroll.tip') }}</div> | ||||
|     <section className="panel first-panel"> | ||||
| @ -718,49 +700,6 @@ watch( | ||||
| </template> | ||||
| 
 | ||||
| <style scoped lang="scss"> | ||||
| .header { | ||||
|   width: 100%; | ||||
|   height: 55px; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   align-items: flex-end; | ||||
|   position: fixed; | ||||
|   z-index: 10; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   right: 0; | ||||
|   padding: 0 14rem; | ||||
|   background-color: transparent; | ||||
| } | ||||
| 
 | ||||
| .logo { | ||||
|   img { | ||||
|     width: 108px; | ||||
|     height: 33px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .tabs { | ||||
|   display: flex; | ||||
|   gap: 32px; | ||||
|   margin-right: 32px; | ||||
| } | ||||
| 
 | ||||
| .tab-item { | ||||
|   font-size: 16px; | ||||
|   color: #000000; | ||||
|   cursor: pointer; | ||||
|   transition: color 0.3s ease; | ||||
|   padding: 4px 8px; | ||||
| 
 | ||||
|   &.active { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| 
 | ||||
|   &:hover { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| } | ||||
| .scroll-down { | ||||
|   position: fixed; | ||||
|   bottom: 50px; | ||||
| @ -873,7 +812,49 @@ watch( | ||||
|   -moz-osx-font-smoothing: grayscale; | ||||
| } | ||||
| 
 | ||||
| .header { | ||||
|   width: 100%; | ||||
|   height: 55px; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   align-items: flex-end; | ||||
|   position: fixed; | ||||
|   z-index: 10; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   right: 0; | ||||
|   padding: 0 10rem; | ||||
|   background-color: transparent; | ||||
| } | ||||
| 
 | ||||
| .logo { | ||||
|   img { | ||||
|     width: 108px; | ||||
|     height: 33px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .tabs { | ||||
|   display: flex; | ||||
|   gap: 32px; | ||||
|   margin-right: 32px; | ||||
| } | ||||
| 
 | ||||
| .tab-item { | ||||
|   font-size: 16px; | ||||
|   color: #000000; | ||||
|   cursor: pointer; | ||||
|   transition: color 0.3s ease; | ||||
|   padding: 4px 8px; | ||||
| 
 | ||||
|   &.active { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| 
 | ||||
|   &:hover { | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .panel { | ||||
|   height: 100vh; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user