mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-02-09 16:03:09 +08:00
59 lines
1.0 KiB
Markdown
59 lines
1.0 KiB
Markdown
|
|
# TypeScript/JavaScript Coding Style
|
||
|
|
|
||
|
|
> This file extends [common/coding-style.md](../common/coding-style.md) with TypeScript/JavaScript specific content.
|
||
|
|
|
||
|
|
## Immutability
|
||
|
|
|
||
|
|
Use spread operator for immutable updates:
|
||
|
|
|
||
|
|
```typescript
|
||
|
|
// WRONG: Mutation
|
||
|
|
function updateUser(user, name) {
|
||
|
|
user.name = name // MUTATION!
|
||
|
|
return user
|
||
|
|
}
|
||
|
|
|
||
|
|
// CORRECT: Immutability
|
||
|
|
function updateUser(user, name) {
|
||
|
|
return {
|
||
|
|
...user,
|
||
|
|
name
|
||
|
|
}
|
||
|
|
}
|
||
|
|
```
|
||
|
|
|
||
|
|
## Error Handling
|
||
|
|
|
||
|
|
Use async/await with try-catch:
|
||
|
|
|
||
|
|
```typescript
|
||
|
|
try {
|
||
|
|
const result = await riskyOperation()
|
||
|
|
return result
|
||
|
|
} catch (error) {
|
||
|
|
console.error('Operation failed:', error)
|
||
|
|
throw new Error('Detailed user-friendly message')
|
||
|
|
}
|
||
|
|
```
|
||
|
|
|
||
|
|
## Input Validation
|
||
|
|
|
||
|
|
Use Zod for schema-based validation:
|
||
|
|
|
||
|
|
```typescript
|
||
|
|
import { z } from 'zod'
|
||
|
|
|
||
|
|
const schema = z.object({
|
||
|
|
email: z.string().email(),
|
||
|
|
age: z.number().int().min(0).max(150)
|
||
|
|
})
|
||
|
|
|
||
|
|
const validated = schema.parse(input)
|
||
|
|
```
|
||
|
|
|
||
|
|
## Console.log
|
||
|
|
|
||
|
|
- No `console.log` statements in production code
|
||
|
|
- Use proper logging libraries instead
|
||
|
|
- See hooks for automatic detection
|