Introduction to the

Dart: THE HTML package provides dart with some of the components necessary to build a browser client. In addition to the HTML and DOM manipulation mentioned earlier, another common operation on the browser side is to use XMLHttpRequest to make asynchronous HTTP resource requests, also known as AJAX requests.

Dart also provides a wrapper similar to XMLHttpRequest in JAVASCRIPT. The corresponding class is called HttpRequest. Check out how to use HttpRequest in DART.

Send a GET request

Although modern Web apps are encapsulated by various frameworks, they are ultimately AJAX rich client applications. We request data from the server side through various asynchronous HTTP requests, which are then displayed on the page. The usual data interaction format is JSON, but there are other data interaction formats as well.

The most common form of AJAX is to send a get request to the server. The HttpRequest has a getString method:

static Future<String> getString(String url, {bool? withCredentials, void onProgress(ProgressEvent e)? }) { return request(url, withCredentials: withCredentials, onProgress: onProgress) .then((HttpRequest xhr) => xhr.responseText!) ; }Copy the code

Note that the getString method is a class method, so call it directly using the HttpRequest class:

var name = Uri.encodeQueryComponent('John'); var id = Uri.encodeQueryComponent('42'); HttpRequest.getString('users.json? name=$name&id=$id') .then((String resp) { // Do something with the response. });Copy the code

Because getString returns a Future, you can simply follow getString with a then statement to get the returned value.

Of course, you can also use await in async methods to get the return value.

Future<void> main() async {
  String pageHtml = await HttpRequest.getString(url);
  // Do something with pageHtml...
}
Copy the code

Or use try catch to catch exceptions:

try {
  var data = await HttpRequest.getString(jsonUri);
  // Process data...
} catch (e) {
  // Handle exception...
}
Copy the code

Send a POST request

GET pulls data from the server, and the corresponding POST is the common method of submitting data to the server. In HttpRequest, the corresponding method is postFormData:

static Future<HttpRequest> postFormData(String url, Map<String, String> data, {bool? withCredentials, String? responseType, Map<String, String>? requestHeaders, void onProgress(ProgressEvent e)? }) { var parts = []; data.forEach((key, value) { parts.add('${Uri.encodeQueryComponent(key)}=' '${Uri.encodeQueryComponent(value)}'); }); var formData = parts.join('&'); if (requestHeaders == null) { requestHeaders = <String, String>{}; } requestHeaders.putIfAbsent('Content-Type', () => 'application/x-www-form-urlencoded; charset=UTF-8'); return request(url, method: 'POST', withCredentials: withCredentials, responseType: responseType, requestHeaders: requestHeaders, sendData: formData, onProgress: onProgress); }Copy the code

As can be seen from the implementation of the method, the default content-type: application/ X-www-form-urlencoded; Charset =UTF-8, which means the default is form submission.

In this case, the uri. encodeQueryComponent is encoded first for the data that carries the data, and then joins with &.

Here’s an example:

var data = { 'firstName' : 'John', 'lastName' : 'Doe' };
        HttpRequest.postFormData('/send', data).then((HttpRequest resp) {
          // Do something with the response.
       });
Copy the code

Note that postFormData returns an HttpRequest, which is called Request, but can actually contain a response. So just use it to get the returned content.

More general operation

Above we looked at get and form post, and you can see from the code that both of them actually call request. Request is a more general HTTP request method. HTTP operations such as POST, PUT, and DELETE are supported. Here is the request method definition:

static Future<HttpRequest> request(String url, {String? method, bool? withCredentials, String? responseType, String? mimeType, Map<String, String>? requestHeaders, sendData, void onProgress(ProgressEvent e)? })Copy the code

SendData can be [ByteBuffer],[Blob], [Document], [String], or [FormData].

ResponseType represents HttpRequest responseType, is to return the format of the object, by default is a String, also can be ‘arraybuffer’, ‘a blob’, ‘document’, ‘json’, or ‘text’.

Here is an example of using request directly:

        var myForm = querySelector('form#myForm');
        var data = new FormData(myForm);
        HttpRequest.request('/submit', method: 'POST', sendData: data)
          .then((HttpRequest resp) {
            // Do something with the response.
        });
Copy the code

conclusion

Using HttpRequest, you can directly simulate Ajax operations in the browser, which is very convenient.

This article is available at www.flydean.com/21-dart-htt…

The most popular interpretation, the most profound dry goods, the most concise tutorial, many tips you didn’t know waiting for you to discover!

Welcome to pay attention to my public number: “procedures those things”, understand technology, more understand you!