## ๐Ÿš€ ้กน็›ฎไบฎ็‚น ๅŸบไบŽ **Vue3.5** + **Element-Plus-X** + **hook-fetch** + **TypeScript** + **Eslint9** ๅผ€ๅ‘็š„ไผไธš็บงAIๅบ”็”จๆจกๆฟ๏ผŒๅฟซ้€Ÿๆž„ๅปบไปฟ่ฑ†ๅŒ…/้€šไน‰็š„ๅ…จๆ ˆAI้กน็›ฎใ€‚ ## ๐Ÿ’ก ๆ ธๅฟƒไผ˜ๅŠฟ - ๆœ€ๆ–ฐๆŠ€ๆœฏๆ ˆ๏ผšVue3.5+/Vite6/Pinia3/TypeScript5 - ๆตๅผไบคไบ’๏ผšHook-Fetchๆ”ฏๆŒServer-Sent Events๏ผŒๆ’ไปถๅŒ–ๅ†™ๆณ•ไผ˜้›…็š„ไธ€ๆ‰น - ไผไธš็บง่ง„่Œƒ๏ผšESLint/Stylelint/husky/commitlintๅ…จ้“พ่ทฏๆ ก้ชŒ - ๅ…จๆ ˆ้กน็›ฎ๏ผš้›†ๆˆ ๅŽ็ซฏๆœๅŠก๏ผŒๅฟซ้€Ÿๅผ€ๅ‘ - ๅผ€็ฎฑๅณ็”จ๏ผšๅ†…็ฝฎๅŠจๆ€่ทฏ็”ฑใ€็Šถๆ€็ฎก็†ใ€็ป„ไปถๅบ“ๅฐ่ฃ…ใ€hooksๅฐ่ฃ… ## ๐ŸŽฏ ๅผ€ๅ‘ๆ–‡ๆกฃ ## ๐Ÿ”— ๅ…ณ้”ฎ้“พๆŽฅ | ๐Ÿ“š ๅ‰็ซฏๆ–‡ๆกฃ | ๅผ€ๅ‘ๆŒ‡ๅ—/้กน็›ฎ่ฏดๆ˜Ž | [ๅฟซ้€Ÿไบ†่งฃ้กน็›ฎ](https://chat-docs.element-plus-x.com) | ## ๐Ÿงฐ ๆ ธๅฟƒๅŠŸ่ƒฝ - ไฝฟ็”จ Vue3.5+ ๅ„็งๆ–ฐ็‰นๆ€ง็š„ๆ”ฏๆŒ๏ผŒ่ฎฉๅผ€ๅ‘ๆ›ดๆœ‰ๆ•ˆ็އ - ้‡‡็”จ Vite6.3+ ไฝœไธบ้กน็›ฎๅผ€ๅ‘ใ€ๆ‰“ๅŒ…ๅทฅๅ…ท - ไฝฟ็”จ Pinia3.0+ ไฝœไธบๅ…จๅฑ€็Šถๆ€็ฎก็†ๅบ“๏ผŒ่ฝป้‡ใ€ไผ˜้›…ใ€ๆ˜“็”จ๏ผŒ้›†ๆˆ Pinia ๆŒไน…ๅŒ–ๆ’ไปถ - ไฝฟ็”จ TypeScript5.8+ ๅขžๅผบ้กน็›ฎ็š„ไปฃ็ ่ง„่Œƒๅ’Œๅฏ่ฏปๆ€ง - ไฝฟ็”จ Unocss ้ข„่ฎพๆ ทๅผ๏ผŒๆ›ดๅฟซไนฆๅ†™็ฎ€ๅ•็š„ๆ ทๅผ - ๅผƒ็”จ Axios (ไธๆ”ฏๆŒๆตๅผ่ฏทๆฑ‚) ๆ”น็”จ Hook-Fetch (ๆ”ฏๆŒๆตๆจกๅผ๏ผŒๆ’ไปถๅŒ–ๅฐ่ฃ…๏ผŒๅ†™ๆณ•ๆžๅบฆไผ˜้›…) ่ฟ›่กŒๅ…จๅฑ€็š„่ฏทๆฑ‚ๅฐ่ฃ… - ไฝฟ็”จ VueRouter ้…็ฝฎๅŠจๆ€่ทฏ็”ฑๆƒ้™ๆ‹ฆๆˆชใ€่ทฏ็”ฑๆ‡’ๅŠ ่ฝฝ - ไฝฟ็”จ KeepAlive ๅฏน้กต้ข่ฟ›่กŒ็ผ“ๅญ˜ - ๅฐ่ฃ…ไบ†ไธ€ไบ›ๅฅฝ็”จ็š„็ป„ไปถๅ’ŒHooks๏ผŒๅขžๅผบ็”จๆˆทไบคไบ’ไฝ“้ชŒ - ไฝฟ็”จ ESLint9+ใ€Stylelint16+ ไปฃ็ ๆ ก้ชŒ่ง„่Œƒใ€ๅŒๆ—ถ็ปŸไธ€ไฟๅญ˜ๆ ผๅผๅŒ–ไปฃ็  - ไฝฟ็”จ huskyใ€lint-stagedใ€commitlintใ€cz-git ่ง„่Œƒๆไบคไฟกๆฏ ## ๐Ÿ“ฆ ๅฎ‰่ฃ…ไธŽ่ฟ่กŒ ```bash # ๅฎ‰่ฃ…ไพ่ต–๏ผˆๆŽจ่pnpm ้ฟๅ…ๅนปๅฝฑไพ่ต–๏ผ‰ pnpm install # ๅผ€ๅ‘ๆจกๅผ pnpm run dev # ็”Ÿไบงๆž„ๅปบ pnpm build # ไปฃ็ ๆ ก้ชŒ pnpm lint # ESLintๆฃ€ๆต‹ pnpm lint:stylelint # ๆ ทๅผๆ ผๅผๅŒ– pnpm cz # ่ง„่Œƒๆไบค๏ผˆ่‡ชๅŠจๆ‰ง่กŒlint๏ผ‰ ``` ### ๆœๅŠก็ซฏๅฏๅŠจ ็›ฎๅฝ•๏ผšE:\devDemo\Yi\Yi.Abp.Net8\src\Yi.Abp.Web ```bash dotnet run ``` ## ๐Ÿงธ ๅณๅฐ†ๆŽจๅ‡บ ๏ผˆๅซ ๆŽฅๅฃ่”่ฐƒ๏ผ‰ - [x] ไผš่ฏ็ฎก็† - [x] ๅ‘้€ๆถˆๆฏ - [x] ็™ปๅฝ•ๆณจๅ†Œ - [ ] md ๆธฒๆŸ“ - [ ] ็ผ–่พ‘่พ“ๅ…ฅๆก† - [ ] ๆ–‡ไปถไธŠไผ  - [ ] ๅ…ถไป–... ๆทฑ่‰ฒไธป้ข˜ๆ ทๅผ็ผ–ๅ†™ๆŒ‡ๅ— 1. ๅœจ src/styles/dark-theme.scss ไธญๆทปๅŠ ๆ ทๅผ ๆ‰€ๆœ‰ๆทฑ่‰ฒไธป้ข˜ๆ ทๅผ้ƒฝไฝฟ็”จ [data-theme="dark"] ้€‰ๆ‹ฉๅ™จๅŒ…่ฃน๏ผš /* ========== ็ป„ไปถๅ็งฐๆทฑ่‰ฒๆ ทๅผ ========== */ [data-theme="dark"] { .your-component-class { background-color: #1f2937 !important; color: #e5e7eb !important; border-color: #374151 !important; } } 2. ๅธธ็”จๆทฑ่‰ฒไธป้ข˜้ขœ่‰ฒๅ€ผ โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ฌโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ” โ”‚ ็”จ้€” โ”‚ ้ขœ่‰ฒๅ€ผ โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ไธป่ƒŒๆ™ฏ โ”‚ #111827 โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ๆฌก็บง่ƒŒๆ™ฏ๏ผˆๅก็‰‡ใ€ๅผน็ช—๏ผ‰ โ”‚ #1f2937 โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ไธ‰็บง่ƒŒๆ™ฏ๏ผˆhoverใ€่กจๅคด๏ผ‰ โ”‚ #374151 โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ไธปๆ–‡ๅญ— โ”‚ #f3f4f6 / #f9fafb โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ๆฌก็บงๆ–‡ๅญ— โ”‚ #e5e7eb โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ไธ‰็บงๆ–‡ๅญ— โ”‚ #9ca3af โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ่พนๆก†ๆต…่‰ฒ โ”‚ #374151 โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ่พนๆก†ๆทฑ่‰ฒ โ”‚ #4b5563 โ”‚ โ”œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ผโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ค โ”‚ ไธป่‰ฒ่ฐƒ โ”‚ #60a5fa โ”‚ โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”ดโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜ 3. ่ฆ†็›– Tailwind ๅทฅๅ…ท็ฑป [data-theme="dark"] { .bg-white { background-color: #374151 !important; } .text-gray-700 { color: #e5e7eb !important; } } 4. ่ฆ†็›– Element Plus ็ป„ไปถ [data-theme="dark"] { .el-card { background-color: #1f2937 !important; border-color: #374151 !important; } } 5. ไฝฟ็”จ CSS ๅ˜้‡๏ผˆๆŽจ่๏ผ‰ ๅœจ src/styles/var.scss ็š„ [data-theme="dark"] ๅ—ไธญๅฎšไน‰ๅ˜้‡๏ผŒ็„ถๅŽๅœจ็ป„ไปถไธญไฝฟ็”จ๏ผš // var.scss [data-theme="dark"] { --my-component-bg: #1f2937; } // dark-theme.scss [data-theme="dark"] { .my-component { background-color: var(--my-component-bg) !important; } } 6. ็ป„ไปถๅ†…ๅŠจๆ€้ขœ่‰ฒ๏ผˆJS ๆ–นๅผ๏ผ‰ ๅฆ‚ๆžœ้œ€่ฆๅœจ JS ไธญๅŠจๆ€่Žทๅ–้ขœ่‰ฒ๏ผš