Compare commits
	
		
			No commits in common. "b7e7cd5090b185c2badd1efdaedb67a2049a1086" and "963c3020b1d9ebf2c77dd08d83813aa835e43db2" have entirely different histories.
		
	
	
		
			b7e7cd5090
			...
			963c3020b1
		
	
		
							
								
								
									
										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). | ||||
|  | ||||
| @ -1 +0,0 @@ | ||||
|   | ||||
| @ -1 +0,0 @@ | ||||
|   | ||||
| @ -19,7 +19,7 @@ | ||||
|     "gsap": "^3.12.5", | ||||
|     "jsdom": "^24.0.0", | ||||
|     "lodash": "^4.17.21", | ||||
|     "naive-ui": "^2.41.0", | ||||
|     "naive-ui": "^2.39.0", | ||||
|     "path": "^0.12.7", | ||||
|     "postcss-preset-env": "^10.0.0", | ||||
|     "postcss-px-to-viewport": "^1.1.1", | ||||
|  | ||||
| @ -33,8 +33,8 @@ importers: | ||||
|         specifier: ^4.17.21 | ||||
|         version: 4.17.21 | ||||
|       naive-ui: | ||||
|         specifier: ^2.41.0 | ||||
|         version: 2.41.0(vue@3.4.35) | ||||
|         specifier: ^2.39.0 | ||||
|         version: 2.39.0(vue@3.4.35) | ||||
|       path: | ||||
|         specifier: ^0.12.7 | ||||
|         version: 0.12.7 | ||||
| @ -1655,13 +1655,14 @@ packages: | ||||
|     resolution: {integrity: sha512-ZYP5VBHshaDAiVZxjbRVcFJpc+4xGgT0bK3vzy1HLN8jTO975HEbuYzZJcHoQEY5K1a0z8YayJkyVETa08eNTg==} | ||||
|     engines: {node: '>=18'} | ||||
| 
 | ||||
|   date-fns-tz@3.2.0: | ||||
|     resolution: {integrity: sha512-sg8HqoTEulcbbbVXeg84u5UnlsQa8GS5QXMqjjYIhS4abEVVKIUwe0/l/UhrZdKaL/W5eWZNlbTeEIiOXTcsBQ==} | ||||
|   date-fns-tz@2.0.1: | ||||
|     resolution: {integrity: sha512-fJCG3Pwx8HUoLhkepdsP7Z5RsucUi+ZBOxyM5d0ZZ6c4SdYustq0VMmOu6Wf7bli+yS/Jwp91TOCqn9jMcVrUA==} | ||||
|     peerDependencies: | ||||
|       date-fns: ^3.0.0 || ^4.0.0 | ||||
|       date-fns: 2.x | ||||
| 
 | ||||
|   date-fns@3.6.0: | ||||
|     resolution: {integrity: sha512-fRHTG8g/Gif+kSh50gaGEdToemgfj74aRX3swtiouboip5JDLAyDE9F11nHMIcvOaXeOC6D7SpNhi7uFyB7Uww==} | ||||
|   date-fns@2.30.0: | ||||
|     resolution: {integrity: sha512-fnULvOpxnC5/Vg3NCiWelDsLiUc9bRwAPs/+LfTLNvetFCtCTN+yQz15C/fs4AwX1R9K5GLtLfn8QW+dWisaAw==} | ||||
|     engines: {node: '>=0.11'} | ||||
| 
 | ||||
|   debug@4.3.6: | ||||
|     resolution: {integrity: sha512-O/09Bd4Z1fBrU4VzkhFqVgpPzaGbw6Sm9FEkBT1A/YBXQFGuuSxa1dN2nxgxS34JmKXqYx8CZAwEVoJFImUXIg==} | ||||
| @ -1979,8 +1980,8 @@ packages: | ||||
|   mutation-observer@1.0.3: | ||||
|     resolution: {integrity: sha512-M/O/4rF2h776hV7qGMZUH3utZLO/jK7p8rnNgGkjKUw8zCGjRQPxB8z6+5l8+VjRUQ3dNYu4vjqXYLr+U8ZVNA==} | ||||
| 
 | ||||
|   naive-ui@2.41.0: | ||||
|     resolution: {integrity: sha512-KnmLg+xPLwXV8QVR7ZZ69eCjvel7R5vru8+eFe4VoAJHEgqAJgVph6Zno9K2IVQRpSF3GBGea3tjavslOR4FAA==} | ||||
|   naive-ui@2.39.0: | ||||
|     resolution: {integrity: sha512-5oUJzRG+rtLSH8eRU+fJvVYiQids2BxF9jp+fwGoAqHOptEINrBlgBu9uy+95RHE5FLJ7Q/z41o+qkoGnUrKxQ==} | ||||
|     peerDependencies: | ||||
|       vue: ^3.0.0 | ||||
| 
 | ||||
| @ -2587,8 +2588,8 @@ packages: | ||||
|       typescript: | ||||
|         optional: true | ||||
| 
 | ||||
|   vueuc@0.4.64: | ||||
|     resolution: {integrity: sha512-wlJQj7fIwKK2pOEoOq4Aro8JdPOGpX8aWQhV8YkTW9OgWD2uj2O8ANzvSsIGjx7LTOc7QbS7sXdxHi6XvRnHPA==} | ||||
|   vueuc@0.4.58: | ||||
|     resolution: {integrity: sha512-Wnj/N8WbPRSxSt+9ji1jtDHPzda5h2OH/0sFBhvdxDRuyCZbjGg3/cKMaKqEoe+dErTexG2R+i6Q8S/Toq1MYg==} | ||||
|     peerDependencies: | ||||
|       vue: ^3.0.11 | ||||
| 
 | ||||
| @ -4409,11 +4410,13 @@ snapshots: | ||||
|       whatwg-mimetype: 4.0.0 | ||||
|       whatwg-url: 14.0.0 | ||||
| 
 | ||||
|   date-fns-tz@3.2.0(date-fns@3.6.0): | ||||
|   date-fns-tz@2.0.1(date-fns@2.30.0): | ||||
|     dependencies: | ||||
|       date-fns: 3.6.0 | ||||
|       date-fns: 2.30.0 | ||||
| 
 | ||||
|   date-fns@3.6.0: {} | ||||
|   date-fns@2.30.0: | ||||
|     dependencies: | ||||
|       '@babel/runtime': 7.25.0 | ||||
| 
 | ||||
|   debug@4.3.6: | ||||
|     dependencies: | ||||
| @ -4721,7 +4724,7 @@ snapshots: | ||||
| 
 | ||||
|   mutation-observer@1.0.3: {} | ||||
| 
 | ||||
|   naive-ui@2.41.0(vue@3.4.35): | ||||
|   naive-ui@2.39.0(vue@3.4.35): | ||||
|     dependencies: | ||||
|       '@css-render/plugin-bem': 0.15.14(css-render@0.15.14) | ||||
|       '@css-render/vue3-ssr': 0.15.14(vue@3.4.35) | ||||
| @ -4731,8 +4734,8 @@ snapshots: | ||||
|       async-validator: 4.2.5 | ||||
|       css-render: 0.15.14 | ||||
|       csstype: 3.1.3 | ||||
|       date-fns: 3.6.0 | ||||
|       date-fns-tz: 3.2.0(date-fns@3.6.0) | ||||
|       date-fns: 2.30.0 | ||||
|       date-fns-tz: 2.0.1(date-fns@2.30.0) | ||||
|       evtd: 0.2.4 | ||||
|       highlight.js: 11.10.0 | ||||
|       lodash: 4.17.21 | ||||
| @ -4742,7 +4745,7 @@ snapshots: | ||||
|       vdirs: 0.1.8(vue@3.4.35) | ||||
|       vooks: 0.2.12(vue@3.4.35) | ||||
|       vue: 3.4.35 | ||||
|       vueuc: 0.4.64(vue@3.4.35) | ||||
|       vueuc: 0.4.58(vue@3.4.35) | ||||
| 
 | ||||
|   nanoid@3.3.7: {} | ||||
| 
 | ||||
| @ -5418,7 +5421,7 @@ snapshots: | ||||
|       '@vue/server-renderer': 3.4.35(vue@3.4.35) | ||||
|       '@vue/shared': 3.4.35 | ||||
| 
 | ||||
|   vueuc@0.4.64(vue@3.4.35): | ||||
|   vueuc@0.4.58(vue@3.4.35): | ||||
|     dependencies: | ||||
|       '@css-render/vue3-ssr': 0.15.14(vue@3.4.35) | ||||
|       '@juggle/resize-observer': 3.4.0 | ||||
|  | ||||
| @ -1,6 +1,5 @@ | ||||
| <script setup> | ||||
| import { ref } from "vue"; | ||||
| 
 | ||||
| import { useI18n } from "vue-i18n"; | ||||
| import { NConfigProvider, NDropdown } from "naive-ui"; | ||||
| import AppHeader from "@/components/AppHeader.vue"; | ||||
| @ -55,7 +54,6 @@ const handleLanguageChange = (key) => { | ||||
|         {{ languageOptions.find(opt => opt.key === locale)?.label }} | ||||
|       </div> | ||||
|     </n-dropdown> --> | ||||
|     <!-- <AppHeader /> --> | ||||
|     <router-view /> | ||||
|   </n-config-provider> | ||||
| </template> | ||||
| @ -68,4 +66,6 @@ const handleLanguageChange = (key) => { | ||||
|   box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); | ||||
|   cursor: pointer; | ||||
| } | ||||
| @import "@/assets/styles/sfcommon.css"; | ||||
| @import "@/assets/styles/row.css"; | ||||
| </style> | ||||
|  | ||||
| Before Width: | Height: | Size: 3.4 KiB | 
| Before Width: | Height: | Size: 396 KiB | 
| Before Width: | Height: | Size: 1.2 MiB | 
| Before Width: | Height: | Size: 4.3 KiB | 
| Before Width: | Height: | Size: 8.8 KiB | 
| Before Width: | Height: | Size: 768 KiB | 
| Before Width: | Height: | Size: 501 KiB After Width: | Height: | Size: 474 KiB | 
| Before Width: | Height: | Size: 4.4 KiB | 
| Before Width: | Height: | Size: 1.6 MiB | 
| Before Width: | Height: | Size: 83 KiB | 
| Before Width: | Height: | Size: 87 KiB | 
| Before Width: | Height: | Size: 73 KiB | 
| Before Width: | Height: | Size: 86 KiB | 
| Before Width: | Height: | Size: 79 KiB | 
							
								
								
									
										
											BIN
										
									
								
								src/assets/image/piece.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 40 KiB | 
| Before Width: | Height: | Size: 2.0 MiB | 
| Before Width: | Height: | Size: 1.2 MiB | 
| Before Width: | Height: | Size: 243 KiB | 
| Before Width: | Height: | Size: 28 KiB | 
| Before Width: | Height: | Size: 334 KiB | 
| Before Width: | Height: | Size: 976 KiB | 
| Before Width: | Height: | Size: 428 KiB | 
| Before Width: | Height: | Size: 833 KiB | 
							
								
								
									
										1155
									
								
								src/assets/styles/row.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										525
									
								
								src/assets/styles/sfcommon.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,525 @@ | ||||
| .cursor { | ||||
|     cursor: pointer; | ||||
| } | ||||
| 
 | ||||
| .fl-page-width { | ||||
|     max-width: 1200px; | ||||
|     margin: auto; | ||||
| } | ||||
| 
 | ||||
| .flex { | ||||
|     display: flex; | ||||
| } | ||||
| 
 | ||||
| .align-center { | ||||
|     align-items: center; | ||||
| } | ||||
| 
 | ||||
| .flex-wrap { | ||||
|     flex-wrap: wrap; | ||||
| } | ||||
| 
 | ||||
| .column { | ||||
|     flex-direction: column; | ||||
| } | ||||
| 
 | ||||
| .items-start { | ||||
|     align-items: flex-start !important; | ||||
| } | ||||
| 
 | ||||
| .items-center { | ||||
|     align-items: center; | ||||
| } | ||||
| 
 | ||||
| .content-start { | ||||
|     align-content: flex-start !important; | ||||
| } | ||||
| 
 | ||||
| .content-center { | ||||
|     align-items: center; | ||||
| } | ||||
| 
 | ||||
| .justify-between { | ||||
|     justify-content: space-between; | ||||
| } | ||||
| 
 | ||||
| .justify-around { | ||||
|     justify-content: space-around; | ||||
| } | ||||
| 
 | ||||
| .justify-end { | ||||
|     justify-content: flex-end; | ||||
| } | ||||
| 
 | ||||
| .justify-center { | ||||
|     justify-content: center; | ||||
| } | ||||
| 
 | ||||
| .relative { | ||||
|     position: relative; | ||||
| } | ||||
| 
 | ||||
| .absolute { | ||||
|     position: absolute; | ||||
| } | ||||
| 
 | ||||
| .text-center { | ||||
|     text-align: center !important; | ||||
| } | ||||
| 
 | ||||
| .text-right { | ||||
|     text-align: right !important; | ||||
| } | ||||
| 
 | ||||
| .text-left { | ||||
|     text-align: left !important; | ||||
| } | ||||
| 
 | ||||
| .no-link { | ||||
|     text-decoration: none; | ||||
| } | ||||
| 
 | ||||
| .sf-link { | ||||
|     color: #409eff; | ||||
|     cursor: pointer; | ||||
|     text-decoration: none; | ||||
| } | ||||
| 
 | ||||
| .title { | ||||
|     font-size: 16px; | ||||
|     /* font-weight: bold; */ | ||||
|     color: #b8bac9; | ||||
|     margin: 10px 0; | ||||
| } | ||||
| 
 | ||||
| .sf-text-ellipsis { | ||||
|     overflow: hidden; | ||||
|     text-overflow: ellipsis; | ||||
|     white-space: nowrap; | ||||
| } | ||||
| 
 | ||||
| .overflow-auto { | ||||
|     overflow: auto; | ||||
| } | ||||
| 
 | ||||
| .overflow-hidden { | ||||
|     overflow: hidden; | ||||
| } | ||||
| 
 | ||||
| .width-100 { | ||||
|     width: 100%; | ||||
| } | ||||
| 
 | ||||
| .height-100 { | ||||
|     height: 100%; | ||||
| } | ||||
| 
 | ||||
| .maxH-100 { | ||||
|     max-height: 100%; | ||||
| } | ||||
| 
 | ||||
| .display-none { | ||||
|     display: none; | ||||
| } | ||||
| 
 | ||||
