flightjs/flight
{ "createdAt": "2013-01-30T19:59:30Z", "defaultBranch": "master", "description": "A component-based, event-driven JavaScript framework from Twitter", "fullName": "flightjs/flight", "homepage": "http://flightjs.github.io/", "language": "JavaScript", "name": "flight", "pushedAt": "2022-08-25T12:11:30Z", "stargazersCount": 6506, "topics": [], "updatedAt": "2025-11-08T10:06:05Z", "url": "https://github.com/flightjs/flight"}Please note
Section titled “Please note”Flight is not under active development. New pull requests will not be accepted unless they fix core bugs or security issues.
Flight
Section titled “Flight”Flight is a lightweight, component-based, event-driven JavaScript framework that maps behavior to DOM nodes. It was created at Twitter, and is used by the twitter.com and TweetDeck web applications.
- Website
- [API documentation]!(doc/README.md)
- Flight example app (Source)
- Flight’s Google Group
- Flight on Twitter
- Flight on Freenode IRC (#flightjs)
Example
Section titled “Example”A simple example of a Flight component.
/* Component definition */
var Inbox = flight.component(inbox);
function inbox() { this.doSomething = function() { /* ... */ } this.doSomethingElse = function() { /* ... */ }
// after initializing the component this.after('initialize', function() { this.on('click', this.doSomething); this.on('mouseover', this.doSomethingElse); });}
/* Attach the component to a DOM node */
Inbox.attachTo('#inbox');Installation
Section titled “Installation”Quick start using the pre-built
library (a
UMD bundle). It exposes all of its modules as
properties of a global variable, flight.
<!-- jQuery --><script unsrc="//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script><!-- Flight release --><script src="http://flightjs.github.io/release/latest/flight.min.js"></script>Using npm:
npm install --save flightjsUsing Bower:
bower install --save flightYou will have to load jQuery in your application.
Why Flight?
Section titled “Why Flight?”Flight is only ~5K minified and gzipped. It’s built upon jQuery.
Flight components are highly portable and easily testable. This is because a Flight component (and its API) is entirely decoupled from other components. Flight components communicate only by triggering and subscribing to events.
Flight also includes a simple and safe mixin infrastructure, allowing components to be easily extended with minimal boilerplate.
Development tools
Section titled “Development tools”Flight has supporting projects that provide everything you need to setup, write, and test your application.
-
Flight generator Recommended. One-step to setup a Flight-based web app.
-
Flight package generator Recommended. One-step to setup everything you need to write and test a standalone Flight component.
-
Jasmine Flight Extensions for the Jasmine test framework.
-
Mocha Flight Extensions for the Mocha test framework.
Finding and writing components
Section titled “Finding and writing components”You can browse all the Flight components available at this time. They can also be found by searching the Bower registry:
bower search flightThe easiest way to write a new Flight component is to use the Flight package generator:
yo flight-package fooBrowser Support
Section titled “Browser Support”Chrome, Firefox, Safari, Opera, IE 7+ (requires ES5-shim).
Quick Overview
Section titled “Quick Overview”Here’s a brief introduction to Flight’s key concepts and syntax. Read the [API documentation]!(doc) for a comprehensive overview.
Components ([API]!(doc/component_api.md))
Section titled “Components ([API]!(doc/component_api.md))”- A Component is nothing more than a constructor with properties mixed into its prototype.
- Every Component comes with a set of basic functionality such as event handling and component registration. (see [Base API]!(doc/base_api.md))
- Additionally, each Component definition mixes in a set of custom properties which describe its behavior.
- When a component is attached to a DOM node, a new instance of that component is created. Each component
instance references the DOM node via its
nodeproperty. - Component instances cannot be referenced directly; they communicate with other components via events.
Interacting with the DOM
Section titled “Interacting with the DOM”Once attached, component instances have direct access to their node object via the node property. (There’s
also a jQuery version of the node available via the $node property.)
Events in Flight
Section titled “Events in Flight”Events are how Flight components interact. The Component prototype supplies methods for triggering events as well as for subscribing to and unsubscribing from events. These Component event methods are actually just convenient wrappers around regular event methods on DOM nodes.
Mixins ([API]!(doc/mixin_api.md))
Section titled “Mixins ([API]!(doc/mixin_api.md))”- In Flight, a mixin is a function which assigns properties to a target object (represented by the
thiskeyword). - A typical mixin defines a set of functionality that will be useful to more than one component.
- One mixin can be applied to any number of [Component]!(#components) definitions.
- One Component definition can have any number of mixins applied to it.
- Each Component defines a [core]!(#core_mixin) mixin within its own module.
- A mixin can itself have mixins applied to it.
Advice ([API]!(doc/advice_api.md))
Section titled “Advice ([API]!(doc/advice_api.md))”In Flight, advice is a mixin ('lib/advice.js') that defines before, after and around methods.
These can be used to modify existing functions by adding custom code. All Components have advice mixed in to
their prototype so that mixins can augment existing functions without requiring knowledge
of the original implementation. Moreover, since Components are seeded with an empty initialize method,
Component definitions will typically use after to define custom initialize behavior.
Debugging ([API]!(doc/debug_api.md))
Section titled “Debugging ([API]!(doc/debug_api.md))”Flight ships with a debug module which can help you trace the sequence of event triggering and binding. By default
console logging is turned off, but you can log trigger, on and off events by means of the following console
commands.
Authors
Section titled “Authors”Thanks for assistance and contributions: @sayrer, @shinypb, @kloots, @marcelduran, @tbrd, @necolas, @fat, @mkuklis, @jrburke, @garann, @WebReflection, @coldhead, @paulirish, @nimbupani, @mootcycle.
Special thanks to the rest of the Twitter web team for their abundant contributions and feedback.
License
Section titled “License”Copyright 2013 Twitter, Inc and other contributors.
Licensed under the MIT License
