electron/docs/api/synopsis.md

46 lines
1.4 KiB
Markdown
Raw Normal View History

2014-05-05 06:49:05 +00:00
# Synopsis
All [node.js's built-in modules](http://nodejs.org/api/) are available in
atom-shell, and third-party node modules are fully supported too (including the
[native modules](../tutorial/using-native-node-modules.md)).
2014-05-05 06:49:05 +00:00
2014-05-10 01:17:10 +00:00
Atom-shell also provides some extra built-in modules for developing native
desktop applications. Some modules are only available on the browser side, some
are only available on the client (renderer) side, and some can be used on both sides.
The basic rule is: if a module is GUI or low-level system related, then it should
be only available on the browser side. You need to be familiar with the concept of
[browser-side vs. client-side](../tutorial/quick-start.md#the-browser-side) scripts
to be able to use those modules.
2014-05-05 06:49:05 +00:00
2014-05-10 01:17:10 +00:00
The browser-side script is just like a normal `node.js` script:
2014-05-05 06:49:05 +00:00
```javascript
var app = require('app');
var BrowserWindow = require('browser-window');
var window = null;
app.on('ready', function() {
window = new BrowserWindow({width: 800, height: 600});
window.loadUrl('https://github.com');
});
```
2014-05-10 01:17:10 +00:00
The web page is no different than a normal web page, except for the extra
2014-05-05 06:49:05 +00:00
ability to use node modules:
```html
<!DOCTYPE html>
<html>
<body>
<script>
var remote = require('remote');
console.log(remote.require('app').getVersion());
</script>
</body>
</html>
```
To run your app, read [Run your app](../tutorial/quick-start.md#run-your-app).