initial commit

This commit is contained in:
Jiao77
2025-09-29 05:57:18 +08:00
commit 9c0051c92b
73 changed files with 18737 additions and 0 deletions

View File

@@ -0,0 +1,95 @@
# TypeScript 警告修复说明
## 修复的问题
### 1. ✅ 已修复:`Property 'CodeHighlight' may not exist on type 'Window'`
**问题原因:** TypeScript 不知道 `window.CodeHighlight` 这个自定义属性的存在。
**解决方案:**
- 创建了 `src/types/global.d.ts` 文件来扩展 Window 接口
- 添加了全局类型声明支持自定义属性
### 2. ⚠️ 残留警告:`document.execCommand('copy') is deprecated`
**问题原因:** `document.execCommand` 是已废弃的 API。
**现状:**
- 已优化为优先使用现代的 `navigator.clipboard` API
- 只在不支持 Clipboard API 的环境中降级使用 `execCommand`
- 这是向后兼容的必要措施,警告可以忽略
**代码实现:**
```javascript
// 优先使用现代 API
if (navigator.clipboard && window.isSecureContext) {
await navigator.clipboard.writeText(text);
} else {
// 降级到传统方法(会有警告但功能正常)
document.execCommand('copy');
}
```
### 3. ✅ 已修复:`'line' is declared but its value is never read`
**问题原因:** forEach 回调中的 `line` 参数未被使用。
**解决方案:** 将未使用的参数重命名为 `_`
```javascript
// 修复前
lines.forEach((line, index) => {
// line 未被使用
});
// 修复后
lines.forEach((_, index) => {
// 使用 _ 表示未使用的参数
});
```
### 4. ✅ 已修复:`'nav' is declared but its value is never read`
**问题原因:** 获取了 DOM 元素但未使用。
**解决方案:** 删除了未使用的变量声明
### 5. ✅ 已修复:`'navigationItems' is declared but its value is never read`
**问题原因:** Props 中定义了但未在组件中使用。
**解决方案:** 从 Props 解构中移除未使用的属性
### 6. ✅ 已修复:`Math.random().toString(36).substr(2, 9)` - substr is deprecated
**问题原因:** `substr` 方法已被废弃。
**解决方案:** 替换为现代的 `substring` 方法
```javascript
// 修复前
Math.random().toString(36).substr(2, 9)
// 修复后
Math.random().toString(36).substring(2, 11)
```
## 构建结果
现在的构建输出:
-**0 错误**
- ⚠️ **1 个警告**`execCommand` 废弃警告 - 可安全忽略)
- 💡 **3 个提示**(来自其他文件的轻微问题)
## 关于剩余警告的说明
最后剩余的 `document.execCommand` 警告是预期的,因为:
1. **兼容性需求**:需要支持旧版浏览器
2. **安全限制**Clipboard API 只在 HTTPS 环境下工作
3. **降级策略**:这是一个合理的 progressive enhancement 实现
如果你希望完全消除这个警告,可以:
- 使用 `// @ts-ignore` 注释
- 或者移除降级支持(但会影响旧浏览器兼容性)
## 最佳实践
1. **类型安全**:为所有自定义全局变量创建类型声明
2. **现代 API**:优先使用新的 Web API适当降级
3. **未使用变量**:使用 `_` 前缀或直接删除
4. **废弃方法**:及时更新到推荐的替代方案
项目现在拥有更好的 TypeScript 类型安全性和更少的警告!