mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-01-19 13:18:59 +08:00
3a32a09f2a
* remove deprecated allBindings as Accessor https://github.com/knockout/knockout/pull/2133 * remove unused event '*Bubble' https://knockoutjs.com/documentation/event-binding.html#note-4-preventing-the-event-from-bubbling * remove unused 'completeOn' https://knockoutjs.com/documentation/binding-lifecycle-events.html#indicating-that-a-control-flow-binding-completes-asynchronously
68 lines
2.9 KiB
Markdown
68 lines
2.9 KiB
Markdown
# Knockout
|
|
|
|
**Knockout** is a JavaScript [MVVM](http://en.wikipedia.org/wiki/Model_View_ViewModel) (a modern variant of MVC) library that makes it easier to create rich, desktop-like user interfaces with JavaScript and HTML. It uses *observers* to make your UI automatically stay in sync with an underlying data model, along with a powerful and extensible set of *declarative bindings* to enable productive development.
|
|
|
|
## SnappyMail Modifications
|
|
|
|
Knockout has a high level of backward compatibility. We don't use it, so a lot of IE code is stripped.
|
|
|
|
npm closure-compiler is old and broken for ES2015/ES6, so we use the new google-closure-compiler.
|
|
|
|
|
|
## Getting started
|
|
|
|
[![Join the chat at https://gitter.im/knockout/knockout](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/knockout/knockout?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
|
|
|
**Totally new to Knockout?** The most fun place to start is the [online interactive tutorials](http://learn.knockoutjs.com/).
|
|
|
|
For more details, see
|
|
|
|
* Documentation on [the project's website](http://knockoutjs.com/documentation/introduction.html)
|
|
* Online examples at [http://knockoutjs.com/examples/](http://knockoutjs.com/examples/)
|
|
|
|
## Downloading Knockout
|
|
|
|
You can [download released versions of Knockout](http://knockoutjs.com/downloads/) from the project's website.
|
|
|
|
For Node.js developers, Knockout is also available from [npm](https://npmjs.org/) - just run `npm install knockout`.
|
|
|
|
## Building Knockout from sources
|
|
|
|
If you prefer to build the library yourself:
|
|
|
|
1. **Clone the repo from GitHub**
|
|
|
|
```sh
|
|
git clone https://github.com/knockout/knockout.git
|
|
cd knockout
|
|
```
|
|
|
|
2. **Acquire build dependencies.**
|
|
|
|
Make sure you have [Node.js](http://nodejs.org/) installed on your workstation. This is only needed to _build_ Knockout from sources. Knockout itself has no dependency on Node.js once it is built (it works with any server technology or none). Now run:
|
|
|
|
```sh
|
|
npm install -g grunt-cli
|
|
npm install
|
|
```
|
|
|
|
The first `npm` command sets up the popular [Grunt](http://gruntjs.com/) build tool. You might need to run this command with `sudo` if you're on Linux or Mac OS X, or in an Administrator command prompt on Windows. The second `npm` command fetches the remaining build dependencies.
|
|
|
|
3. **Run the build tool**
|
|
|
|
```sh
|
|
grunt
|
|
```
|
|
Now you'll find the built files in `build/output/`.
|
|
|
|
## Running the tests
|
|
|
|
If you have [phantomjs](http://phantomjs.org/download.html) installed, then the `grunt` script will automatically run the specification suite and report its results.
|
|
|
|
Or, if you want to run the specs in a browser (e.g., for debugging), simply open `spec/runner.html` in your browser.
|
|
|
|
## License
|
|
|
|
MIT license - [http://www.opensource.org/licenses/mit-license.php](http://www.opensource.org/licenses/mit-license.php)
|
|
|
|
`ln -s node_modules/google-closure-compiler/contrib node_modules/closure-compiler/node_modules/google-closure-compiler/contrib`
|