スキル一覧に戻る
verekia

miniplex

by verekia

⚛️ React Three Fiber Game Dev Recipes

17🍴 0📅 2026年1月22日
GitHubで見るManusで実行

SKILL.md


name: miniplex description: Use Miniplex for minimalistic Entity Component System with TypeScript support.

Miniplex ECS

Use Miniplex for minimalistic Entity Component System with TypeScript support.

When setting up or undertaking important changes with Miniplex, fetch the documentations:

Core: https://raw.githubusercontent.com/hmans/miniplex/refs/heads/main/packages/core/README.md React bindings: https://raw.githubusercontent.com/hmans/miniplex/refs/heads/main/packages/react/README.md

Technique

Define an entity type with optional properties, create a world, and query entities based on their properties. Use miniplex-react for React bindings with the Entities component.

Key Concepts

  • Entity type defines all possible components as optional properties
  • world.with('prop1', 'prop2') creates typed queries
  • world.add() and world.remove() for entity lifecycle
  • world.addComponent() and world.removeComponent() for component lifecycle
  • <Entities in={query}>{Component}</Entities> renders entities reactively
  • Entity props are passed directly to child components

What NOT to Use

  • onEntityAdded / onEntityRemoved - Prefer using data and systems to trigger things (e.g., timers, flags)
  • .where() - Don't use predicate-based filtering

Preferred Methods

Only use these world methods:

  • world.add(entity) - Add a new entity
  • world.remove(entity) - Remove an entity
  • world.addComponent(entity, 'component', value) - Add component to existing entity
  • world.removeComponent(entity, 'component') - Remove component from entity
  • world.with('prop1', 'prop2') - Create queries

Queries

Declare queries at module level and import them where needed:

// ecs/queries.ts
export const characterQuery = world.with('position', 'isCharacter')
export const enemyQuery = world.with('position', 'isEnemy')
export const movingEntities = world.with('position', 'velocity')

// In a system file
import { movingEntities } from './ecs/queries'

Usage

type Entity = {
  position?: { x: number; y: number }
  isCharacter?: true
}

const world = new World<Entity>()
const characters = world.with('position', 'isCharacter')

// Add entity
world.add({ position: { x: 0, y: 0 }, isCharacter: true })

// Render
<Entities in={characters}>{Character}</Entities>

Note: Miniplex is feature-complete but no longer maintained.


This skill is part of verekia's r3f-gamedev.

スコア

総合スコア

65/100

リポジトリの品質指標に基づく評価

SKILL.md

SKILL.mdファイルが含まれている

+20
LICENSE

ライセンスが設定されている

+10
説明文

100文字以上の説明がある

0/10
人気

GitHub Stars 100以上

0/15
最近の活動

1ヶ月以内に更新

+10
フォーク

10回以上フォークされている

0/5
Issue管理

オープンIssueが50未満

+5
言語

プログラミング言語が設定されている

+5
タグ

1つ以上のタグが設定されている

+5

レビュー

💬

レビュー機能は近日公開予定です