How to Display Justin Bieber Tweets with Asynchronous Recursion
Tutorial Details
- Topic: Justin Bieber News (or JavaScript)
- Estimated Difficulty: Intermediate
- Format: 20 Minute Screencast
Bottom line: Justin Bieber = traffic. I fully intend to use this to my advantage, and none of you can do anything about it. The purpose of today’s video tutorial is to demonstrate how to use a scary set of words, “asynchronous recursion” to continuously display updated tweets about the great Biebster. And then finally, we’ll hijack these tweets to make them look as if they’re referring to Nettuts+ instead.
The Full Source
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>The Biebster</title>
</head>
<body>
<h2> Latest Biebster Tweets </h2>
<ul id="tweets"> </ul>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4.2/jquery.min.js"></script>
<script>
(function() {
var UpdatePanel = {
init : function(options) {
this.options = $.extend({
interval : 5000,
number : 3,
hijackTweet : false
}, options);
this.updater();
},
updater : function() {
(function updateBox() {
this.timer = setTimeout(function() {
updateIt();
updateBox();
}, UpdatePanel.options.interval);
})();
// get the ball rolling
updateIt();
function updateIt() {
$.ajax({
type : 'GET',
url : UpdatePanel.options.url,
dataType : 'jsonp',
error : function() {},
success : function(results) {
var theTweets = '',
elem = UpdatePanel.options.elem.empty();
$.each(results.results, function(index, tweet) {
if ( UpdatePanel.options.hijackTweet ) {
tweet.text = tweet.text.replace(/(Justin )?Bieber/ig, 'Nettuts');
}
if ( index === UpdatePanel.options.number ) {
return false;
}
else {
theTweets += '<li>' + tweet.text + '</li>';
}
});
elem.append(theTweets);
}
});
}
},
clearUpdater : function() {
clearTimeout(this.timer);
}
};
window.UpdatePanel = UpdatePanel;
})();
UpdatePanel.init({
interval : 5000,
number : 5,
url : "http://search.twitter.com/search.json?q=bieber",
elem : $('#tweets'),
hijackTweet : true
});
</script>
</body>
</html>
Conclusion
Thanks for watching; I hope you enjoyed it! Stay tuned to Nettuts+ for more news and gossip on Justin Bieber!
Note: Want to add some source code? Type <pre><code> before it and </code></pre> after it. Find out more
- http://smallbitsofcode.com Boba
- http://brianegan.com Brian Egan
- http://brianegan.com Brian Egan
- Ihab Khattab
- Ryan
- Tim
- http://sitebase.be Sitebase
- Overkil
- http://www.stav.co Mathias M. Stav
- Simon
- Liam
- w1sh
- http://coley.co Stephen Coley
- http://onelazydude.com Nikunj Chapagain
- http://philwebservices.i.ph/ John Paul
- http://www.myastrodata.com/ Vladimir
- http://www.shaherhan.com cloud
- http://matteoinvernizzi.altervista.org/projects/marquee.html do u remembrer old good websites?
- Zachary
- http://www.giulianoliker.com Giuliano
- Gregi
- http://shawntysco.com Shawn Tysco
- PDesign
- noname
- http://www.idesigncrap.wordpress.com Antor
- http://fabryz.com Fabryz
- http://www.isuez.com/ isuez
- bieberftl
- tigerlabs
- Brannon
- Nobody
- SKyintheSeA
- iamjem
- http://www.twostepmedia.co.uk Ben Howdle
- http://www.planetnana.co.il/punka1/justin-follow.htm Tirearredlota
- http://www.benedikt-wolters.de/blog Benedikt
- Alberto
