SkillAgentSearch skills...

BitECS

Flexible, minimal, data-oriented ECS library for Typescript

Install / Use

/learn @NateTheGreatt/BitECS

README

<h1 align="center"> ❤ ❤ ❤ <br /> bitECS </h1> <p align="center"> <a href="https://www.npmjs.com/package/bitecs"> <img src="https://img.shields.io/npm/v/bitecs.svg" alt="Version" /> </a> <a href="https://www.npmjs.com/package/bitecs"> <img src="https://badgen.net/bundlephobia/minzip/bitecs" alt="Minzipped" /> </a> <a href="https://www.npmjs.com/package/bitecs"> <img src="https://img.shields.io/npm/dt/bitecs.svg" alt="Downloads" /> </a> <a href="https://github.com/NateTheGreatt/bitECS/blob/master/LICENSE"> <img src="https://badgen.net/npm/license/bitecs" alt="License" /> </a> <a href="https://discord.gg/daUxSk5AwX"> <img src="https://img.shields.io/discord/1212857060731912202?color=7289da&label=Discord&logo=discord&logoColor=white" alt="Discord" /> </a> </p> <p align="center"> Flexible, minimal, <a href="https://www.dataorienteddesign.com/dodbook/">data-oriented</a> <a href="https://en.wikipedia.org/wiki/Entity_component_system">ECS</a> library for Typescript. </p> </center>

✨ Features

bitECS is a minimal, less opinionated, and powerful Entity Component System (ECS) library. It provides a lean API that enables developers to build their architecture to their liking, offering flexibility while maintaining efficiency where needed. Features include: | | | |---|---| | 🔮 Simple, declarative API | 🍃 Lightweight (~5kb minzipped) | | 🔍 Powerful querying | 📦 Zero dependencies | | 🔗 Relational entity modeling | 🧵 Thread-friendly | | 💾 Serialization included | 💖 Made with love |

💿 Install

npm i bitecs

📘 Documentation

| | | ---------------- | | 🏁 Introduction | | 💾 Serialization | | 🧵 Multithreading | | 📑 API Docs |

🕹 Example

import {
  createWorld,
  query,
  addEntity,
  removeEntity,
  addComponent,
} from 'bitecs'

// Put components wherever you want
const Health = [] as number[]

const world = createWorld({
  components: {
    // They can be any shape you want
    // SoA:
    Position: { x: [], y: [] },
    Velocity: { x: new Float32Array(1e5), y: new Float32Array(1e5) },
    // AoS:
    Player: [] as { level: number; experience: number; name: string }[]
  },
  time: {
    delta: 0, 
    elapsed: 0, 
    then: performance.now()
  }
})

const { Position, Velocity, Player } = world.components

const eid = addEntity(world)
addComponent(world, eid, Position)
addComponent(world, eid, Velocity)
addComponent(world, eid, Player)
addComponent(world, eid, Health)

// SoA access pattern
Position.x[eid] = 0
Position.y[eid] = 0
Velocity.x[eid] = 1.23
Velocity.y[eid] = 1.23
Health[eid] = 100

// AoS access pattern  
Player[eid] = { level: 1, experience: 0, name: "Hero" }

const movementSystem = (world) => {
  const { Position, Velocity } = world.components
  
  for (const eid of query(world, [Position, Velocity])) {
    Position.x[eid] += Velocity.x[eid] * world.time.delta
    Position.y[eid] += Velocity.y[eid] * world.time.delta
  }
}

const experienceSystem = (world) => {
  const { Player } = world.components
  
  for (const eid of query(world, [Player])) {
    Player[eid].experience += world.time.delta / 1000
    if (Player[eid].experience >= 100) {
      Player[eid].level++
      Player[eid].experience = 0
    }
  }
}

const healthSystem = (world) => {
  for (const eid of query(world, [Health])) {
    if (Health[eid] <= 0) removeEntity(world, eid)
  }
}

const timeSystem = (world) => {
  const { time } = world
  const now = performance.now()
  const delta = now - time.then
  time.delta = delta
  time.elapsed += delta
  time.then = now
}

const update = (world) => {
  timeSystem(world)
  movementSystem(world)
  experienceSystem(world)
  healthSystem(world)
}

// Node environment
setInterval(() => {
  update(world)
}, 1000/60)

// Browser environment
requestAnimationFrame(function animate() {
  update(world)
  requestAnimationFrame(animate)
})

🔌 Used by

🌟 Star History

Star History Chart

View on GitHub
GitHub Stars1.4k
CategoryDevelopment
Updated14h ago
Forks107

Languages

TypeScript

Security Score

100/100

Audited on Mar 31, 2026

No findings