※2012.10.11現在Twitter API変更によりこの方法は使用できなくなりました。
新API(var1)に対応した方法は下記をご覧ください。

2012年10月 Twitter APIの変更によりjQueryでつぶやきが表示できなくなったので解決策

demo

まずは読み込むべきデータの確認をしてみましょう。
下記のURIで自分のタイムラインの情報を見ることができます。[USERNAME]には自分のアカウント名に置き換えてください。

http://twitter.com/statuses/user_timeline/[USERNAME].json

データはjsonの他にもxml、rssなど取得できます、最後のjsonの拡張子を変えるだけでそれぞれのフォーマットで取得できます。
今回は処理が速いといわれるjson形式で取得してみます。
他にもフォロアーのタイムラインやリストなども取得できますが、ログインしなくては見られない情報はOAuth認証などの処理が必要になります。

自分のつぶやきを取得

HTMLにはあらかじめdiv要素に#twitterなどでマークアップしておきます。

HTML

  1. <div id="twitter"></div>

JavaScript

  1. <script src="js/jquery.js" type="text/javascript"></script>
  2. <script type="text/javascript">
  3. $(function() {
  4. $.getJSON('http://twitter.com/statuses/user_timeline/[USERNAME].json?callback=?', function (json) {
  5. //配列に入れる
  6. for(var i in json){
  7. $("#twitter").append("<p>" + json[i].text + "</p>");
  8. }
  9. });
  10. });
  11. </script>

自分のつぶやきは「text」で取得できます。
これで#twitterにp要素でひたすらTwitterのtextが追加されます。
json.lengthで取得した配列分だけ表示しますので、表示数を設定する場合はこの部分を変更すると良いかもしれません。

投稿時間を表示

とりあえず自分のつぶやきは表示されたはずですが、これではよくわからない気がするので投稿時間も表示してみましょう。
つぶやきは「text」でしたが、時間は「created_at」です。
単純に「json[i].text」の部分を「json[i].created_at」に変えて実行してみましょう。

Fri Jun 05 17:07:09 +0000 2009

こんな感じで表示されるはずです。
こ、これはわかりにくいですね。
なので、読みやすい形に変換してみましょう。

投稿時間を見やすいフォーマットに変換

今回は、「php_date.js」というライブラリを使います。
「php_date.js」はdate関数をPHP風に使えるという大変便利なライブラリです。
下記URLからダウンロードしてください。

※最新のv0.3.0では下記の方法だと表示できないようです。この記事のサンプルはv0.2.0を使用しています。

php_date.js
http://rewish.org/javascript/php_date

ダウンロードしてファイルを読み込んだら早速使用してみましょう。
formatメソッドに書式と変換したい値(created_at)を渡すだけで、フォーマットされて返ってきます。

  1. var dateObj = new Date;
  2. dateObj.format('Y-m-d H:i:s', json[i].created_at);

これで完成と思いきや、このままだと日付がIEでは「Nan」と表示されて正しく表示されません。
これは、文字列を置き換えることで解決できるようです。

twitterAPI JSON|created_at|ie 対応
http://blog.artvecta.net/archives/159

URL、リプライ、ハッシュタグを正規表現で置き換えてリンクを付ける

今の状態だとテキストを素のまま表示しているだけですね。
取得したテキストに正規表現を使用してリンクを付けてみましょう。
各正規表現は次のようになります。

URL

/(s?https?:\/\/[-_.!~*'()a-zA-Z0-9;\/?:\@&=+\$,%#]+)/

ハッシュタグ

/#(\w+)/ → 【リンク先】 http://twitter.com/search?q=%23[ハッシュタグ名]

リプライ

/@(\w+)/ → 【リンク先】 http://twitter.com/[リプライ名]

最終的なコード

dl要素でマークアップしてみました。

JavaScript

  1. <script src="js/jquery.js" type="text/javascript"></script>
  2. <script src="js/php_date.js" type="text/javascript"></script>
  3. <script type="text/javascript">
  4. $(function() {
  5. //IE対策
  6. function replaceTwTimeStr(time){
  7. var tArray = time.split(" ");
  8. var timeStr = tArray[0] + " " + tArray[1] + " " + tArray[2] + " " + tArray[5] + " " + tArray[3] + " " + tArray[4];
  9. return timeStr;
  10. }
  11. var dateObj = new Date;
  12. $.getJSON('http://twitter.com/statuses/user_timeline/[USERNAME].json?callback=?', function (json) {
  13. for(var i in json){
  14. var text = json[i].text;
  15. //URLにリンクを付ける
  16. text = text.replace(/(s?https?:\/\/[-_.!~*'()a-zA-Z0-9;\/?:@&=+$,%#]+)/gi,'<a href="$1">$1</a>');
  17. //ハッシュタグにリンク
  18. text = text.replace(/#(\w+)/gi,'<a href="http://twitter.com/search?q=%23$1">#$1</a>');
  19. //リプライにリンク
  20. text = text.replace(/@(\w+)/gi,'<a href="http://twitter.com/$1">@$1</a>');
  21. //つぶやきを表示
  22. $("#twitter dl").append("<dt>" +
  23. dateObj.format('Y-m-d H:i:s', replaceTwTimeStr(json[i].created_at)) +
  24. "</dt><dd>" + text + "</dd>");
  25. }
  26. });
  27. });
  28. </script>

HTML

  1. <div id="twitter"><dl></dl></div>