| .fl-pa-sm { | ||||
|     padding: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pb-xs { | ||||
|     padding-bottom: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pa-xs { | ||||
|     padding: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-py-xs { | ||||
|     padding-top: 4px !important; | ||||
|     padding-bottom: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .m-auto { | ||||
|     margin: auto | ||||
| } | ||||
| 
 | ||||
| .fl-mx-xs { | ||||
|     margin-left: 4px !important; | ||||
|     margin-right: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-my-xs { | ||||
|     margin-top: 4px !important; | ||||
|     margin-bottom: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-ml-xs { | ||||
|     margin-left: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mt-xs { | ||||
|     margin-top: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pt-xs { | ||||
|     padding-top: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pl-xs { | ||||
|     padding-left: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pl-sm { | ||||
|     padding-left: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pr-sm { | ||||
|     padding-right: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pt-sm { | ||||
|     padding-top: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pb-sm { | ||||
|     padding-bottom: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-px-sm { | ||||
|     padding-left: 8px !important; | ||||
|     padding-right: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-px-xs { | ||||
|     padding-left: 4px !important; | ||||
|     padding-right: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-py-sm { | ||||
|     padding-top: 8px !important; | ||||
|     padding-bottom: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pa-md { | ||||
|     padding: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pl-md { | ||||
|     padding-left: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pr-md { | ||||
|     padding-right: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pt-md { | ||||
|     padding-top: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pb-md { | ||||
|     padding-bottom: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-px-md { | ||||
|     padding-left: 16px !important; | ||||
|     padding-right: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-py-md { | ||||
|     padding-top: 16px !important; | ||||
|     padding-bottom: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pa-lg { | ||||
|     padding: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pl-lg { | ||||
|     padding-left: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pr-lg { | ||||
|     padding-right: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pt-lg { | ||||
|     padding-top: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-pb-lg { | ||||
|     padding-bottom: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-px-lg { | ||||
|     padding-left: 24px !important; | ||||
|     padding-right: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-py-lg { | ||||
|     padding-top: 24px !important; | ||||
|     padding-bottom: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-ma-sm { | ||||
|     margin: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-ma-xs { | ||||
|     margin: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-ml-sm { | ||||
|     margin-left: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mr-sm { | ||||
|     margin-right: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mt-sm { | ||||
|     margin-top: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mb-xs { | ||||
|     margin-bottom: 4px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mb-sm { | ||||
|     margin-bottom: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mx-sm { | ||||
|     margin-left: 8px !important; | ||||
|     margin-right: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-my-sm { | ||||
|     margin-top: 8px !important; | ||||
|     margin-bottom: 8px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-ma-md { | ||||
|     margin: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-ml-md { | ||||
|     margin-left: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mr-md { | ||||
|     margin-right: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mt-md { | ||||
|     margin-top: 16px !important; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| .fl-mb-md { | ||||
|     margin-bottom: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mx-md { | ||||
|     margin-left: 16px !important; | ||||
|     margin-right: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-my-md { | ||||
|     margin-top: 16px !important; | ||||
|     margin-bottom: 16px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-ma-lg { | ||||
|     margin: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-ml-lg { | ||||
|     margin-left: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mr-lg { | ||||
|     margin-right: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mt-lg { | ||||
|     margin-top: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mb-lg { | ||||
|     margin-bottom: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-mx-lg { | ||||
|     margin-left: 24px !important; | ||||
|     margin-right: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .fl-my-lg { | ||||
|     margin-top: 24px !important; | ||||
|     margin-bottom: 24px !important; | ||||
| } | ||||
| 
 | ||||
| .border-box { | ||||
|     box-sizing: border-box; | ||||
| } | ||||
| 
 | ||||
| .border-dashed { | ||||
|     border: 2px dashed rgba(145, 148, 99, 0.6); | ||||
|     border-radius: 5px | ||||
| } | ||||
| 
 | ||||
| .box-content { | ||||
|     box-sizing: content-box; | ||||
| } | ||||
| 
 | ||||
| .box-border { | ||||
|     box-sizing: border-box; | ||||
| } | ||||
| 
 | ||||
| * ::-webkit-scrollbar { | ||||
|     width: 10px; | ||||
|     height: 10px; | ||||
| } | ||||
| 
 | ||||
| * ::-webkit-scrollbar-track { | ||||
|     border-radius: 3px; | ||||
|     background: rgba(0, 0, 0, 0.06); | ||||
|     -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.08); | ||||
| } | ||||
| 
 | ||||
| * ::-webkit-scrollbar-thumb { | ||||
|     border-radius: 3px; | ||||
|     background: rgba(0, 0, 0, 0.12); | ||||
|     -webkit-box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.2); | ||||
| } | ||||
| 
 | ||||
| .link-area { | ||||
|     display: flex; | ||||
|     align-items: center; | ||||
|     color: #409eff; | ||||
| } | ||||
| 
 | ||||
| .bg-white { | ||||
|     background: #ffffff !important; | ||||
| } | ||||
| 
 | ||||
| .bg-grey { | ||||
|     background: #777777 !important; | ||||
| } | ||||
| 
 | ||||
| .bg-grey-1 { | ||||
|     background: #b4b0b0 !important; | ||||
| } | ||||
| 
 | ||||
| .bg-black { | ||||
|     background: #000 !important; | ||||
| } | ||||
| 
 | ||||
| .bg-764CF6 { | ||||
|     background: #764CF6 !important; | ||||
| } | ||||
| 
 | ||||
| .bg-370D9B { | ||||
|     background: #370D9B !important; | ||||
| } | ||||
| 
 | ||||
| .bg-b2b2c6 { | ||||
|     background: #b2b2c6 | ||||
| } | ||||
| 
 | ||||
| .bg-fff { | ||||
|     background-color: #fff !important; | ||||
| } | ||||
| 
 | ||||
| .bg-primary { | ||||
|     /* background-color: #3aace8 !important; */ | ||||
|     background-color: #764CF6 !important; | ||||
| } | ||||
| 
 | ||||
| .bg-danger { | ||||
|     background-color: #ef136e | ||||
| } | ||||
| 
 | ||||
| .color-white { | ||||
|     color: #fff !important; | ||||
| } | ||||
| 
 | ||||
| .color-000 { | ||||
|     color: #000 !important; | ||||
| } | ||||
| 
 | ||||
| .color-danger { | ||||
|     color: #ef136e !important; | ||||
| } | ||||
| 
 | ||||
| .color-primary { | ||||
|     color: #3aace8 !important; | ||||
| } | ||||
| 
 | ||||
| .color-764CF6 { | ||||
|     color: #764CF6 !important; | ||||
| } | ||||
| 
 | ||||
| .color-info { | ||||
|     color: #4ed80e !important; | ||||
| } | ||||
| 
 | ||||
| .color-draft { | ||||
|     color: #b0bce0 !important; | ||||
| } | ||||
| 
 | ||||
| .color-yellow { | ||||
|     color: orange !important; | ||||
| } | ||||
| 
 | ||||
| .color-black { | ||||
|     color: #000 !important; | ||||
| } | ||||
| 
 | ||||
| .color-grey { | ||||
|     color: rgb(163, 156, 156) !important; | ||||
| } | ||||
| 
 | ||||
| .color-grey-disable { | ||||
|     color: rgb(163, 156, 156) !important; | ||||
|     cursor: no-drop; | ||||
| } | ||||
| 
 | ||||
| .index-container { | ||||
|     padding: 20px 30px 0 30px; | ||||
|     background: #fff; | ||||
|     border-radius: 5px; | ||||
| } | ||||
| 
 | ||||
| .no-radius { | ||||
|     border-radius: none; | ||||
| } | ||||
| 
 | ||||
| .no-shadow { | ||||
|     box-shadow: none; | ||||
| } | ||||
| 
 | ||||
| .no-margin { | ||||
|     margin: none; | ||||
| } | ||||
| 
 | ||||
| .no-padding { | ||||
|     padding: none; | ||||
| } | ||||
| 
 | ||||
| .border-1 { | ||||
|     /* border: 1px solid rgb(65, 62, 62) */ | ||||
|     border: 1px solid #E3DFEA; | ||||
| } | ||||
| 
 | ||||
| .border-radius-4 { | ||||
|     border-radius: 4px !important | ||||
| } | ||||
| 
 | ||||
| .border-radius-8 { | ||||
|     border-radius: 8px !important | ||||
| } | ||||
| 
 | ||||
| .border-radius-16 { | ||||
|     border-radius: 16px !important | ||||
| } | ||||
| @ -3,33 +3,30 @@ | ||||
|     <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> | ||||
| </template> | ||||
| <script setup> | ||||
| import { useI18n } from 'vue-i18n'; | ||||
| 
 | ||||
| import { useRouter } from "vue-router"; | ||||
| import { useHome } from '@/store/home/index.js'; | ||||
| const router = useRouter(); | ||||
| const { currentTab } = useHome(); | ||||
| const { t } = useI18n(); | ||||
| 
 | ||||
| const handleTabClick = (tab) => { | ||||
|   currentTab.value = tab; | ||||
|   router.push('/'+tab); | ||||
| } | ||||
| </script> | ||||
| <style scoped lang="scss"> | ||||
| .header { | ||||
|   width: 100%; | ||||
|   height: 80px; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   align-items: flex-end; | ||||
|   position: fixed; | ||||
|   z-index: 10; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   right: 0; | ||||
|   padding: 0; | ||||
|   border-radius: 0; | ||||
|   background-color: transparent; | ||||
| 
 | ||||
|   padding: 0 1rem; | ||||
| } | ||||
| .logo{ | ||||
|     img{ | ||||
|       width: 108px; | ||||
|       height: 33px; | ||||
|     } | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -19,11 +19,11 @@ function getBrowserLanguage() { | ||||
|   if (lang.includes('ja')) { | ||||
|     return 'ja' | ||||
|   } | ||||
|   return 'en' // 默认中文,而不是英语
 | ||||
|   return 'zh' // 默认中文,而不是英语
 | ||||
| } | ||||
| 
 | ||||
| // 获取存储的语言或浏览器语言
 | ||||
| const savedLanguage = 'en' | ||||
| const savedLanguage = localStorage.getItem('language') || getBrowserLanguage() | ||||
| 
 | ||||
| const i18n = createI18n({ | ||||
|   legacy: false, // 使用 Composition API
 | ||||
|  | ||||
| @ -5,66 +5,9 @@ export default { | ||||
|     confirm: 'Confirm' | ||||
|   }, | ||||
|   home: { | ||||
|     nav: { | ||||
|       home: 'Home', | ||||
|       company: 'Company Overview', | ||||
|       business: 'Business Introduction' | ||||
|     }, | ||||
|     scroll: { | ||||
|       tip: 'Scroll Down' | ||||
|     }, | ||||
|     section2: { | ||||
|       title1: 'FiEE with Art Creators', | ||||
|       title2: 'Embarking on Global Impact' | ||||
|     }, | ||||
|     section3: { | ||||
|       label: 'Company Profile', | ||||
|       title: 'FiEE', | ||||
|       desc: 'As an innovative pioneer deeply rooted in cutting-edge technology, FiEE continuously researches the application of AI and big data in artistic creation. Through in-depth analysis of artistic concepts and profound insights into creative practices, we precisely grasp the development trends of art. With great passion, we integrate various technologies and resources to provide comprehensive empowerment for art creators, from inspiration to promotion.', | ||||
|       features: { | ||||
|         data: { | ||||
|           title: 'Big Data Anchors Creative Direction', | ||||
|           desc: 'Using self-developed big data models to deeply analyze the global art market, providing forward-looking judgments to help creators clarify direction.' | ||||
|         }, | ||||
|         ai: { | ||||
|           title: 'AI Algorithms Break Communication Barriers', | ||||
|           desc: 'Utilizing cutting-edge AI algorithms to build personalized recommendation systems, precisely matching audiences and breaking through art communication limitations.' | ||||
|         }, | ||||
|         cloud: { | ||||
|           title: 'Cloud Computing Mines Artistic Value', | ||||
|           desc: 'Leveraging excellent cloud computing capabilities to efficiently process massive data, supporting creators in exploration and expansion.' | ||||
|         }, | ||||
|         cooperation: { | ||||
|           title: 'Professional Cooperation Establishes Benchmark Status', | ||||
|           desc: 'Collaborating with professional art institutions and academic platforms to help creators gain recognition and establish professional art benchmarks.' | ||||
|         }, | ||||
|         promotion: { | ||||
|           title: 'Diverse Promotion Shapes Global Brands', | ||||
|           desc: 'Utilizing diverse communication and innovative marketing, combined with brand building and promotion, to help creators become global art brands.' | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     section4: { | ||||
|       label: 'Business Introduction', | ||||
|       title: 'Multi-business Synergy, Driving Artistic Influence to Soar', | ||||
|       desc: 'FiEE focuses on providing global promotion and professional operation services for art creators. Through precise positioning and multi-platform linkage, we break geographical restrictions to bring works to the international stage. Relying on a strong resource network to connect business opportunities, using AI and big data for precise marketing, efficiently reaching audiences, helping creators achieve breakthroughs in both artistic and commercial value.', | ||||
|       cards1: { | ||||
|         title: 'Global Floral Industry, Suitable for International Art Exchange Center', | ||||
|         desc: 'FiEE upholds the concept of "Art Without Borders", relying on multi-platform linkage to break geographical restrictions, pushing works to the global market, attracting potential consumers, and letting art creators shine on the international stage.' | ||||
|       }, | ||||
|       cards2: { | ||||
|         title: 'Professional Operation Team, Precise Audience Targeting', | ||||
|         desc: 'FiEE\'s operation team brings together senior talents from multiple fields, leveraging rich experience and market insights to formulate precise promotion strategies through data analysis, enabling works to accurately reach target audiences and achieve deep resonance.' | ||||
|       }, | ||||
|       cards3: { | ||||
|         title: 'Strong Resource Network, Expanding Unlimited Business Opportunities', | ||||
|         desc: 'FiEE establishes deep cooperation with globally renowned art institutions and mainstream media, building a vast resource network, helping art creators connect with high-end resources, and expanding business cooperation opportunities such as artwork licensing and derivative product development.' | ||||
|       }, | ||||
|       cards4: { | ||||
|         title: 'Technology-Driven Marketing, Efficiently Reaching Fan Groups', | ||||
|         desc: 'FiEE uses AI algorithms and big data analysis to precisely profile target groups, achieve personalized promotion, quickly reach fan groups, accumulate loyal fan communities, and use intelligent tools to optimize promotion strategies, empowering art creators\' artistic career development.' | ||||
|       } | ||||
|     } | ||||
|     title: 'Children Art Collection', | ||||
|     vote: 'Vote', | ||||
|     signup: 'Sign Up' | ||||
|   }, | ||||
|   vote: { | ||||
|     title: 'Children Art Collection Activity', | ||||
| @ -77,80 +20,5 @@ export default { | ||||
|       phone: 'Phone Number', | ||||
|       submit: 'Submit Registration' | ||||
|     } | ||||
|   }, | ||||
|   companyprofil: { | ||||
|     slogan: { | ||||
|       title1: 'Leading the Full Cycle of Art', | ||||
|       title2: 'Transforming Value to New Heights', | ||||
|       desc: 'FiEE aspires to become the helmsman of the full art creation cycle, deeply participating in every key node from inspiration inception, work refinement completion, to market promotion and cultural dissemination.' | ||||
|     }, | ||||
|     intro: { | ||||
|       label: 'Company Introduction', | ||||
|       title1: 'Uniquely Positioned', | ||||
|       title2: 'Full-Cycle Value Empowerment Pioneer', | ||||
|       desc: 'FiEE completely breaks through the limitations of traditional single-service institutions. As an industry transformer, we deeply integrate cutting-edge technology with diverse resources, carefully building a "full-cycle" value empowerment system that spans the entire process of artistic creation from conceptual germination to brilliant blooming. Whether you are a newcomer just entering the art world with dreams, or a mature art worker who has struggled on the artistic path and yearns to break through creative bottlenecks and climb higher artistic peaks, FiEE will be your most solid partner, accompanying you all the way, sheltering you from wind and rain, and pointing the way forward.' | ||||
|     }, | ||||
|     team: { | ||||
|       label: 'Team Introduction', | ||||
|       title1: 'Gathering Elite Talents', | ||||
|       title2: 'Igniting Art Innovation Engine', | ||||
|       desc: 'The FiEE team consists of operation experts, technical elites, and international consultants, providing comprehensive support from content planning to global promotion. Through cross-border cooperation and resource integration, FiEE breaks through traditional boundaries and explores new artistic expressions. Relying on cutting-edge technology and precise marketing, we help works achieve both commercial value and social impact breakthroughs, injecting lasting momentum into artistic prosperity.', | ||||
|       features: { | ||||
|         global: { | ||||
|           title: 'Global Reach, Diverse Navigation', | ||||
|           desc: 'Overseas precision marketing, laying multiple channels, shaping international brands. Intelligent management of multilingual platforms, providing localized services.' | ||||
|         }, | ||||
|         fans: { | ||||
|           title: 'Deep Fan Cultivation, Building Ecosystem', | ||||
|           desc: 'Fine community operations, providing diverse value-added services. Upgrading community management tools, precisely reaching users. Innovative incentive mechanisms, developing featured derivatives.' | ||||
|         }, | ||||
|         talent: { | ||||
|           title: 'Broad Talent Recruitment, Team Advancement', | ||||
|           desc: 'Recruiting technical and marketing elites, injecting innovative vitality. Strengthening internal training, optimizing organizational structure. Introducing advanced concepts, improving management and service efficiency.' | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     achievement: { | ||||
|       label: 'Outstanding Achievements', | ||||
|       title: 'Pioneering to Art\'s Summit', | ||||
|       desc: 'Long-term deep cultivation in the art field, FiEE continues to expand its business map, accumulating deep industry resources and building an extensive cooperation network. Currently, we have deeply partnered with multiple global popular self-media platforms, helping art creators shine on the international stage from multiple dimensions and bloom their unique artistic brilliance.', | ||||
|       certification: { | ||||
|         title1: 'Authoritative Qualification Certification', | ||||
|         title2: 'Building Solid Foundation for Art Career', | ||||
|         desc: 'FiEE provides professional and authoritative qualification certification services, helping art creators obtain widely recognized industry qualifications. This not only significantly enhances the value of art creators\' works but also helps art creators stand out in the fiercely competitive art market, greatly enhancing art workers\' market competitiveness, laying a solid foundation for art creators\' careers.' | ||||
|       }, | ||||
|       platform: { | ||||
|         title1: 'Global Platform Matrix', | ||||
|         title2: 'Expanding Art Communication Boundaries', | ||||
|         desc: 'With deep industry resources and extensive cooperation network, FiEE has reached deep strategic partnerships with over 30 global popular self-media platforms. From internationally renowned social platforms to professional media focused on art fields, we carefully create exclusive accounts for art creators and use advanced optimization strategies to make art creators\' accounts stand out among numerous creators.' | ||||
|       } | ||||
|     }, | ||||
|     news: { | ||||
|       label: 'Focus on FIEE Frontier Dynamics', | ||||
|       title: 'Insight Trends, Lighting the Beacon for Art\'s Future', | ||||
|       desc: 'FiEE remains rooted in the art field, always following global art development trends. Through in-depth case analysis and cross-border discussions, we explore the deep integration of art with technology and business, providing forward-looking insights and inspiration for the future development of art.', | ||||
|       carousel: { | ||||
|         item1: { | ||||
|           title: 'Achieving Technical Breakthrough, Leading Art Creation Technology Innovation', | ||||
|           desc: 'As the digital wave sweeps through the art field with unprecedented momentum, art creation is undergoing profound changes. With the team\'s persistent efforts and innovative spirit, FiEE has achieved milestone breakthroughs in art creation technology. After countless days and nights of hard work, FiEE\'s self-developed new generation intelligent creation assistance system has officially launched, like a rising brilliant star, opening a new development path for art creation and bringing unprecedented changes and opportunities to the entire industry.' | ||||
|         }, | ||||
|         item2: { | ||||
|           title: 'Global Strategy Upgrade, FiEE Reaches Strategic Cooperation with 30+ International Platforms, Building New Art Communication Matrix', | ||||
|           desc: 'Against the backdrop of accelerating global cultural integration with unprecedented momentum, the art field has become the frontier of cultural exchange and innovation. As a leader in the art industry, FiEE actively participates in this wave of global cultural exchange with keen strategic vision and decisive action. Recently, FiEE excitingly announced deep strategic cooperation with over 30 international leading self-media platforms including TikTok and Instagram, while officially launching the far-reaching "Art Without Borders Plan", determined to break down cultural barriers between regions.' | ||||
|         }, | ||||
|         item3: { | ||||
|           title: 'Empowering Art Creators, FiEE Releases "AI × Short Video" Full-Chain Solution', | ||||
|           desc: 'For art creators, creative bottlenecks and low efficiency are two mountains standing in the way forward. Conceiving an attractive short video script often requires a lot of time and energy, creators not only have to rack their brains to think of unique ideas but also need to consider audience preferences and market trends. The dissemination and promotion after work completion is also a difficult gap to cross.' | ||||
|         }, | ||||
|         item4: { | ||||
|           title: 'FiEE Launches 18-Month Art KOL Incubation, Cultivating Tomorrow\'s Stars in Art Field', | ||||
|           desc: 'In the current flourishing development of the art industry, the importance of quality content creators is increasingly prominent. As a pioneer in the industry, FiEE has always focused on talent cultivation and development dynamics in the art field. Today, FiEE officially announces the launch of an 18-month art KOL incubation plan that has been carefully prepared, aiming to cultivate a batch of future stars with strong influence in the art field and promote the innovative development of the entire industry.' | ||||
|         }, | ||||
|         item5: { | ||||
|           title: 'Diverse Talents Gathering, FiEE Builds Foundation for Art Innovation Development', | ||||
|           desc: 'In the current golden age of flourishing art industry development, innovation has become the key element leading continuous industry progress and breaking through traditional patterns. Tracing back to the source, talent as the core driving force of innovation is of self-evident importance. FiEE deeply understands this truth and actively recruits talents with an open-minded attitude and far-sighted strategic vision, carefully gathering operation experts, technical elites, and international consultants.' | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -5,140 +5,20 @@ export default { | ||||
|     confirm: '确认' | ||||
|   }, | ||||
|   home: { | ||||
|     nav: { | ||||
|       home: '首页', | ||||
|       company: '公司概况', | ||||
|       business: '业务介绍' | ||||
|     title: '儿童美术征集', | ||||
|     vote: '投票', | ||||
|     signup: '报名' | ||||
|   }, | ||||
|     scroll: { | ||||
|       tip: '向下滑动' | ||||
|   vote: { | ||||
|     title: '儿童美术征集活动', | ||||
|     voteBtn: '立即投票' | ||||
|   }, | ||||
|     section2: { | ||||
|       title1: 'FiEE携手文艺创作者', | ||||
|       title2: '启航全球影响力新征程' | ||||
|     }, | ||||
|     section3: { | ||||
|       label: '公司简介', | ||||
|       title: 'FiEE', | ||||
|       desc: '作为一家深度扎根前沿科技领域的创新领航者,FiEE持续钻研AI、大数据在文艺创作中的应用。凭借对文艺理念的深度剖析,以及对创作实践的深刻洞察,我们精准把握文艺发展脉络。怀着满腔热忱,整合各类技术与资源,为文艺创作者提供从灵感启发到作品推广的全方位赋能。', | ||||
|       features: { | ||||
|         data: { | ||||
|           title: '大数据锚定创作方向', | ||||
|           desc: '借助自研大数据模型,深析全球文艺市场,提供前瞻研判,助创作者明确方向。' | ||||
|         }, | ||||
|         ai: { | ||||
|           title: 'AI 算法打破传播圈层', | ||||
|           desc: '运用前沿 AI算法,搭建个性化推荐体系,精准匹配受众,突破文艺传播圈限制。' | ||||
|         }, | ||||
|         cloud: { | ||||
|           title: '云计算挖掘文艺价值', | ||||
|           desc: '凭借卓越云计算能力,高效处理海量数据,为创作者探索与拓展提供支撑。' | ||||
|         }, | ||||
|         cooperation: { | ||||
|           title: '专业合作树立标杆地位', | ||||
|           desc: '与专业文艺机构、学术平台合作,助力创作者作品获赞,树立专业文艺标杆。' | ||||
|         }, | ||||
|         promotion: { | ||||
|           title: '多元推广塑造全球品牌', | ||||
|           desc: '借助多元传播与创新营销,结合品牌塑造与推广,助创作者成全球文艺品牌。' | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     section4: { | ||||
|       label: '业务介绍', | ||||
|       title: '多元业务协同,推动文艺影响力腾飞', | ||||
|       desc: 'FiEE 专注为文艺创作者提供全球化推广与专业运营服务。通过精准定位、多平台联动,打破地域限制,让作品登上国际舞台。依托强大资源网络对接商业机遇,运用 AI与大数据精准营销,高效触达受众,助力创作者实现艺术与商业价值双突破。', | ||||
|       cards1: { | ||||
|         title: '全球花卉产业,适合国际艺术交流中心', | ||||
|         desc: 'FiEE秉持 "文艺无国界"理念,依托多平台联动,打破地域限制,将作品推向全球市场,吸引潜在消费者,让文艺创作者在国际舞台绽放光彩。' | ||||
|       }, | ||||
|       cards2: { | ||||
|         title: '专业运营团队,精准定位受众', | ||||
|         desc: 'FiEE运营团队汇聚多领域资深人才,凭借丰富经验和对市场的洞察,通过数据分析制定精准推广策略,让作品精准触达目标受众,实现深度共鸣。' | ||||
|       }, | ||||
|       cards3: { | ||||
|         title: '强大资源网络,拓展无限商业机遇', | ||||
|         desc: 'FiEE与全球知名文艺机构、主流媒体建立深度合作,构建庞大资源网络,帮文艺创作者对接高端资源,拓展艺术作品授权、衍生品开发等商业合作机会。' | ||||
|       }, | ||||
|       cards4: { | ||||
|         title: '技术驱动营销,高效触达粉丝群体', | ||||
|         desc: 'FiEE利用 AI 算法和大数据分析,精准画像目标人群,实现个性化推广,快速触达粉丝群体,积累忠实粉丝社群,运用智能工具优化推广策略,为文艺创作者的艺术事业发展助力。' | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|   companyprofil: { | ||||
|     slogan: { | ||||
|       title1: '领航文艺全周期', | ||||
|       title2: '创变价值新巅峰', | ||||
|       desc: 'FiEE立志成为文艺创作全周期的掌舵人,深度参与从灵感初绽、作品打磨完成,到市场推广宣传、文化广泛传播的每一处关键节点' | ||||
|     }, | ||||
|     intro: { | ||||
|       label: '公司介绍', | ||||
|       title1: '独树一帜', | ||||
|       title2: '全周期价值赋能领航者', | ||||
|       desc: 'FiEE彻底打破传统单一服务机构的局限,以行业变革者的姿态,深度融合前沿技术与丰富多元的资源,精心构建起一套贯穿文艺创作从萌芽构思到辉煌绽放全流程的"全周期"价值赋能体系。无论你是刚刚踏入文艺殿堂、怀揣梦想的创作新人,还是在文艺道路上摸爬滚打、渴望突破创作瓶颈、攀登更高文艺巅峰的成熟文艺工作者,FiEE都将成为你最坚实的伙伴,一路贴心陪伴,为你的文艺征途遮风挡雨,指引前行的方向。' | ||||
|     }, | ||||
|     team: { | ||||
|       label: '团队介绍', | ||||
|       title1: '汇聚精英', | ||||
|       title2: '燃文艺创变引擎', | ||||
|       desc: 'FiEE团队由运营专家、技术精英及国际顾问组成,提供从内容策划到全球推广的全方位支持。通过跨界合作与资源整合,FiEE突破传统边界,探索文艺新表达。依托前沿技术与精准营销,助力作品实现商业价值与社会影响力的双重提升,为文艺繁荣注入持久动力。', | ||||
|       features: { | ||||
|         global: { | ||||
|           title: '纵横全球 多元领航', | ||||
|           desc: '海外精准营销,铺设多元渠道,塑造国际品牌。智能管理多语言平台,提供本地化服务。' | ||||
|         }, | ||||
|         fans: { | ||||
|           title: '深耕粉丝 构筑生态', | ||||
|           desc: '社区精细运营,提供多元增值服务。升级社群管理工具,精准触达用户。创新激励机制,开发特色衍生周边。' | ||||
|         }, | ||||
|         talent: { | ||||
|           title: '广纳贤才 团队进阶', | ||||
|           desc: '广纳技术、营销精英,注入创新活力。强化内部培训,优化组织架构。引入先进理念,提升管理与服务效能。' | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     achievement: { | ||||
|       label: '卓越建树', | ||||
|       title: '以开拓之姿,登文艺之巅', | ||||
|       desc: '长期深耕文艺领域,FiEE持续拓展业务版图,积累了深厚的行业资源,搭建起广泛的合作网络。目前已与多个全球热门自媒体平台深度携手,从多维度助力文艺创作者闪耀国际舞台,绽放独有的艺术光芒。', | ||||
|       certification: { | ||||
|         title1: '权威资质认证', | ||||
|         title2: '铸就文艺事业坚实根基', | ||||
|         desc: 'FiEE提供专业且权威的资质认证服务,助力文艺创作者获取行业广泛认可的资质。这不仅能让文艺创作者的作品价值得到显著提升,更能使文艺创作者在竞争白热化的艺术市场中崭露头角,大幅增强文艺工作者的市场竞争力,为文艺创作者的事业铺就稳固基石。' | ||||
|       }, | ||||
|       platform: { | ||||
|         title1: '全球平台矩阵', | ||||
|         title2: '拓展文艺传播边界', | ||||
|         desc: 'FiEE凭借深厚的行业资源和广泛的合作网络,与超过 30 个全球热门自媒体平台达成深度战略合作伙伴关系。从国际知名的社交平台,到专注文艺领域的专业媒体,我们为文艺创作者精心打造专属账号,并运用先进的优化策略,让文艺创作者的账号在众多创作者中脱颖而出。' | ||||
|       } | ||||
|     }, | ||||
|     news: { | ||||
|       label: '聚焦FIEE前沿动态', | ||||
|       title: '洞察趋势,点亮文艺前行灯塔', | ||||
|       desc: 'FiEE始终扎根文艺领域,时刻紧跟全球艺术发展趋势。通过深度剖析案例、开展跨界研讨,探索文艺与科技、商业的深度融合,为文艺事业未来发展提供前瞻性洞察与灵感启迪。', | ||||
|       carousel: { | ||||
|         item1: { | ||||
|           title: '实现技术突破,引领文艺创作技术革新', | ||||
|           desc: '在数字化浪潮以前所未有的态势席卷文艺领域的当下,文艺创作正经历着深刻变革。FiEE凭借着团队持之以恒的努力与创新精神,在文艺创作技术领域取得了具有里程碑意义的重大突破。 历经无数个日夜的艰苦攻坚,FiEE自主研发的新一代智能创作辅助系统正式上线,宛如一颗冉冉升起的璀璨新星,为文艺创作开辟了全新的发展路径,给整个行业带来了前所未有的变革与机遇。' | ||||
|         }, | ||||
|         item2: { | ||||
|           title: '全球化战略升级,FiEE与30+国际平台达成战略合作,构建文艺传播新矩阵', | ||||
|           desc: '在全球文化交融以前所未有的迅猛之势加速推进的时代大背景下,文艺领域已然成为文化交流与创新的前沿阵地。作为文艺行业的领航者,FiEE 以敏锐的战略眼光和果敢的行动力,积极投身于这场全球文化交流的浪潮之中。 近日,FiEE 振奋人心地宣布与 TikTok、Instagram等 30 余家国际头部自媒体平台达成深度战略合作,同时正式启动具有深远意义的"文艺无界计划",矢志破除地域之间的文化藩篱。' | ||||
|         }, | ||||
|         item3: { | ||||
|           title: '助力文艺创作者,FiEE 发布"AI × 短视频"全链路解决方案', | ||||
|           desc: '对于文艺创作者而言,创作瓶颈与效率低下是横亘在前行道路上的两座大山。构思一个吸引人的短视频脚本,常常需要耗费大量时间和精力,创作者们不仅要绞尽脑汁思考独特的创意,还要兼顾受众喜好和市场趋势。 作品完成后的传播与推广,同样是一道难以跨越的鸿沟。' | ||||
|         }, | ||||
|         item4: { | ||||
|           title: 'FiEE启动 18 个月艺术 KOL 孵化,培育文艺领域明日之星', | ||||
|           desc: '在文艺产业蓬勃发展的当下,优质内容创作者的重要性愈发凸显。作为行业内的先锋企业,FiEE始终关注着文艺领域的人才培养与发展动态。 今日,FiEE正式宣布启动一项精心筹备长达 18 个月的艺术 KOL 孵化计划,旨在为文艺领域培育一批具有强大影响力的明日之星,推动整个行业的创新发展。' | ||||
|         }, | ||||
|         item5: { | ||||
|           title: '多元人才汇聚,FiEE 构筑文艺创新发展基石', | ||||
|           desc: '在当下文艺行业蓬勃发展、百花齐放的黄金时代,创新俨然成为引领行业持续进步、突破传统格局的关键要素。而追根溯源,人才作为创新的核心驱动力,其重要性不言而喻。 FiEE 深明此理,以海纳百川的胸怀和高瞻远瞩的战略眼光,积极广纳贤才,精心汇聚运营专家、技术精英以及国际顾问。' | ||||
|         } | ||||
|       } | ||||
|   entry: { | ||||
|     title: '报名', | ||||
|     form: { | ||||
|       name: '姓名', | ||||
|       phone: '手机号', | ||||
|       submit: '提交报名' | ||||
|     } | ||||
|   } | ||||
| }  | ||||
| @ -1,708 +1,9 @@ | ||||
| <script setup> | ||||
| import { | ||||
|   onUnmounted, | ||||
|   ref, | ||||
|   watch, | ||||
|   reactive | ||||
| } 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, | ||||
|               scrollTrigger: { | ||||
|                 trigger: text, | ||||
|                 start: "top 80%", | ||||
|                 end: "top 50%", | ||||
|                 toggleActions: | ||||
|                   "play none none reverse", | ||||
|               }, | ||||
|             }); | ||||
|           }); | ||||
| 
 | ||||
|         // 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", | ||||
|               }, | ||||
|             }); | ||||
|           }); | ||||
| 
 | ||||
|         // 轮播卡片上升动画 | ||||
|         gsap.from('.carousel-item', { | ||||
|           y: 100, | ||||
|           opacity: 0, | ||||
|           duration: 1.5, | ||||
|           stagger: 0.4, | ||||
|           scrollTrigger: { | ||||
|             trigger: '.carousel-container', | ||||
|             start: 'top 70%', | ||||
|             end: 'top 30%', | ||||
|             scrub: 2, | ||||
|             toggleActions: 'restart pause reverse pause', | ||||
|           } | ||||
|         }); | ||||
| 
 | ||||
|       }, main.value); | ||||
|     } | ||||
|   }, | ||||
|   { | ||||
|     immediate: true, | ||||
|   } | ||||
| ); | ||||
| // 向前滑动 | ||||
| const handlePrev = () => { | ||||
|   if (!carouselTrack.value) return; | ||||
| 
 | ||||
|   carouselTrack.value.style.transition = "transform 0.5s ease-in-out"; | ||||
|   currentIndex.value--; | ||||
| 
 | ||||
|   // 如果滑到第一组的开头,立即跳转到第二组对应位置 | ||||
|   if (currentIndex.value < 0) { | ||||
|     currentIndex.value = state.marqueeArr.length - 1; | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
| // 向后滑动 | ||||
| const handleNext = () => { | ||||
|   if (!carouselTrack.value) return; | ||||
| 
 | ||||
|   carouselTrack.value.style.transition = "transform 0.5s ease-in-out"; | ||||
|   currentIndex.value++; | ||||
| 
 | ||||
|   // 如果滑到最后,立即跳转到第一个位置 | ||||
|   if (currentIndex.value >= state.marqueeArr.length) { | ||||
|     currentIndex.value = 0; | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
| // 添加滑动相关的状态 | ||||
| const isDragging = ref(false); | ||||
| const startX = ref(0); | ||||
| const scrollLeft = ref(0); | ||||
| 
 | ||||
| // 处理鼠标/触摸按下事件 | ||||
| const handleDragStart = (e) => { | ||||
|   isDragging.value = true; | ||||
|   startX.value = e.type === "mousedown" ? e.pageX : e.touches[0].pageX; | ||||
|   scrollLeft.value = getSlideOffset(); | ||||
| 
 | ||||
|   // 禁用过渡效果,实现平滑拖动 | ||||
|   if (carouselTrack.value) { | ||||
|     carouselTrack.value.style.transition = "none"; | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
| // 处理鼠标/触摸移动事件 | ||||
| const handleDragMove = (e) => { | ||||
|   if (!isDragging.value) return; | ||||
|   e.preventDefault(); | ||||
| 
 | ||||
|   const x = e.type === "mousemove" ? e.pageX : e.touches[0].pageX; | ||||
|   const walk = startX.value - x; | ||||
| 
 | ||||
|   if (carouselTrack.value) { | ||||
|     carouselTrack.value.style.transform = `translateX(-${scrollLeft.value + walk | ||||
|       }px)`; | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
| // 处理鼠标/触摸释放事件 | ||||
| const handleDragEnd = (e) => { | ||||
|   if (!isDragging.value) return; | ||||
|   isDragging.value = false; | ||||
| 
 | ||||
|   if (carouselTrack.value) { | ||||
|     // 恢复过渡效果 | ||||
|     carouselTrack.value.style.transition = "transform 0.5s ease-in-out"; | ||||
| 
 | ||||
|     const x = e.type === "mouseup" ? e.pageX : e.changedTouches[0].pageX; | ||||
|     const walk = startX.value - x; | ||||
| 
 | ||||
|     // 获取单个项目的宽度 | ||||
|     const firstItem = carouselTrack.value.querySelector(".carousel-item"); | ||||
|     if (!firstItem) return; | ||||
| 
 | ||||
|     const itemWidth = firstItem.offsetWidth; | ||||
|     const itemMargin = parseInt(window.getComputedStyle(firstItem).marginRight); | ||||
|     const totalWidth = itemWidth + itemMargin; | ||||
| 
 | ||||
|     // 根据滑动距离决定是否切换到下一个/上一个 | ||||
|     if (Math.abs(walk) > totalWidth / 3) { | ||||
|       if (walk > 0) { | ||||
|         handleNext(); | ||||
|       } else { | ||||
|         handlePrev(); | ||||
|       } | ||||
|     } else { | ||||
|       // 如果滑动距离不够,回到当前位置 | ||||
|       carouselTrack.value.style.transform = `translateX(-${getSlideOffset()}px)`; | ||||
|     } | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
| // 导入图片 | ||||
| import carouselShow1 from "@/assets/image/companyprofil/carouselShow-1.png"; | ||||
| import carouselShow2 from "@/assets/image/companyprofil/carouselShow-2.png"; | ||||
| import carouselShow3 from "@/assets/image/companyprofil/carouselShow-3.png"; | ||||
| import carouselShow4 from "@/assets/image/companyprofil/carouselShow-4.png"; | ||||
| import carouselShow5 from "@/assets/image/companyprofil/carouselShow-5.png"; | ||||
| 
 | ||||
| const state = reactive({ | ||||
|   marqueeArr: [ | ||||
|     { | ||||
|       title: t('companyprofil.news.carousel.item1.title'), | ||||
|       subTitle: t('companyprofil.news.carousel.item1.desc'), | ||||
|       imgUrl: carouselShow1, | ||||
|     }, | ||||
|     { | ||||
|       title: t('companyprofil.news.carousel.item2.title'), | ||||
|       subTitle: t('companyprofil.news.carousel.item2.desc'), | ||||
|       imgUrl: carouselShow2, | ||||
|     }, | ||||
|     { | ||||
|       title: t('companyprofil.news.carousel.item3.title'), | ||||
|       subTitle: t('companyprofil.news.carousel.item3.desc'), | ||||
|       imgUrl: carouselShow3, | ||||
|     }, | ||||
|     { | ||||
|       title: t('companyprofil.news.carousel.item4.title'), | ||||
|       subTitle: t('companyprofil.news.carousel.item4.desc'), | ||||
|       imgUrl: carouselShow4, | ||||
|     }, | ||||
|     { | ||||
|       title: t('companyprofil.news.carousel.item5.title'), | ||||
|       subTitle: t('companyprofil.news.carousel.item5.desc'), | ||||
|       imgUrl: carouselShow5, | ||||
|     }, | ||||
|   ], | ||||
| }); | ||||
| 
 | ||||
| const carouselTrack = ref(null); | ||||
| const currentIndex = ref(0); | ||||
| 
 | ||||
| const getVisibleItems = () => { | ||||
|   const items = state.marqueeArr; | ||||
|   // 前后各复制一组,实现无缝循环 | ||||
|   return [...items, ...items]; | ||||
| }; | ||||
| 
 | ||||
| // 计算实际滑动距离 | ||||
| const getSlideOffset = () => { | ||||
|   if (!carouselTrack.value) return 0; | ||||
| 
 | ||||
|   const firstItem = carouselTrack.value.querySelector(".carousel-item"); | ||||
|   if (!firstItem) return 0; | ||||
| 
 | ||||
|   const itemWidth = firstItem.offsetWidth; | ||||
|   const itemMargin = parseInt(window.getComputedStyle(firstItem).marginRight); | ||||
|   const totalWidth = itemWidth + itemMargin; | ||||
| 
 | ||||
|   return currentIndex.value * totalWidth; | ||||
| }; | ||||
| 
 | ||||
| // 定义 resize 处理函数 | ||||
| const handleResize = () => { | ||||
|   if (carouselTrack.value) { | ||||
|     carouselTrack.value.style.transform = `translateX(-${getSlideOffset()}px)`; | ||||
|   } | ||||
| }; | ||||
| const handleCarouselClick = (item, event) => { | ||||
|   // 检查事件类型是否为点击 | ||||
|   if (event.type === "click") { | ||||
|     event.stopPropagation(); // 阻止事件传播 | ||||
|     event.preventDefault(); // 阻止默认行为 | ||||
|     console.log(item); | ||||
|     router.push({ | ||||
|       path: "/companyprofildetail", | ||||
|       query: { | ||||
|         title: item.title, | ||||
|       }, | ||||
|     }); | ||||
|   } | ||||
| }; | ||||
| onUnmounted(() => { | ||||
|   ctx?.revert(); // <- Easy Cleanup! | ||||
| }); | ||||
| import { useAuth } from "@/store/auth/index.js"; | ||||
| const { clickSendCode, telNum, code, showTextCode, clickLogin } = useAuth(); | ||||
| </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" class="height-full"> | ||||
|     <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"> | ||||
|         {{ t('companyprofil.slogan.title1') }} | ||||
|       </div> | ||||
|       <div class="absolute top-320px left-510px text-[#10253E] text-[54px] font-bold text-animate"> | ||||
|         {{ t('companyprofil.slogan.title2') }} | ||||
|       </div> | ||||
|       <div class="absolute top-420px left-510px text-[#8B59F7] text-[20px] w-[535px] text-animate"> | ||||
|         {{ t('companyprofil.slogan.desc') }} | ||||
|       </div> | ||||
|     </div> | ||||
|     <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="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"> | ||||
|           {{ t('companyprofil.intro.label') }} | ||||
|         </div> | ||||
|         <div class="pl-[505px] pr-[480px] flex"> | ||||
|           <div class="w-[411px] mr-[38px] text-animate"> | ||||
|             <div class="text-[#10253E] text-[40px]"> | ||||
|               {{ t('companyprofil.intro.title1') }} | ||||
|             </div> | ||||
|             <div class="text-[#10253E] text-[40px]"> | ||||
|               {{ t('companyprofil.intro.title2') }} | ||||
|             </div> | ||||
|             <div class="text-[#455363] text-[16px] mt-[56px]"> | ||||
|               {{ t('companyprofil.intro.desc') }} | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <div class="text-[#10253E] text-[20px] image-animate"> | ||||
|             <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"> | ||||
|           {{ t('companyprofil.team.label') }} | ||||
|         </div> | ||||
|         <div class="pl-[505px] pr-[490px] flex z-3"> | ||||
|           <div class="w-[412px] mr-[40px] text-animate"> | ||||
|             <div class="text-[#10253E] text-[40px]"> | ||||
|               {{ t('companyprofil.team.title1') }} | ||||
|             </div> | ||||
|             <div class="text-[#10253E] text-[40px]"> | ||||
|               {{ t('companyprofil.team.title2') }} | ||||
|             </div> | ||||
|             <div class="mt-[93px]"> | ||||
|               <img class="w-[58px] h-[58px]" src="@/assets/image/cl.png" alt="cl" /> | ||||
|               <div class="text-[#10253E] text-[18px] mt-[20px] font-bold relative"> | ||||
|                 <n-divider class="absolute left-[-23px] top-[6px]" style=" | ||||
|                     background-color: #8b59f7; | ||||
|                   " vertical />{{ t('companyprofil.team.features.global.title') }} | ||||
|               </div> | ||||
|               <div class="text-[#455363] text-[16px]"> | ||||
|                 {{ t('companyprofil.team.features.global.desc') }} | ||||
|               </div> | ||||
|             </div> | ||||
|             <div class="mt-[68px]"> | ||||
|               <img class="w-[58px] h-[50px]" src="@/assets/image/heart.png" alt="cl" /> | ||||
|               <div class="text-[#10253E] text-[18px] mt-[20px] font-bold relative"> | ||||
|                 <n-divider class="absolute left-[-23px] top-[6px]" style=" | ||||
|                     background-color: #8b59f7; | ||||
|                   " vertical />{{ t('companyprofil.team.features.fans.title') }} | ||||
|               </div> | ||||
|               <div class="text-[#455363] text-[16px]"> | ||||
|                 {{ t('companyprofil.team.features.fans.desc') }} | ||||
|               </div> | ||||
|             </div> | ||||
|             <div class="mt-[65px]"> | ||||
|               <img class="w-[54px] h-[52px]" src="@/assets/image/3p.png" alt="cl" /> | ||||
|               <div class="text-[#10253E] text-[18px] mt-[20px] font-bold relative"> | ||||
|                 <n-divider class="absolute left-[-23px] top-[6px]" style=" | ||||
|                     background-color: #8b59f7; | ||||
|                   " vertical />{{ t('companyprofil.team.features.talent.title') }} | ||||
|               </div> | ||||
|               <div class="text-[#455363] text-[16px]"> | ||||
|                 {{ t('companyprofil.team.features.talent.desc') }} | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
| 
 | ||||
|           <div class="text-[#455363] text-[16px] flex-1 image-animate"> | ||||
|             <div> | ||||
|               {{ t('companyprofil.team.desc') }} | ||||
|             </div> | ||||
|             <img class="w-[465px] h-[625px] mt-[80px]" src="@/assets/image/randg.png" alt="cl" /> | ||||
|           </div> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div class="content3 relative bg-[#fff] pt-[185px] pb-[158px] overflow-hidden"> | ||||
|         <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 /> | ||||
|         <img class="absolute top-[95px] z-3 w-[800px] h-[163px] right-[0px] image-animate " 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="text-[#8B59F7] text-[16px]"> | ||||
|             {{ t('companyprofil.achievement.label') }} | ||||
|           </div> | ||||
|           <div class="text-[#10253E] text-[40px]"> | ||||
|             {{ t('companyprofil.achievement.title') }} | ||||
|           </div> | ||||
|           <div class="text-[#455363] w-[748px] text-[16px] mt-[30px]"> | ||||
|             {{ t('companyprofil.achievement.desc') }} | ||||
|           </div> | ||||
|         </div> | ||||
|         <div class="relative pl-[505px] pr-[490px] flex z-4 mt-[100px]"> | ||||
|           <div class="w-[419px] mr-[30px] flex flex-col justify-center text-animate"> | ||||
|             <div class="text-[#10253E] text-[22px]">{{ t('companyprofil.achievement.certification.title1') }}</div> | ||||
|             <div class="text-[#10253E] text-[22px]">{{ t('companyprofil.achievement.certification.title2') }}</div> | ||||
|             <div class="text-[#455363] text-[16px] mt-[30px]"> | ||||
|               {{ t('companyprofil.achievement.certification.desc') }} | ||||
|             </div> | ||||
|           </div> | ||||
|           <div class="flex image-animate"> | ||||
|             <img class="w-[465px] h-[493px]" src="@/assets/image/btable.png" alt="cl" /> | ||||
|           </div> | ||||
|         </div> | ||||
|         <div class="relative pl-[505px] pr-[490px] flex z-4 mt-[85px]"> | ||||
|           <div class="w-[419px] mr-[30px] flex flex-col justify-center text-animate"> | ||||
|             <div class="text-[#10253E] text-[22px]">{{ t('companyprofil.achievement.platform.title1') }}</div> | ||||
|             <div class="text-[#10253E] text-[22px]">{{ t('companyprofil.achievement.platform.title2') }}</div> | ||||
|             <div class="text-[#455363] text-[16px] mt-[30px]"> | ||||
|               {{ t('companyprofil.achievement.platform.desc') }} | ||||
|             </div> | ||||
|           </div> | ||||
|           <div class="flex image-animate"> | ||||
|             <img class="w-[465px] h-[369px]" src="@/assets/image/huang.png" alt="cl" /> | ||||
|           </div> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div class="content4 relative bg-[#fff]  overflow-hidden"> | ||||
|         <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="relative pl-[505px] pr-[490px] flex z-3 mt-[130px] z-4 flex-col text-animate"> | ||||
|           <div class="text-[#8B59F7] text-[16px]"> | ||||
|             {{ t('companyprofil.news.label') }} | ||||
|           </div> | ||||
|           <div class="text-[#10253E] text-[40px]"> | ||||
|             {{ t('companyprofil.news.title') }} | ||||
|           </div> | ||||
|           <div class="text-[#455363] w-[748px] text-[16px] mt-[30px]"> | ||||
|             {{ t('companyprofil.news.desc') }} | ||||
|           </div> | ||||
|           <div class="w-full mt-[56px] flex flex-wrap justify-end"> | ||||
|             <div class="flex flex-wrap mr-[20px]"> | ||||
|               <div class="arrow-btn" @click="handlePrev"> | ||||
|                 <img class="w-[38px] h-[38px]" src="@/assets/image/companyprofil/icon-left.png" /> | ||||
|               </div> | ||||
|               <div class="arrow-btn ml-[25px]" @click="handleNext"> | ||||
|                 <img class="w-[38px] h-[38px]" src="@/assets/image/companyprofil/icon-right.png" /> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
| 
 | ||||
|         <div class="pt-[73px] pb-[103px] carousel-container px-[495px] z-14"> | ||||
|           <div ref="carouselTrack" class="carousel-track " :style="{ | ||||
|             transform: `translateX(-${getSlideOffset()}px)`, | ||||
|           }" @mousedown="handleDragStart" @mousemove="handleDragMove" @mouseup="handleDragEnd" | ||||
|             @mouseleave="handleDragEnd" @touchstart="handleDragStart" @touchmove="handleDragMove" | ||||
|             @touchend="handleDragEnd"> | ||||
|             <div v-for="(item, idx) in getVisibleItems()" :key="idx" class="carousel-item cursor-pointer" | ||||
|               @click="handleCarouselClick(item, $event)"> | ||||
|               <img class="carousel-image" :src="item.imgUrl" /> | ||||
|               <div class="carousel-content"> | ||||
|                 <div class="carousel-title"> | ||||
|                   <div>{{ item.title }}</div> | ||||
|                 </div> | ||||
|                 <div class="carousel-subtitle"> | ||||
|                   <div>{{ item.subTitle }}</div> | ||||
|                 </div> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   </main> | ||||
|   <footer> | ||||
|     <div class="footer-content"> | ||||
|       <img class="copyright" src="@/assets/image/cp.png" alt="logo" /> | ||||
|     </div> | ||||
|   </footer> | ||||
|   <div class="box-border relative w-screen min-h-screen" style=""></div> | ||||
| </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 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; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .head { | ||||
|   width: 100%; | ||||
|   background-color: #f8f9ff; | ||||
| 
 | ||||
|   img { | ||||
|     width: 100%; | ||||
|     height: 100%; | ||||
|     object-fit: cover; | ||||
|     image-rendering: -webkit-optimize-contrast; | ||||
|     image-rendering: crisp-edges; | ||||
|     -webkit-backface-visibility: hidden; | ||||
|     backface-visibility: hidden; | ||||
|     transform: translateZ(0); | ||||
|     -webkit-font-smoothing: antialiased; | ||||
|     -moz-osx-font-smoothing: grayscale; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 482px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
| } | ||||
| 
 | ||||
| .divider2 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 720px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
|   background-image: linear-gradient(to bottom, | ||||
|       #e6eaee 50%, | ||||
|       transparent 50%); | ||||
|   background-size: 1px 12px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) | ||||
|   background-repeat: repeat-y; | ||||
| } | ||||
| 
 | ||||
| .divider3 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 952px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
|   background-image: linear-gradient(to bottom, | ||||
|       #e6eaee 50%, | ||||
|       transparent 50%); | ||||
|   background-size: 1px 12px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) | ||||
|   background-repeat: repeat-y; | ||||
| } | ||||
| 
 | ||||
| .divider4 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 1182px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
|   background-image: linear-gradient(to bottom, | ||||
|       #e6eaee 50%, | ||||
|       transparent 50%); | ||||
|   background-size: 1px 15px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) | ||||
|   background-repeat: repeat-y; | ||||
| } | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 1406px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
| } | ||||
| 
 | ||||
| .footer-content { | ||||
|   height: 90px; | ||||
|   display: flex; | ||||
|   justify-content: center; | ||||
|   align-items: center; | ||||
| 
 | ||||
|   .copyright { | ||||
|     width: 232px; | ||||
|     height: 22pxpx; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .carousel-container { | ||||
|   width: 100%; | ||||
|   overflow: hidden; | ||||
|   position: relative; | ||||
| } | ||||
| 
 | ||||
| .arrow-btn { | ||||
|   cursor: pointer; | ||||
| } | ||||
| 
 | ||||
| .carousel-track { | ||||
|   display: flex; | ||||
|   transition: transform 0.5s ease-in-out; | ||||
|   will-change: transform; | ||||
| } | ||||
| 
 | ||||
| .carousel-item { | ||||
|   width: 445px; | ||||
|   height: 444px; | ||||
|   background-color: #fff; | ||||
|   margin-right: 28px; | ||||
|   flex: 0 0 auto; | ||||
|   display: block; | ||||
|   padding: 8px 8px 18px 8px; | ||||
|   border-radius: 12px; | ||||
|   box-shadow: 0 3px 14px 1px rgba(0, 0, 0, 0.16); | ||||
|   will-change: transform, opacity; // 优化动画性能 | ||||
| } | ||||
| 
 | ||||
| .carousel-image { | ||||
|   width: 428px; | ||||
|   height: 259px; | ||||
|   object-fit: cover; | ||||
|   display: block; | ||||
| } | ||||
| 
 | ||||
| .carousel-content { | ||||
|   padding: 0 23px 0 23px; | ||||
|   margin-top: 10px; | ||||
| } | ||||
| 
 | ||||
| .carousel-title { | ||||
|   font-size: 20px; | ||||
|   font-weight: 500; | ||||
|   display: -webkit-box; | ||||
|   -webkit-line-clamp: 1; | ||||
|   -webkit-box-orient: vertical; | ||||
|   overflow: hidden; | ||||
|   text-overflow: ellipsis; | ||||
|   line-height: 1.5; | ||||
|   max-height: calc(1.5em * 5); | ||||
| } | ||||
| 
 | ||||
| .carousel-subtitle { | ||||
|   color: #455363; | ||||
|   margin-top: 5px; | ||||
|   font-size: 16px; | ||||
|   display: -webkit-box; | ||||
|   -webkit-line-clamp: 5; | ||||
|   -webkit-box-orient: vertical; | ||||
|   overflow: hidden; | ||||
|   text-overflow: ellipsis; | ||||
|   line-height: 1.5; | ||||
|   max-height: calc(1.5em * 5); | ||||
| } | ||||
| 
 | ||||
| // 添加一个通用的溢出控制类 | ||||
| .overflow-hidden { | ||||
|   overflow: hidden; | ||||
| } | ||||
| 
 | ||||
| // 为所有可能需要动画的容器添加溢出隐藏 | ||||
| [ref*="moveRef"] { | ||||
|   position: relative; | ||||
| } | ||||
| </style> | ||||
| <style scoped lang="scss"></style> | ||||
|  | ||||
| @ -1,470 +1,9 @@ | ||||
| <script setup> | ||||
| import { useAuth } from "@/store/auth/index.js"; | ||||
| const { clickSendCode, telNum, code, showTextCode, clickLogin } = useAuth(); | ||||
| </script> | ||||
| <template> | ||||
|   <div class="page-container"> | ||||
|     <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> | ||||
|       <section | ||||
|         className="section-first" | ||||
|         v-if="state.pageTitle === '实现技术突破,引领文艺创作技术革新'" | ||||
|         style="background: #fff" | ||||
|       > | ||||
|         <div class="flex flex-wrap justify-center"> | ||||
|           <div | ||||
|             class="w-full title mt-[298px] px-[180px] text-center div-indent" | ||||
|           > | ||||
|             实现技术突破,引领文艺创作技术革新 | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full text-center mt-[28px] text-[#455363] text-[40px] div-indent" | ||||
|           > | ||||
|             2025年02月07日 12时00分 | ||||
|           </div> | ||||
|           <div class="mt-[63px] overflow-hidden div-indent"> | ||||
|             <img | ||||
|               class="w-[1625px] h-[1003px]" | ||||
|               src="@/assets/image/companyprofil/carouselShow-1.png" | ||||
|             /> | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full px-[188px] text-[#455363] text-[40px] div-indent mt-[118px] mb-[275px]" | ||||
|           > | ||||
|             <div> | ||||
|               在数字化浪潮以前所未有的态势席卷文艺领域的当下,文艺创作正经历着深刻变革。FiEE凭借着团队持之以恒的努力与创新精神,在文艺创作技术领域取得了具有里程碑意义的重大突破。 | ||||
|             </div> | ||||
|             <div> | ||||
|               历经无数个日夜的艰苦攻坚,FiEE自主研发的新一代智能创作辅助系统正式上线,宛如一颗冉冉升起的璀璨新星,为文艺创作开辟了全新的发展路径,给整个行业带来了前所未有的变革与机遇。 | ||||
|             </div> | ||||
|             <div> | ||||
|               研发过程中,技术团队遭遇了诸多棘手难题。在海量文艺作品数据的收集环节,需从不同年代、不同风格、不同类型的文艺作品中获取数据,涵盖古今中外的文学名著、影视佳作、音乐经典等,这些数据来源广泛且格式多样,收集难度极大。 | ||||
|               整理与分析时,既要确保数据的准确性和完整性,又要对不同类型的数据进行分类整合,以便后续的深度挖掘。 | ||||
|             </div> | ||||
|             <div> | ||||
|               人工智能算法的优化也绝非易事,团队需要不断调整算法参数,使其能够精准地从海量数据中提取有价值的信息。大数据模型的搭建更是复杂,要考虑到模型的稳定性、可扩展性以及与其他技术的兼容性。 | ||||
|             </div> | ||||
|             <div> | ||||
|               团队成员们查阅了海量的国内外资料,从前沿学术论文到行业实践案例,不放过任何一个可能的灵感来源。进行了无数次的实验和模拟,每一次实验都可能面临失败,但他们从未放弃,不断优化方案。 | ||||
|             </div> | ||||
|             <div> | ||||
|               比如在处理不同类型文艺作品数据的兼容性时,团队创新性地采用了多维度数据分类算法。这种算法通过对数据的时间维度、风格维度、题材维度等多个角度进行分析,将看似杂乱无章的数据进行有效分类,确保了数据的精准分析和利用,为后续的智能创作支持奠定了坚实基础。 | ||||
|               该智能创作辅助系统整合了人工智能、大数据等前沿技术,为创作者提供了全方位、智能化的创作支持。通过对海量文艺作品数据的深度挖掘与分析,系统能够精准洞察当下文艺创作的趋势与热点。 | ||||
|             </div> | ||||
|             <div> | ||||
|               在提高创作效率方面,系统的人工智能技术展现出强大实力。传统创作方式可能需要花费数月时间构思框架,而使用该系统,仅需几天时间就能生成初步框架,创作者只需在此基础上进行细节完善,大大缩短了创作周期。 | ||||
|             </div> | ||||
|             <div> | ||||
|               公司技术研发团队负责人在发布会上难掩激动之情:"这次技术突破是我们团队长期以来辛勤付出的结晶,也是FiEE对文艺创作技术革新的一次大胆尝试。我们深知,在科技飞速发展的今天,只有不断创新,才能为文艺创作者提供更强大的创作工具,推动文艺创作朝着高质量、高效率的方向发展。" | ||||
|             </div> | ||||
|             <div> | ||||
|               业内专家评价道:"FiEE的这一技术突破,无疑为文艺创作领域注入了新的活力。它不仅提升了创作效率,更为创作者带来了全新的创作思路,为整个行业的数字化转型提供了宝贵的经验和借鉴。" | ||||
|             </div> | ||||
|             <div> | ||||
|               此次技术突破,使FiEE在文艺科技领域的竞争力大幅提升,成为行业内的技术引领者。未来,FiEE将继续加大技术研发投入,广纳人才,不断探索创新,致力于为文艺产业的数字化转型提供更多、更优质的技术支持,推动文艺创作迈向新的高峰。 | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <section | ||||
|         className="section-sec" | ||||
|         v-if="state.pageTitle.includes('全球化战略升级')" | ||||
|         style="background: #fff" | ||||
|       > | ||||
|         <div class="flex flex-wrap justify-center"> | ||||
|           <div | ||||
|             class="w-full title mt-[298px] px-[180px] text-center div-indent" | ||||
|           > | ||||
|             全球化战略升级,FiEE与30+国际平台达成战略合作,构建文艺传播新矩阵 | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full text-center mt-[28px] text-[#455363] text-[40px] div-indent" | ||||
|           > | ||||
|             2025年02月10日 10时30分 | ||||
|           </div> | ||||
|           <div class="mt-[63px] overflow-hidden div-indent"> | ||||
|             <img | ||||
|               class="w-[1625px] h-[1003px]" | ||||
|               src="@/assets/image/companyprofil/carouselShow-2.png" | ||||
|             /> | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full px-[188px] text-[#455363] text-[40px] div-indent mt-[118px] mb-[275px]" | ||||
|           > | ||||
|             <div> | ||||
|               在全球文化交融以前所未有的迅猛之势加速推进的时代大背景下,文艺领域已然成为文化交流与创新的前沿阵地。作为文艺行业的领航者,FiEE | ||||
|               以敏锐的战略眼光和果敢的行动力,积极投身于这场全球文化交流的浪潮之中。 | ||||
|             </div> | ||||
|             <div> | ||||
|               近日,FiEE 振奋人心地宣布与 TikTok、Instagram等 30 | ||||
|               余家国际头部自媒体平台达成深度战略合作,同时正式启动具有深远意义的 | ||||
|               “文艺无界计划”,矢志破除地域之间的文化藩篱,全力以赴助力文艺创作者登上广阔无垠的世界舞台。此次 | ||||
|               FiEE 与全球 30 | ||||
|               余家顶尖平台的深度携手,堪称一场全方位、深层次的资源整合与协同创新的盛会。 | ||||
|             </div> | ||||
|             <div> | ||||
|               在社交媒体领域,与 TikTok 的合作堪称一大亮点。TikTok | ||||
|               以其独特的短视频生态和强大的算法推荐系统,在全球范围内吸引了数十亿用户。借助这一平台,FiEE | ||||
|               能够将文艺创作者的精彩作品以极具感染力的短视频形式,迅速精准地推送给全球各地对文艺感兴趣的用户,轻松打破地域限制,引发全球范围内的热烈互动与关注。 | ||||
|             </div> | ||||
|             <div> | ||||
|               Instagram | ||||
|               则凭借其精美的视觉呈现和活跃的社交氛围,为各类文艺作品搭建了一个绝佳的展示橱窗。在这里,创作者们的作品能够得到高水准的展示,收获海量粉丝的关注与点赞,极大地提升作品的曝光量与影响力,让艺术之美在全球范围内广泛传播。在垂直社区方面,与 | ||||
|               ArtStation | ||||
|               等专业平台的合作,为不同文艺领域的创作者们营造了一个专业、纯粹的交流与展示空间。 | ||||
|             </div> | ||||
|             <div> | ||||
|               为确保 “文艺无界计划” 能够高效、有序地实施,FiEE | ||||
|               制定了一系列详尽且切实可行的策略与措施。在内容创作环节,FiEE | ||||
|               将邀请国际知名的文艺专家、创作者开展线上线下相结合的专业培训与指导课程,帮助创作者深入了解国际市场的审美偏好、文化需求以及流行趋势,从而提升作品的国际传播力。 | ||||
|             </div> | ||||
|             <div> | ||||
|               在推广运营方面,FiEE | ||||
|               将整合各方优势资源,为创作者量身定制全方位、立体化的推广方案。一方面,积极举办线上创作比赛等活动,吸引全球用户的目光,迅速提升创作者的知名度与影响力;另一方面,充分利用社交媒体平台的广告投放、话题营销、达人合作等手段,精准推送创作者的作品,进一步扩大作品的传播范围,让更多人能够欣赏到优秀的文艺创作。 | ||||
|             </div> | ||||
|             <div> | ||||
|               可以预见,对于广大文艺创作者而言,此次合作无疑是一次千载难逢的发展机遇。他们将有机会与国际顶尖的艺术家、创作者进行深度交流与合作,接触到全球最前沿的创作理念与技术,从而拓宽自己的创作视野,提升创作水平。同时,通过多元化的平台矩阵,他们的作品能够获得前所未有的曝光量与认可度,实现商业价值的最大化,为自己的艺术生涯开辟更为广阔的发展空间。 | ||||
|             </div> | ||||
|             <div> | ||||
|               展望未来,FiEE | ||||
|               将坚定不移地继续深化与国际平台的合作,不断优化和完善 | ||||
|               “文艺无界计划”,持续为文艺创作者提供更加优质、全面、高效的服务,助力他们在国际舞台上绽放出更加耀眼夺目的光芒,为推动全球文化的交流、融合与繁荣贡献更多的智慧与力量。 | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <section | ||||
|         className="section-third" | ||||
|         v-if="state.pageTitle.includes('助力文艺创作者')" | ||||
|         style="background: #fff" | ||||
|       > | ||||
|         <div class="flex flex-wrap justify-center"> | ||||
|           <div | ||||
|             class="w-full title mt-[298px] px-[180px] text-center div-indent" | ||||
|           > | ||||
|             助力文艺创作者,FiEE 发布 “AI × 短视频” 全链路解决方案 | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full text-center mt-[28px] text-[#455363] text-[40px] div-indent" | ||||
|           > | ||||
|             2025年02月14日 12时30分 | ||||
|           </div> | ||||
|           <div class="mt-[63px] overflow-hidden div-indent"> | ||||
|             <img | ||||
|               class="w-[1625px] h-[1003px]" | ||||
|               src="@/assets/image/companyprofil/carouselShow-3.png" | ||||
|             /> | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full px-[188px] text-[#455363] text-[40px] div-indent mt-[118px] mb-[275px]" | ||||
|           > | ||||
|             <div> | ||||
|               对于文艺创作者而言,创作瓶颈与效率低下是横亘在前行道路上的两座大山。构思一个吸引人的短视频脚本,常常需要耗费大量时间和精力,创作者们不仅要绞尽脑汁思考独特的创意,还要兼顾受众喜好和市场趋势。 | ||||
|             </div> | ||||
|             <div> | ||||
|               作品完成后的传播与推广,同样是一道难以跨越的鸿沟。在信息爆炸的时代,如何让自己的作品在海量内容中脱颖而出,精准触达目标受众,成为创作者们日思夜想的难题。 | ||||
|             </div> | ||||
|             <div> | ||||
|               传统的传播方式犹如撒网捕鱼,精准度严重不足,大量优质的文艺内容在传播过程中石沉大海,难以被真正感兴趣的受众发现。而且,用户互动性的欠缺也使得创作者无法深入挖掘用户需求,难以与受众建立起紧密的情感连接,作品难以真正 | ||||
|               “活” 起来,在传播的浪潮中显得孤立无援。 | ||||
|             </div> | ||||
|             <div> | ||||
|               在科技飞速发展的当下,人工智能与短视频行业正以前所未有的速度改变着文艺创作与传播的格局。 | ||||
|             </div> | ||||
|             <div> | ||||
|               作为文艺领域的创新先锋,FiEE | ||||
|               紧跟时代步伐,积极探索技术与文艺的深度融合,今日正式发布 “AI × | ||||
|               短视频” 全链路解决方案,为文艺行业带来了一场革命性的变革。 | ||||
|             </div> | ||||
|             <div> | ||||
|               该解决方案集成了多项前沿 AI | ||||
|               技术,具有多方面的显著优势。在内容创作环节,AI | ||||
|               智能脚本生成工具能够根据创作者输入的主题、风格、受众等关键信息,快速生成创意十足的脚本。通过对海量优秀短视频脚本和文艺作品的学习,AI | ||||
|               不仅能提供新颖的故事框架,还能精准匹配符合主题的情节与台词,大大缩短了创作周期。 | ||||
|             </div> | ||||
|             <div> | ||||
|               在内容传播与运营方面,AI | ||||
|               大数据分析技术让短视频的推广更加精准有效。通过对用户的浏览历史、点赞评论行为、关注列表等多维度数据进行深度分析,系统能够精准洞察用户的兴趣偏好和需求,将文艺创作者的作品推送给真正感兴趣的受众群体。该解决方案的应用场景广泛,无论是专业的文艺创作者,还是怀揣文艺梦想的业余爱好者,都能从中受益。 | ||||
|             </div> | ||||
|             <div> | ||||
|               专业创作者可以借助 AI | ||||
|               技术突破创作瓶颈,提升创作效率,创作出更具创新性和影响力的作品;业余爱好者则可以通过该方案降低创作门槛,轻松实现自己的创作想法,享受创作的乐趣。FiEE | ||||
|               相关负责人表示:“我们一直关注着文艺创作者的需求和痛点,希望通过‘AI | ||||
|               × | ||||
|               短视频’全链路解决方案,为他们提供全方位的支持和帮助。这不仅是一次技术的创新应用,更是我们助力文艺行业发展的一次重要实践。我们相信,在 | ||||
|               AI | ||||
|               技术的加持下,文艺创作者们能够创作出更多优秀的作品,让文艺之光照亮更广阔的天地。” | ||||
|             </div> | ||||
|             <div> | ||||
|               展望未来,FiEE 将持续投入研发力量,不断优化和完善 “AI × 短视频” | ||||
|               全链路解决方案,探索更多 AI | ||||
|               技术在文艺领域的应用场景,加强与行业伙伴的合作,共同推动文艺创作与传播的创新发展,为文艺创作者打造更加优质、高效的创作环境,助力文艺行业迈向新的高峰。 | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <section | ||||
|         className="section-four" | ||||
|         v-if="state.pageTitle.includes('培育文艺领域明日之星')" | ||||
|         style="background: #fff" | ||||
|       > | ||||
|         <div class="flex flex-wrap justify-center"> | ||||
|           <div | ||||
|             class="w-full title mt-[298px] px-[180px] text-center div-indent" | ||||
|           > | ||||
|             FiEE启动 18 个月艺术 KOL 孵化,培育文艺领域明日之星 | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full text-center mt-[28px] text-[#455363] text-[40px] div-indent" | ||||
|           > | ||||
|             2025年02月19日 12时00分 | ||||
|           </div> | ||||
|           <div class="mt-[63px] overflow-hidden div-indent"> | ||||
|             <img | ||||
|               class="w-[1625px] h-[1003px]" | ||||
|               src="@/assets/image/companyprofil/carouselShow-4.png" | ||||
|             /> | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full px-[188px] text-[#455363] text-[40px] div-indent mt-[118px] mb-[275px]" | ||||
|           > | ||||
|             <div> | ||||
|               在文艺产业蓬勃发展的当下,优质内容创作者的重要性愈发凸显。作为行业内的先锋企业,FiEE始终关注着文艺领域的人才培养与发展动态。 | ||||
|             </div> | ||||
|             <div> | ||||
|               今日,FiEE正式宣布启动一项精心筹备长达 18 个月的艺术 KOL | ||||
|               孵化计划,旨在为文艺领域培育一批具有强大影响力的明日之星,推动整个行业的创新发展。随着社交媒体的兴起和内容传播方式的变革,KOL | ||||
|               在文艺领域的传播与推广中扮演着关键角色。他们不仅是优质内容的创作者,更是连接文艺作品与广大受众的桥梁。 | ||||
|             </div> | ||||
|             <div> | ||||
|               然而,培养一位成熟且具有广泛影响力的艺术 KOL | ||||
|               并非一蹴而就,需要系统的规划、专业的指导以及充足的实践机会。FiEE敏锐地洞察到这一市场需求,投入大量资源,精心策划了此次为期 | ||||
|               18 | ||||
|               个月的孵化计划。此次孵化计划目标明确,旨在挖掘并培养一批在文艺领域具有潜力的创作者,帮助他们成长为在国内外具有较高知名度和影响力的艺术 | ||||
|               KOL。 | ||||
|             </div> | ||||
|             <div> | ||||
|               通过这一计划,不仅能够为这些创作者提供广阔的发展空间,还能为文艺市场注入新鲜血液,推动文艺作品的多元化传播。在实施内容上,计划涵盖多个维度,全方位助力创作者成长。在专业培训环节,公司邀请了来自不同艺术领域的知名专家和学者,为创作者们提供系统且深入的课程培训。 | ||||
|             </div> | ||||
|             <div> | ||||
|               这些课程内容丰富,既包括艺术创作技巧的提升,如绘画中的色彩运用、音乐创作中的旋律编排等,也涵盖新媒体运营知识,如社交媒体营销策略、粉丝互动技巧等,以及商业管理方面的课程,帮助创作者了解文艺市场的运作规律,实现作品的商业价值转化。同时,为确保每位创作者都能得到个性化的指导,公司还为他们配备了一对一的导师,导师将根据创作者的特点和需求,提供针对性的建议和帮助。 | ||||
|             </div> | ||||
|             <div> | ||||
|               资源对接也是孵化计划的重要组成部分。FiEE凭借多年在行业内积累的深厚资源和广泛的合作伙伴关系,为创作者搭建了与品牌、媒体、平台等对接的桥梁。创作者们有机会与知名品牌合作,为其创作具有艺术价值的宣传内容;与媒体合作,参与文艺专题报道和节目制作;与各大文艺平台合作,发布自己的作品,扩大作品的传播范围。 | ||||
|             </div> | ||||
|             <div> | ||||
|               FiEE艺术 KOL | ||||
|               孵化项目负责人在启动仪式上表示:“我们坚信,每一位参与孵化计划的创作者都具有无限的潜力。这 | ||||
|               18 | ||||
|               个月的时间,将是他们成长的关键时期。FiEE将全力为他们提供支持和帮助,让他们在艺术创作的道路上越走越远,成为文艺领域的中流砥柱。” | ||||
|             </div> | ||||
|             <div> | ||||
|               展望未来,此次 18 个月艺术 KOL | ||||
|               孵化计划的实施,有望为文艺领域培养出一批具有独特风格和广泛影响力的 | ||||
|               KOL。 | ||||
|             </div> | ||||
|             <div> | ||||
|               他们将通过自己的作品和影响力,吸引更多人关注文艺,推动文艺作品的传播与创新,为文艺产业的繁荣发展贡献重要力量。FiEE也将持续关注创作者的成长,不断优化孵化计划,为文艺领域的人才培养探索更多有效的模式。 | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <section | ||||
|         className="section-five" | ||||
|         v-if="state.pageTitle.includes('多元人才汇聚')" | ||||
|         style="background: #fff" | ||||
|       > | ||||
|         <div class="flex flex-wrap justify-center"> | ||||
|           <div | ||||
|             class="w-full title mt-[298px] px-[180px] text-center div-indent" | ||||
|           > | ||||
|             多元人才汇聚,FiEE 构筑文艺创新发展基石 | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full text-center mt-[28px] text-[#455363] text-[40px] div-indent" | ||||
|           > | ||||
|             2025年02月20日 12时00分 | ||||
|           </div> | ||||
|           <div class="mt-[63px] overflow-hidden div-indent"> | ||||
|             <img | ||||
|               class="w-[1625px] h-[1003px]" | ||||
|               src="@/assets/image/companyprofil/carouselShow-5.png" | ||||
|             /> | ||||
|           </div> | ||||
|           <div | ||||
|             class="w-full px-[188px] text-[#455363] text-[40px] div-indent mt-[118px] mb-[275px]" | ||||
|           > | ||||
|             <div> | ||||
|               在当下文艺行业蓬勃发展、百花齐放的黄金时代,创新俨然成为引领行业持续进步、突破传统格局的关键要素。而追根溯源,人才作为创新的核心驱动力,其重要性不言而喻。 | ||||
|             </div> | ||||
|             <div> | ||||
|               FiEE | ||||
|               深明此理,以海纳百川的胸怀和高瞻远瞩的战略眼光,积极广纳贤才,精心汇聚运营专家、技术精英以及国际顾问,成功打造出一支专业素养过硬、知识结构多元的卓越团队,为公司在文艺领域的创新征程筑牢了坚不可摧的发展根基。 | ||||
|             </div> | ||||
|             <div> | ||||
|               运营专家团队堪称 FiEE | ||||
|               在文艺领域稳健前行的领航灯塔。他们在文艺行业这片广阔天地中深耕多年,凭借丰富的实战经验和对市场的深度理解,练就了敏锐捕捉市场动态的能力,对受众喜好的把握更是精准入微。 | ||||
|             </div> | ||||
|             <div> | ||||
|               他们借助大数据分析和实地市场调研,深入研究不同年龄段、不同地域受众的文化背景和兴趣偏好,精准定位目标受众,为文艺创作者提供极具针对性的创作方向。他们会深入剖析当下的社会热点和观众的精神需求,巧妙融入时代元素,让作品既有深度又具吸引力。通过独特的创意策划,从项目起步阶段就成功吸引观众的目光,为后续的成功奠定坚实基础。 | ||||
|             </div> | ||||
|             <div> | ||||
|               随着科技与文艺的融合趋势愈发显著,技术精英成为 FiEE | ||||
|               创新发展的强劲引擎。 | ||||
|             </div> | ||||
|             <div> | ||||
|               公司积极招徕掌握人工智能、大数据、虚拟现实等前沿技术的专业人才,为文艺创作注入科技活力。在内容创作过程中,这些技术精英充分发挥人工智能辅助创作工具的优势,为文艺创作者提供源源不断的灵感启发。利用虚拟现实(VR)和增强现实(AR)技术,让作品与观众进行深度互动,极大地拓展了文艺作品的表现形式和传播范围。 | ||||
|             </div> | ||||
|             <div> | ||||
|               在全球化的时代浪潮下,国际顾问团队为 FiEE | ||||
|               带来了广阔的全球视野和多元的文化视角。他们来自世界各地,对不同国家和地区的文艺市场规则、审美偏好以及文化差异有着深入的了解。在FiEE将本土优秀文艺作品推向世界的过程中,国际顾问团队发挥着关键作用。这不仅为本土文艺创作者带来了新的创作思路和启发,也提升了FiEE在国际文艺领域的影响力。 | ||||
|             </div> | ||||
|             <div> | ||||
|               正是因为有了运营专家、技术精英和国际顾问等多元人才的汇聚,FiEE得以通过跨界合作与资源整合,突破传统文艺的边界,探索文艺新表达。FiEE与科技企业、时尚品牌、教育机构等展开广泛合作,将文艺与科技、时尚、教育等领域深度融合,创造出一系列新颖的文艺产品和服务。依托前沿技术与精准营销,FiEE | ||||
|               助力众多文艺作品实现了商业价值与社会影响力的双重提升,为文艺的繁荣发展注入了持久动力。 | ||||
|             </div> | ||||
|             <div> | ||||
|               展望未来,FiEE | ||||
|               将继续秉持开放、包容的人才理念,不断完善人才战略,吸引更多优秀人才加入。我们坚信,在多元人才的共同努力下,FiEE | ||||
|               将在文艺创新发展的道路上不断前行,为推动全球文艺事业的繁荣做出更大的贡献。 | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|       </section> | ||||
| 
 | ||||
|       <section | ||||
|         style="background: #fff" | ||||
|         className="flex flex-wrap justify-center" | ||||
|       > | ||||
|         <img | ||||
|           class="w-[580px] h-[55px] my-[85px]" | ||||
|           src="@/assets/image/image-footer.png" | ||||
|           alt="logo" | ||||
|         /> | ||||
|       </section> | ||||
|     </main> | ||||
|   </div> | ||||
|   <div class="box-border relative w-screen min-h-screen" style=""></div> | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { | ||||
|   onUnmounted, | ||||
|   ref, | ||||
|   onMounted, | ||||
|   reactive, | ||||
|   nextTick, | ||||
|   onBeforeMount, | ||||
| } from "vue"; | ||||
| import { useHome } from "@/store/home/index.js"; | ||||
| import { useRoute } from "vue-router"; | ||||
| import { useI18n } from "vue-i18n"; | ||||
|   | ||||
| const { t } = useI18n(); | ||||
| const state = reactive({ | ||||
|   pageTitle: "", | ||||
| }); | ||||
| 
 | ||||
| const { currentTab } = useHome(); | ||||
| const route = useRoute(); | ||||
| onBeforeMount(() => { | ||||
|   state.pageTitle = route.query.title; | ||||
| }); | ||||
| onMounted(() => {}); | ||||
| onUnmounted(() => {}); | ||||
| </script> | ||||
| 
 | ||||
| <style scoped lang="scss"> | ||||
| .page-container { | ||||
|   width: 100%; | ||||
|   overflow-x: hidden; | ||||
|   position: relative; | ||||
| } | ||||
| 
 | ||||
| .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; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .title { | ||||
|   font-size: 85px; | ||||
|   font-weight: 600; | ||||
| } | ||||
| 
 | ||||
| .div-indent { | ||||
|   text-indent: 2em; // Adjust the value as needed for the desired indent | ||||
|   line-height: 75px; | ||||
| } | ||||
| .title { | ||||
|   line-height: 110px; | ||||
|   color: #10253e; | ||||
| } | ||||
| </style> | ||||
| <style scoped lang="scss"></style> | ||||
|  | ||||
| @ -1,106 +1,38 @@ | ||||
| <script setup> | ||||
| import { NCarousel, NDivider, NMarquee, NImage } from 'naive-ui' | ||||
| import { onUnmounted, ref, watch, onMounted } from 'vue'; | ||||
| import { NCarousel } from 'naive-ui' | ||||
| import { onUnmounted, ref, watch } from 'vue'; | ||||
| import gsap from 'gsap'; | ||||
| 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); | ||||
| let scrollTween; | ||||
| let ctx; | ||||
| const { currentTab } = useHome(); | ||||
| let isScrolling = false;  // 添加滚动状态标记 | ||||
| const scrollThreshold = 50;  // 添加滚动阈值 | ||||
| let lastScrollTime = 0;  // 添加最后滚动时间记录 | ||||
| const scrollDownVisible = ref(true); | ||||
| const { t } = useI18n(); | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| const handleTabClick = (tab) => { | ||||
|   currentTab.value = tab; | ||||
|   router.push('/' + tab); | ||||
| } | ||||
| 
 | ||||
| const goToSection = (i) => { | ||||
|   if (scrollTween) { | ||||
|     scrollTween.kill(); | ||||
|   ctx.data.forEach((e) => { | ||||
|     if (e.vars && e.vars.id === 'scrollTween') { | ||||
|       e.kill(); | ||||
|     } | ||||
| 
 | ||||
|   // 防止频繁触发 | ||||
|   const now = Date.now(); | ||||
|   if (now - lastScrollTime < 500) return;  // 500ms 内不重复触发 | ||||
|   lastScrollTime = now; | ||||
| 
 | ||||
|   isScrolling = true; | ||||
|   }); | ||||
|   ctx.add(() => { | ||||
|     scrollTween = gsap.to(window, { | ||||
|       scrollTo: { y: i * window.innerHeight, autoKill: false }, | ||||
|     duration: 0.8,  // 增加动画时间使其更平滑 | ||||
|     ease: "power2.inOut", | ||||
|     onComplete: () => { | ||||
|       scrollTween = null; | ||||
|       isScrolling = false; | ||||
|     }, | ||||
|       duration: 1, | ||||
|       id: 'scrollTween', | ||||
|       onComplete: () => (scrollTween = null), | ||||
|       overwrite: true, | ||||
|     }); | ||||
| }; | ||||
| 
 | ||||
| // 修改handleWheel函数 | ||||
| const handleWheel = (e) => { | ||||
|   if (isScrolling) { | ||||
|     e.preventDefault(); | ||||
|     return; | ||||
|   } | ||||
| 
 | ||||
|   const delta = e.deltaY; | ||||
|   const currentSection = Math.round(window.scrollY / window.innerHeight); | ||||
|   const lastPanel = document.querySelector('.panel:last-child'); | ||||
|   const isInLastPanel = currentSection === 3; | ||||
| 
 | ||||
|   // 在最后一个panel时允许自然滚动 | ||||
|   if (isInLastPanel && lastPanel.scrollHeight > window.innerHeight) { | ||||
|     // 检查是否在panel顶部且向上滚动,或在底部且向下滚动 | ||||
|     if ((lastPanel.scrollTop === 0 && delta < 0) || | ||||
|       (lastPanel.scrollTop + lastPanel.clientHeight >= lastPanel.scrollHeight && delta > 0)) { | ||||
|       // 只有在这些边界条件下才触发页面切换 | ||||
|       if (Math.abs(delta) > scrollThreshold) { | ||||
|         if (delta > 0 && currentSection < 3) { | ||||
|           goToSection(currentSection + 1); | ||||
|         } else if (delta < 0 && currentSection > 0) { | ||||
|           goToSection(currentSection - 1); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     return; // 其他情况允许自然滚动 | ||||
|   } | ||||
| 
 | ||||
|   // 非最后一个panel的处理保持不变 | ||||
|   if (Math.abs(delta) > scrollThreshold) { | ||||
|     if (delta > 0 && currentSection < 3) { | ||||
|       goToSection(currentSection + 1); | ||||
|     } else if (delta < 0 && currentSection > 0) { | ||||
|       goToSection(currentSection - 1); | ||||
|     } | ||||
|   } | ||||
| }; | ||||
| 
 | ||||
| // 监听滚轮事件 | ||||
| onMounted(() => { | ||||
|   window.scrollTo(0, 0); | ||||
|   window.addEventListener('wheel', handleWheel, { passive: false }); | ||||
| }); | ||||
| 
 | ||||
| onUnmounted(() => { | ||||
|   window.removeEventListener('wheel', handleWheel); | ||||
|   ctx?.revert(); | ||||
|   ScrollTrigger.killAll(); | ||||
|   }); | ||||
| }; | ||||
| 
 | ||||
| watch( | ||||
|   [() => transitionState.transitionComplete, main], | ||||
| @ -109,21 +41,6 @@ watch( | ||||
|       ctx = gsap.context((self) => { | ||||
|         const panels = self.selector('.panel'); | ||||
|          | ||||
|         // 为每个面板创建滚动触发器 | ||||
|         panels.forEach((panel, i) => { | ||||
|           ScrollTrigger.create({ | ||||
|             trigger: panel, | ||||
|             start: 'top center', | ||||
|             end: 'bottom center', | ||||
|             onToggle: (self) => { | ||||
|               if (self.isActive && !isScrolling) { | ||||
|                 goToSection(i); | ||||
|               } | ||||
|             }, | ||||
|             preventOverlaps: true, | ||||
|           }); | ||||
|         }); | ||||
| 
 | ||||
|         // 移除之前的渐入动画代码 | ||||
|         panels.forEach((panel, i) => { | ||||
|           // 背景视差 | ||||
| @ -155,6 +72,14 @@ watch( | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
| 
 | ||||
|           // 原有的面板切换逻辑 | ||||
|           ScrollTrigger.create({ | ||||
|             trigger: panel, | ||||
|             start: 'top bottom', | ||||
|             end: '+=200%', | ||||
|             onToggle: (self) => self.isActive && !scrollTween && goToSection(i), | ||||
|           }); | ||||
|         }); | ||||
| 
 | ||||
|         // 修改第二个面板的动画配置 | ||||
| @ -196,338 +121,23 @@ watch( | ||||
|           } | ||||
|         }); | ||||
| 
 | ||||
|         // 修改第三幕的ScrollTrigger配置 | ||||
|         ScrollTrigger.create({ | ||||
|           trigger: panels[2], | ||||
|           start: "top 60%", // 提前触发 | ||||
|           end: "bottom center", | ||||
|           onEnter: () => { | ||||
|             // 初始状态设置 | ||||
|             gsap.set(".content3", { | ||||
|               opacity: 1,  // 容器始终保持可见 | ||||
|               y: 0 | ||||
|           start: 0, | ||||
|           end: 'max', | ||||
|           snap: 1 / (panels.length - 1), | ||||
|         }); | ||||
| 
 | ||||
|             gsap.set([ | ||||
|               ".content3 > div:nth-child(1)", | ||||
|               ".content3 > div:nth-child(2)", | ||||
|               ".content3 > div:nth-child(3)", | ||||
|               ".content3 > .n-marquee" | ||||
|             ], { | ||||
|               opacity: 0, | ||||
|               y: 50 | ||||
|             }); | ||||
|        | ||||
|             const tl = gsap.timeline({ | ||||
|               defaults: { | ||||
|                 duration: 0.8, | ||||
|                 ease: "power2.out" | ||||
|               } | ||||
|             }); | ||||
| 
 | ||||
|             tl.to(".content3 > div:nth-child(1)", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|             }) | ||||
|               .to(".content3 > div:nth-child(2)", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.6") | ||||
|               .to(".content3 > div:nth-child(3)", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.6") | ||||
|               .to(".content3 > .n-marquee", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|                 onStart: () => { | ||||
|                   const marquee = document.querySelector('.content3 > .n-marquee'); | ||||
|                   if (marquee) { | ||||
|                     marquee.style.visibility = 'visible'; | ||||
|                   } | ||||
|                 } | ||||
|               }, "-=0.6"); | ||||
|           }, | ||||
|           onLeave: () => { | ||||
|             const tl = gsap.timeline({ | ||||
|               defaults: { | ||||
|                 duration: 0.3, | ||||
|                 ease: "power2.in" | ||||
|               } | ||||
|             }); | ||||
| 
 | ||||
|             tl.to([ | ||||
|               ".content3 > .n-marquee", | ||||
|               ".content3 > div:nth-child(3)", | ||||
|               ".content3 > div:nth-child(2)", | ||||
|               ".content3 > div:nth-child(1)" | ||||
|             ], { | ||||
|               opacity: 0, | ||||
|               y: -30, | ||||
|               stagger: 0.1 | ||||
|             }); | ||||
|           }, | ||||
|           onEnterBack: () => { | ||||
|             gsap.set(".content3", { | ||||
|               opacity: 1, | ||||
|               y: 0 | ||||
|             }); | ||||
| 
 | ||||
|             gsap.set([ | ||||
|               ".content3 > div:nth-child(1)", | ||||
|               ".content3 > div:nth-child(2)", | ||||
|               ".content3 > div:nth-child(3)", | ||||
|               ".content3 > .n-marquee" | ||||
|             ], { | ||||
|               opacity: 0, | ||||
|               y: -50 | ||||
|             }); | ||||
| 
 | ||||
|             const tl = gsap.timeline({ | ||||
|               defaults: { | ||||
|                 duration: 0.8, | ||||
|                 ease: "power2.out" | ||||
|               } | ||||
|             }); | ||||
| 
 | ||||
|             tl.to(".content3 > div:nth-child(1)", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|             }) | ||||
|               .to(".content3 > div:nth-child(2)", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.6") | ||||
|               .to(".content3 > div:nth-child(3)", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.6") | ||||
|               .to(".content3 > .n-marquee", { | ||||
|                 opacity: 1, | ||||
|                 y: 0, | ||||
|               }, "-=0.6"); | ||||
|           }, | ||||
|           onLeaveBack: () => { | ||||
|             const tl = gsap.timeline({ | ||||
|               defaults: { | ||||
|                 duration: 0.3, | ||||
|                 ease: "power2.in" | ||||
|               } | ||||
|             }); | ||||
| 
 | ||||
|             tl.to([ | ||||
|               ".content3 > .n-marquee", | ||||
|               ".content3 > div:nth-child(3)", | ||||
|               ".content3 > div:nth-child(2)", | ||||
|               ".content3 > div:nth-child(1)" | ||||
|             ], { | ||||
|               opacity: 0, | ||||
|               y: 30, | ||||
|               stagger: 0.1 | ||||
|             }); | ||||
|           } | ||||
|         }); | ||||
| 
 | ||||
|         // 修改第四幕的动画配置 | ||||
|         ScrollTrigger.create({ | ||||
|           trigger: panels[3], | ||||
|           start: "top 80%", | ||||
|           end: "bottom center", | ||||
|           onEnter: () => { | ||||
|             // 进入第四幕时隐藏 | ||||
|             scrollDownVisible.value = false; | ||||
|             // 初始状态设置 | ||||
|             gsap.set(".content4", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               immediateRender: true | ||||
|             }); | ||||
| 
 | ||||
|             // 预先设置所有元素的初始状态 | ||||
|             gsap.set([ | ||||
|               ".content4 > div:nth-child(1)", | ||||
|               ".content4 > div:nth-child(2)", | ||||
|               ".content4 > div:nth-child(3)" | ||||
|             ], { | ||||
|               opacity: 0, | ||||
|               y: 30, | ||||
|               immediateRender: true | ||||
|             }); | ||||
| 
 | ||||
|             // 单独设置卡片的初始状态 | ||||
|             gsap.set(".content4 .container .card", { | ||||
|               opacity: 0, | ||||
|               y: 50, | ||||
|               immediateRender: true | ||||
|             }); | ||||
| 
 | ||||
|             const tl = gsap.timeline({ | ||||
|               defaults: { | ||||
|                 duration: 0.6, | ||||
|                 ease: "power2.out" | ||||
|               } | ||||
|             }); | ||||
| 
 | ||||
|             // 标题动画 | ||||
|             tl.to(".content4 > div:nth-child(1)", { | ||||
|               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"); | ||||
|           }, | ||||
|           onLeave: () => { | ||||
|             // 离开第四幕时显示 | ||||
|             scrollDownVisible.value = true; | ||||
|             gsap.timeline({ | ||||
|               defaults: { | ||||
|                 duration: 0.4, | ||||
|                 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"); | ||||
|           }, | ||||
|           onEnterBack: () => { | ||||
|             // 返回第四幕时隐藏 | ||||
|             scrollDownVisible.value = false; | ||||
|             gsap.set(".content4", { | ||||
|               opacity: 1, | ||||
|               y: 0, | ||||
|               immediateRender: true | ||||
|             }); | ||||
| 
 | ||||
|             gsap.set([ | ||||
|               ".content4 > div:nth-child(1)", | ||||
|               ".content4 > div:nth-child(2)", | ||||
|               ".content4 > div:nth-child(3)" | ||||
|             ], { | ||||
|               opacity: 0, | ||||
|               y: -30, | ||||
|               immediateRender: true | ||||
|             }); | ||||
| 
 | ||||
|             gsap.set(".content4 .container .card", { | ||||
|               opacity: 0, | ||||
|               y: -50, | ||||
|               immediateRender: true | ||||
|             }); | ||||
| 
 | ||||
|             const tl = gsap.timeline({ | ||||
|               defaults: { | ||||
|                 duration: 0.6, | ||||
|                 ease: "power2.out" | ||||
|               } | ||||
|             }); | ||||
| 
 | ||||
|             tl.to(".content4 > div:nth-child(1)", { | ||||
|               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"); | ||||
|           }, | ||||
|           onLeaveBack: () => { | ||||
|             // 向上离开第四幕时显示 | ||||
|             scrollDownVisible.value = true; | ||||
|             gsap.timeline({ | ||||
|               defaults: { | ||||
|                 duration: 0.4, | ||||
|                 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"); | ||||
|           } | ||||
|         }); | ||||
|       }, main.value); | ||||
|     } | ||||
|   }, | ||||
|   { immediate: true } | ||||
| ); | ||||
| 
 | ||||
| onUnmounted(() => { | ||||
|   ctx.revert(); | ||||
|   ScrollTrigger.killAll(); | ||||
| }); | ||||
| </script> | ||||
| 
 | ||||
| <template> | ||||
| @ -536,23 +146,32 @@ watch( | ||||
|       <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  | ||||
|         class="tab-item"  | ||||
|         :class="{ active: currentTab === 'home' }"  | ||||
|         @click="handleTabClick('home')" | ||||
|       > | ||||
|         首页 | ||||
|       </div> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'companyprofil' }" @click="handleTabClick('companyprofil')"> | ||||
|           {{ t('home.nav.company') }} | ||||
|       <div  | ||||
|         class="tab-item"  | ||||
|         :class="{ active: currentTab === 'company' }"  | ||||
|         @click="handleTabClick('company')" | ||||
|       > | ||||
|         公司概况 | ||||
|       </div> | ||||
|         <div class="tab-item" :class="{ active: currentTab === 'business' }" @click="handleTabClick('business')"> | ||||
|           {{ t('home.nav.business') }} | ||||
|       <div  | ||||
|         class="tab-item"  | ||||
|         :class="{ active: currentTab === 'business' }"  | ||||
|         @click="handleTabClick('business')" | ||||
|       > | ||||
|         业务介绍 | ||||
|       </div> | ||||
|     </div> | ||||
|   </header> | ||||
|   <main ref="main"> | ||||
|     <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"> | ||||
|         <img class="carousel-item" src="@/assets/image/banner/cn/b0.png"> | ||||
|         <img class="carousel-img" src="@/assets/image/banner/cn/b1.jpg"> | ||||
|         <img class="carousel-img" src="@/assets/image/banner/cn/b2.jpg"> | ||||
|         <img class="carousel-img" src="@/assets/image/banner/cn/b3.jpg"> | ||||
| @ -561,164 +180,52 @@ watch( | ||||
|     </section> | ||||
| 
 | ||||
|     <section 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: 70px;"> | ||||
|         <img ref="secondImage" class="second-image" src="@/assets/image/head.png"> | ||||
| 
 | ||||
| 
 | ||||
|         <img  | ||||
|           ref="secondImage"  | ||||
|           class="second-image"  | ||||
|           src="@/assets/image/head.png" | ||||
|         > | ||||
|         <div class="pop1"> | ||||
|           <img class="w-[88px] h-[32px]" src="@/assets/image/panel2/pop1.png" alt="pop1"> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div class="content"> | ||||
|         <div class="text-[#10253E] text-[54px] leading-[80px]">{{ t('home.section2.title1') }}</div> | ||||
|         <div class="text-[#10253E] text-[54px] leading-[80px]">{{ t('home.section2.title2') }}</div> | ||||
|         <div class="text-[#10253E] text-[54px] leading-[80px]">FiEE携手文艺创作者</div> | ||||
|         <div class="text-[#10253E] text-[54px] leading-[80px]">启航全球影响力新征程</div> | ||||
|       </div> | ||||
|     </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;"> | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|     <section className="panel"> | ||||
|       <div class="parallax-bg">THREE</div> | ||||
|       <div class="content"> | ||||
|         <!-- 添加你的内容 --> | ||||
|       </div> | ||||
|       <div class="content3 mt-[140px]"> | ||||
|         <div class="text-[#8B59F7] text-[16px]">{{ t('home.section3.label') }}</div> | ||||
|         <div class="text-[#10253E] text-[40px]  mt-[17px]"> | ||||
|           FiEE | ||||
|         </div> | ||||
|         <div class="text-[#455363] text-[16px]  mt-[31px]"> | ||||
|           {{ t('home.section3.desc') }} | ||||
|         </div> | ||||
|         <n-marquee auto-fill> | ||||
|           <div style="display: flex;"> | ||||
|             <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-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.data.desc') }} | ||||
|               </div> | ||||
|             </div> | ||||
|             <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-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.ai.desc') }} | ||||
|               </div> | ||||
|             </div> | ||||
|             <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-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.cloud.desc') }} | ||||
|               </div> | ||||
|             </div> | ||||
|             <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-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.cooperation.desc') }} | ||||
|               </div> | ||||
|             </div> | ||||
|             <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-[#455363] text-[16px] mt-[14px] max-w-[200px] break-words"> | ||||
|                 {{ t('home.section3.features.promotion.desc') }} | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
|         </n-marquee> | ||||
|       </div> | ||||
| 
 | ||||
|     </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"></div> | ||||
|       <div class="content4 mt-[103px]"> | ||||
|         <div class="text-[#8B59F7] text-[16px]">{{ t('home.section4.label') }}</div> | ||||
|         <div class="text-[#10253E] text-[40px]  mt-[17px]"> | ||||
|           {{ t('home.section4.title') }} | ||||
|         </div> | ||||
|         <div class="text-[#455363] text-[16px]  mt-[31px]"> | ||||
|           {{ t('home.section4.desc') }} | ||||
|         </div> | ||||
|         <div class="container"> | ||||
|           <div class="mt-[100px]"> | ||||
|             <div class="card"> | ||||
|               <img src="@/assets/image/yw1.png" alt="Image 1" /> | ||||
|               <div class="js-detail font-bold"> | ||||
|                 {{ t('home.section4.cards1.title') }} | ||||
|                 <div class="text-[#455363] text-[16px] font-normal"> | ||||
|                   {{ t('home.section4.cards1.desc') }} | ||||
|                 </div> | ||||
|               </div> | ||||
|             </div> | ||||
|             <div class="card"> | ||||
|               <img src="@/assets/image/yw3.png" alt="Image 2" /> | ||||
|               <div class="js-detail font-bold"> | ||||
|                 {{ t('home.section4.cards2.title') }} | ||||
|                 <div class="text-[#455363] text-[16px] font-normal"> | ||||
|                   {{ t('home.section4.cards2.desc') }} | ||||
|                 </div> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
|           <div class="right"> | ||||
|             <div class="card"> | ||||
|               <img src="@/assets/image/yw2.png" alt="Image 3" /> | ||||
|               <div class="js-detail font-bold"> | ||||
|                 {{ t('home.section4.cards3.title') }} | ||||
|                 <div class="text-[#455363] text-[16px] font-normal"> | ||||
|                   {{ t('home.section4.cards3.desc') }} | ||||
|                 </div> | ||||
|               </div> | ||||
|             </div> | ||||
|             <div class="card"> | ||||
|               <img src="@/assets/image/yw4.png" alt="Image 4" /> | ||||
|               <div class="js-detail font-bold"> | ||||
|                 {{ t('home.section4.cards4.title') }} | ||||
|                 <div class="text-[#455363] text-[16px] font-normal"> | ||||
|                   {{ t('home.section4.cards4.desc') }} | ||||
|                 </div> | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|     <section className="panel"> | ||||
|       <div class="parallax-bg">FOUR</div> | ||||
|       <div class="content"> | ||||
|         <!-- 添加你的内容 --> | ||||
|       </div> | ||||
|     </section> | ||||
|   </main> | ||||
|   <footer> | ||||
|     <div class="footer-content"> | ||||
|       <img class="copyright" src="@/assets/image/cp.png" alt="logo" /> | ||||
| 
 | ||||
| 
 | ||||
|     </div> | ||||
|   </footer> | ||||
| </template> | ||||
| 
 | ||||
| <style scoped lang="scss"> | ||||
| .carousel-img { | ||||
|   width: 100%; | ||||
|   height: 100vh; | ||||
|   object-fit: cover; | ||||
|   image-rendering: -webkit-optimize-contrast; | ||||
|   image-rendering: crisp-edges; | ||||
|   -webkit-backface-visibility: hidden; | ||||
|   backface-visibility: hidden; | ||||
|   transform: translateZ(0); | ||||
|   -webkit-font-smoothing: antialiased; | ||||
|   -moz-osx-font-smoothing: grayscale; | ||||
| } | ||||
| 
 | ||||
| .header { | ||||
|   width: 100%; | ||||
|   height: 55px; | ||||
| @ -762,119 +269,6 @@ watch( | ||||
|     color: #8B59FA; | ||||
|   } | ||||
| } | ||||
| .scroll-down { | ||||
|   position: fixed; | ||||
|   bottom: 50px; | ||||
|   left: 50%; | ||||
|   transform: translateX(-50%); | ||||
|   color: #FFFFFF; | ||||
|   font-size: 16px; | ||||
|   font-weight: 600; | ||||
|   z-index: 999; | ||||
|   background: rgba(0, 0, 0, 0.1); | ||||
|   backdrop-filter: blur(20px); | ||||
|   border: 1px solid rgba(255, 255, 255, 0.1); | ||||
|   border-radius: 22px; | ||||
|   padding: 10px 20px; | ||||
|   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; | ||||
| 
 | ||||
|   &.hide { | ||||
|     opacity: 0; | ||||
|     pointer-events: none; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| @keyframes float { | ||||
| 
 | ||||
|   0%, | ||||
|   100% { | ||||
|     transform: translate(-50%, 0); | ||||
|   } | ||||
| 
 | ||||
|   50% { | ||||
|     transform: translate(-50%, -10px); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| :deep .n-carousel__dot { | ||||
|   background-color: #DDDDDD !important; | ||||
| } | ||||
| 
 | ||||
| :deep .n-carousel__dot--active { | ||||
|   background-color: #8B59F7 !important; | ||||
| } | ||||
| 
 | ||||
| .divider1 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 477px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| .divider2 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 715px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
|   background-image: linear-gradient(to bottom, #E6EAEE 50%, transparent 50%); | ||||
|   background-size: 1px 15px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) | ||||
|   background-repeat: repeat-y; | ||||
| } | ||||
| 
 | ||||
| .divider3 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 950px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
|   background-image: linear-gradient(to bottom, #E6EAEE 50%, transparent 50%); | ||||
|   background-size: 1px 15px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) | ||||
|   background-repeat: repeat-y; | ||||
| } | ||||
| 
 | ||||
| .divider4 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 1186px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
|   background-image: linear-gradient(to bottom, #E6EAEE 50%, transparent 50%); | ||||
|   background-size: 1px 15px; // 第一个值是宽度,第二个值是虚线的总长度(实线+空白) | ||||
|   background-repeat: repeat-y; | ||||
| } | ||||
| 
 | ||||
| .divider5 { | ||||
|   position: absolute; | ||||
|   z-index: 3; | ||||
|   left: 1420px; | ||||
|   width: 1px; | ||||
|   height: 100vw; | ||||
| } | ||||
| 
 | ||||
| .carousel-img { | ||||
|   width: 100%; | ||||
|   height: 100vh; | ||||
|   object-fit: cover; | ||||
|   image-rendering: -webkit-optimize-contrast; | ||||
|   image-rendering: crisp-edges; | ||||
|   -webkit-backface-visibility: hidden; | ||||
|   backface-visibility: hidden; | ||||
|   transform: translateZ(0); | ||||
|   -webkit-font-smoothing: antialiased; | ||||
|   -moz-osx-font-smoothing: grayscale; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| .panel { | ||||
|   height: 100vh; | ||||
| @ -884,21 +278,6 @@ watch( | ||||
|   font-size: 30px; | ||||
|   overflow: hidden; | ||||
| 
 | ||||
|   // 为第四个panel添加特殊处理 | ||||
|   &:last-child { | ||||
|     position: relative; | ||||
|     overflow-y: auto; | ||||
|     height: auto; | ||||
|     min-height: 100vh; | ||||
| 
 | ||||
|     // 隐藏滚动条但保持功能 | ||||
|     &::-webkit-scrollbar { | ||||
|       display: none; // Chrome, Safari, Opera | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|   } | ||||
| 
 | ||||
|   &.first-panel { | ||||
|     position: relative; | ||||
| 
 | ||||
| @ -927,7 +306,7 @@ watch( | ||||
| 
 | ||||
| .content { | ||||
|   position: relative; | ||||
|   z-index: 5; | ||||
|   z-index: 2; | ||||
|   height: 100%; | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
| @ -935,37 +314,6 @@ watch( | ||||
|   align-items: center; | ||||
| } | ||||
| 
 | ||||
| .content3 { | ||||
|   position: relative; | ||||
|   z-index: 5; | ||||
|   padding: 0 500px; | ||||
|   height: 100%; | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
| 
 | ||||
|   >div { | ||||
|     opacity: 0; | ||||
|     transform: translateY(50px); | ||||
|     will-change: opacity, transform; | ||||
|   } | ||||
| 
 | ||||
|   >.n-marquee { | ||||
|     opacity: 0; | ||||
|     transform: translateY(50px); | ||||
|     will-change: opacity, transform; | ||||
|     visibility: hidden; // 初始隐藏跑马灯 | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .content4 { | ||||
|   position: relative; | ||||
|   z-index: 5; | ||||
|   padding: 0 500px; | ||||
|   height: 100%; | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
| } | ||||
| 
 | ||||
| .no-hover { | ||||
|   pointer-events: none; | ||||
| } | ||||
| @ -980,72 +328,8 @@ watch( | ||||
| 
 | ||||
| .second-image { | ||||
|   opacity: 0; | ||||
|   padding: 0 64px; | ||||
|   transform: translateY(50px); | ||||
|   will-change: opacity, transform; | ||||
|   pointer-events: none; | ||||
| } | ||||
| 
 | ||||
| .divider3, | ||||
| .divider4 { | ||||
|   :deep(.n-divider) { | ||||
|     border-left: none; | ||||
|     background-image: linear-gradient(to bottom, #E6EAEE 50%, transparent 50%); | ||||
|     background-size: 1px 30px; | ||||
|     background-repeat: repeat-y; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| // 确保跑马灯内容可见 | ||||
| :deep(.n-marquee) { | ||||
|   .n-marquee-content { | ||||
|     visibility: visible !important; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .container { | ||||
|   display: grid; | ||||
|   grid-template-columns: repeat(2, 1fr); | ||||
|   /* Two columns */ | ||||
|   gap: 30px; | ||||
|   padding: 10px; | ||||
| } | ||||
| 
 | ||||
| .card { | ||||
|   margin-top: 39px; | ||||
|   box-shadow: 0px 3px 14px 1px rgba(0, 0, 0, 0.16); | ||||
|   padding: 9px; | ||||
|   border-radius: 12px; | ||||
|   background-color: #FFFFFF; | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   align-items: center; | ||||
|   text-align: center; | ||||
| } | ||||
| 
 | ||||
| .card img { | ||||
|   max-width: 100%; | ||||
|   border-radius: 8px; | ||||
| } | ||||
| 
 | ||||
| .js-detail { | ||||
|   text-align: left; | ||||
|   margin-top: 10px; | ||||
|   font-size: 20px; | ||||
|   color: #10253E; | ||||
|   width: 100%; | ||||
|   padding: 0 23px; | ||||
| } | ||||
| 
 | ||||
| .footer-content { | ||||
|   height: 90px; | ||||
|   display: flex; | ||||
|   justify-content: center; | ||||
|   align-items: center; | ||||
| 
 | ||||
|   .copyright { | ||||
|     width: 232px; | ||||
|     height: 22pxpx; | ||||
|   } | ||||
| } | ||||
| </style> | ||||