Connection Manager exposes Custom Events that track the progress of a transaction throughout its lifecycle. These Custom Events are raised at the global level and at the transaction level. The following code example provides a step-by-step approach to subscribing to transactional Custom Events raised by Connection Manager. In this scenario, an event handler object is created to handle all of the Custom Events; this event handler object is passed to Connection Manager in the callback object. Connection Manager will automatically subscribe to the events and fire the specified events.
Click "Send a Request" below to try it out, then read the description below to learn how to subscribe to transactional Custom Events in Connection Manager.
Load the Yahoo Global Object and Connection Manager source files:
1 | <script src="yahoo.js"></script> |
2 | <script src="event.js"></script> |
3 | <script src="connection.js"></script> |
view plain | print | ? |
Create an object to handle all the custom events fired by Connection Manager.
1 | var div = document.getElementById('container'); |
2 | |
3 | var transactionObject = { |
4 | start:function(type, args){ |
5 | div.innerHTML = "<li>Transaction " + args[0].tId + " " + type + " fired.<li>"; |
6 | }, |
7 | |
8 | complete:function(type, args){ |
9 | div.innerHTML += "<li>Transaction " + args[0].tId + " " + type + " fired.<li>"; |
10 | }, |
11 | |
12 | success:function(type, args){ |
13 | div.innerHTML += "<li>Transaction " + args[0].tId + " " + type + " fired.<li>"; |
14 | if(args[0].responseText !== undefined){ |
15 | div.innerHTML += "<li>Transaction id: " + args[0].tId + "<li>"; |
16 | div.innerHTML += "<li>HTTP status: " + args[0].status + "<li>"; |
17 | div.innerHTML += "<li>Status code message: " + args[0].statusText + "<li>"; |
18 | div.innerHTML += "<li>HTTP headers: " + args[0].getAllResponseHeaders + "<li>"; |
19 | div.innerHTML += "<li>Server response: " + args[0].responseText + "<li>"; |
20 | div.innerHTML += "<li>Argument object: Array ( [foo] => " + args[0].argument[0] +" [bar] => " + args[0].argument[1] +" )<li>"; |
21 | } |
22 | }, |
23 | |
24 | failure:function(type, args){ |
25 | div.innerHTML += "<li>Transaction " + args[0].tId + " " + type + " fired.<li>"; |
26 | if(args[0].responseText !== undefined){ |
27 | div.innerHTML += "<li>Transaction id: " + args[0].tId + "<li>"; |
28 | div.innerHTML += "<li>HTTP status: " + args[0].status + "<li>"; |
29 | div.innerHTML += "<li>Status code message: " + args[0].statusText + "<li>"; |
30 | } |
31 | }, |
32 | |
33 | abort:function(type, args){ |
34 | div.innerHTML += "<li>Transaction " + args[0].tId + " " + type + " fired.<li>"; |
35 | } |
36 | }; |
view plain | print | ? |
Let's create two functions to provide handlers for callback.success
and callback.failure
compatibility. The inclusion of these handlers will demonstrate their backward compatibility with Custom Events.
1 | var handleSuccess = function(o){ |
2 | div.innerHTML += "<li>Success response handler triggered in callback.success<li>"; |
3 | }; |
4 | |
5 | var handleFailure = function(o){ |
6 | div.innerHTML += "<li>Failure response handler triggered in callback.success<li>"; |
7 | }; |
view plain | print | ? |
Subscribe to the transaction custom events fired by Connection Manager by creating a customevents
object in the callback object. NOTE: callback.success and callback.failure are provided here to demonstrate backward compatibility, and would be redundant to customevents.onSuccess and customevents.onFailure, respectively.
1 | var callback = { |
2 | success:handleSuccess, |
3 | failure:handleFailure, |
4 | customevents:{ |
5 | onStart:transactionObject.start, |
6 | onComplete:transactionObject.complete, |
7 | onSuccess:transactionObject.success, |
8 | onFailure:transactionObject.failure, |
9 | onAbort:transactionObject.abort |
10 | }, |
11 | argument:["foo","bar"] |
12 | }; |
view plain | print | ? |
Call YAHOO.util.Connect.asyncRequest
to make a request to get.php
, and PHP will return the contents of $_GET
via print_r()
.
Each event handler in transactionObject
will be triggered in response to its custom event(e.g., transactionObject.start will be called when startEvent fires). In this example, event handlers are created and subscribed to all possible events raised by Connection Manager.
1 | var sUrl = "php/get.php?s=hello%20world"; |
2 | var request = YAHOO.util.Connect.asyncRequest('GET', sUrl, callback); |
view plain | print | ? |
Note: Logging and debugging is currently turned off for this example.
Copyright © 2008 Yahoo! Inc. All rights reserved.
Privacy Policy - Terms of Service - Copyright Policy - Job Openings