Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Running dart in a web server

Tags:

dart

dartium

How do I run dart in a server? say in localhost or any web server? Currently google provides a dart editor which executes the code in dartium browser. Also even if I get to run it on a server would it be visible to others viewing the page in a browser other than dartium?

like image 818
gopi1410 Avatar asked Apr 28 '12 05:04

gopi1410


2 Answers

You can actually run Dart as a web server:

import 'dart:io';

main() {
  HttpServer.bind('127.0.0.1', 8080).then((server) {
    server.listen((HttpRequest request) {
      request.response.write('Hello, world');
      request.response.close();
    });
  });
}

That starts a web server on the local machine using port 8080. It simply returns "Hello, world".

From there all you need to do is define your routes, actions, etc.

like image 70
Levi Morrison Avatar answered Oct 17 '22 21:10

Levi Morrison


When you create a new "Web Application" using the Dart Editor, it creates a .html file and a .dart file. The html file uses a tag to link to the .dart file, eg:

MyApp.html //contains <script type="application/dart" src="MyApp.dart"></script>
MyApp.dart //contains dart app code.

The editor can also generate a javascript file from the .dart file, eg:

MyApp.dart.js //contains dart app code converted to JS

As far as a web server is concerned, these are simply static files that get served to the browser.

The html file contains a link to a special JavaScript script which can identify if the browser being used has native support for Dart (ie, Dartium).

  • If it does, then then the MyApp.html and MyApp.dart pair of files is used.

  • If the browser does not support Dart natively, then the special script dynamically changes the script element to point to the MyApp.dart.js file instead, so that the browser receives the javascript version of your app.

This means that you can copy the three files (.html, .dart, .js) onto any web server (localhost or otherwise), and simply browse to the .html file.

For completeness, the "special script" can be viewed here: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/client/dart.js

like image 33
Chris Buckett Avatar answered Oct 17 '22 23:10

Chris Buckett