-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathindex.html
86 lines (68 loc) · 7.79 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>Flight by Twitter</title>
<meta name="description" content="A lightweight, component-based JavaScript framework for assigning behavior to DOM nodes.">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="shortcut icon" type="image/x-icon" href="https://twitter.com/favicons/favicon.ico">
<link rel="stylesheet" href="css/normalize.min.css">
<link rel="stylesheet" href="css/main.css">
</head>
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-39101739-3', 'flightjs.github.io');
ga('send', 'pageview');
</script>
<body>
<div class="container">
<div class="site-header" role="banner">
<img src="img/flight-logo.png" width="150" height="150" alt="Twitter logo">
<h1 class="site-title">Flight</h1>
<hr>
<h2 class="site-tagline">An event-driven web framework, from Twitter</h2>
<a class="btn" href="https://github.com/flightjs/flight">View on GitHub</a>
</div><!-- /.site-header -->
<div class="site-main" role="main">
<h2>Overview</h2>
<p>Flight is a lightweight, component-based JavaScript framework that maps behavior to DOM nodes. Twitter uses it for their web applications. By way of example, we've included a <a href="https://flightjs.github.io/example-app/">simple email client demo</a> (browse the <a href="https://github.com/flightjs/example-app">source</a>) built over the Flight framework. There's also a flight implementation over on the <a href="http://todomvc.com/examples/flight/">todoMVC</a> site (<a href="https://github.com/tastejs/todomvc/tree/gh-pages/examples/flight">source</a>), courtesy of <a href="https://github.com/mkuklis">@mkuklis</a></p>
<p>Flight uses <a href="https://jquery.com/">jQuery</a> and requires a module loader with support for AMD, like <a href="http://webpack.github.io/">WebPack</a> or <a href="http://requirejs.org/">Require.js</a>. Please read the <a href="https://github.com/flightjs/flight/tree/v1.x">Flight documentation</a> for installation instructions.</p>
<h2>Why Flight?</h2>
<p>Flight is distinct from existing frameworks in that it doesn't prescribe or provide any particular approach to rendering or providing data to a web application. It's agnostic to how requests are routed, which templating language you use or even if you render your HTML on the client or the server. While some web frameworks encourage developers to arrange their code around a prescribed model layer, Flight is organized around the existing DOM model with functionality mapped directly to DOM nodes.</p>
<p>Not only does this obviate the need for additional data structures that will inevitably influence the broader architecture, but by mapping our functionality directly onto the native web we get to take advantage of native features. For example, we get custom event propagation for free by piggy-backing off DOM event bubbling, and our event handling infrastructure works equally well with both native and custom events.</p>
<h2>How does it work?</h2>
<p>Flight enforces strict separation of concerns. When you create a component you don't get a handle to it. Consequently, components cannot be referenced by other components and cannot become properties of the global object tree. This is by design. Components do not engage each other directly; instead, they broadcast their actions as events which are subscribed to by other components.</p>
<h2>Why events?</h2>
<p>Events are open ended. When a component triggers an event it has no knowledge of how its request will be satisfied or by whom. This enforced decoupling of functionality allows the engineer to consider each component in isolation rather than having to reason about the growing complexity of the application as a whole.</p>
<p>By making DOM node events proxies for component events, we let the web work for us:</p>
<ul>
<li>we get event propagation for free</li>
<li>a component can subscribe to a given event type at the document level or it can choose to listen only those events originating from within a specified DOM Node</li>
<li>subscribing components do not distinguish between custom events from other components (e.g. <code>dataMailItemsServed</code>) and native DOM node events (e.g. <code>click</code>), and process both types of event in an identical fashion</li>
</ul>
<p><img src="img/eventPropagation.png" alt=""></p>
<h2>Mobility and Testing</h2>
<p>Each component is a module, which aside from a minimal set of standard dependencies (relevant Flight utilities and mixins), has no reference to the outside world. Thus a given component will respond to a given event in the same way, regardless of environment. This makes testing both simple and reliable — events are essentially the only variable and a production event is easy to replicate in testing. You can even debug a component by triggering events in the console.</p>
<h2>Mixins</h2>
<p>A mixin defines a set of functionality that is useful to more than one object. Flight comes with built-in support for <a href="http://javascriptweblog.wordpress.com/2011/05/31/a-fresh-look-at-javascript-mixins/">functional mixins</a>, including protection against unintentional overrides and duplicate mixins. While classical JavaScript patterns support only single inheritance, a component (or other object) can have multiple mixins applied to it. Moreover mixins requires a fraction of the boilerplate required to form traditional classical hierarchies out of constructor-prototypes hybrids, and don't suffer the leaky abstractions of the latter ('super', 'static', 'const' etc.)</p>
<h2>Documentation and Demo</h2>
<p>The project includes <a href="https://github.com/flightjs/flight/tree/master/doc">full documentation</a> as well as an <a href="https://github.com/flightjs/example-app">example app</a> in the form of an <a href="https://flightjs.github.io/example-app">email client</a>:</p>
<p><img src="img/demo.png" alt=""></p>
<h2>Contributions</h2>
<p>We welcome outside contributions! Check out our <a href="https://github.com/flightjs/flight/issues">GitHub issues</a> to see what needs doing. To get started, you could try a <a href="https://github.com/flightjs/flight/labels/helpwanted">helpwanted</a> ticket!</p>
<div class="social">
<a href="https://twitter.com/share" class="twitter-share-button" data-size="large" data-count="none" data-text="@flightjs a lightweight, component-based JavaScript framework from Twitter">Tweet</a>
<a href="https://twitter.com/flightjs" class="twitter-follow-button" data-show-count="false" data-size="large" data-show-screen-name="false">Follow @flight</a>
</div>
</div><!-- /.site-main -->
<div class="site-footer" role="contentinfo">
<p class="license">Code licensed under the <a href="http://opensource.org/licenses/MIT" target="_blank">MIT License</a>. Documentation licensed under <a href="http://creativecommons.org/licenses/by/3.0/" target="_blank">CC BY 3.0</a>.</p>
</div><!-- /.site-footer -->
</div><!-- /.container -->
<script>!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0];if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src="https://platform.twitter.com/widgets.js";fjs.parentNode.insertBefore(js,fjs);}}(document,"script","twitter-wjs");</script>
</body>
</html>