6 Eylül Salı ´11
Her yerde twitter naneleri gormeye alistik. Twitter da sitenize public timeline'inizi ekleyebilmeniz icin widget sunuyor ama benim gibi begenmeyip kendiniz tasarlamak istiyorsaniz twitter timeline'inizi api ile jquery'ye isletip kendi tasariminiza gomebilirsiniz.

Bunun icin su dokumani takip edin:http://mfyz.com/dokuman/123
Twitter'in kendi widgetları sayesinde twitter hesabınızın public timeline yani akışını sitenize ekleyebiliyorsunuz fakat o widgetı kullanmak zorunda değilsiniz. Twitter api ile akışınızı jquery ile alıp kendiniz çizebilirsiniz. Aslında çok basit. Twitter apisi zaten size public timeline'ınızı json nesnesi olarak veriyor herhangi bir api key kayıdı yapmaya gerek kalmadan.

Bu json nesnesinin adresi
http://api.twitter.com/1/statuses/user_timeline.json?screen_name=mfyz&count=10&callback=?
Adresteki mfyz benim twitter kullanıcı adım. count parametresiyle de en son pos edilen içeriklerin listesinin boyutunu belirleyebiliyorsunuz, sanırım bu parametrede bir üst limit var.

Yukaridaki adresi tarayıcınıza yapıştırırsanız json nesnesi alırsınız. jQuery ile bu json nesnesini işleyecegiz. Bunun için jquery'deki getJSON() fonksiyonunu kullanacağız. jQuery, normal .ajax() fonksiyonu gibi bu json nesnesini xmlhttprequest yani ajax ile alıp sonucunda işleyebileceğimiz bir javascript objesi olarak bize sunuyor.

Size bu işi yapan tüm kodu verip sonra kod üstünden açıklayacağım:
var $tweetList;
var $tweetUrl = 'http://api.twitter.com/1/statuses/user_timeline.json?screen_name=mfyz&&count=10&callback=?';

$.getJSON($tweetUrl, function (data) {
	$.each(data, function (i, item) {
		if (i == 0) {
			$tweetList = $('<ul class="tweetList">');
		}

		// handle @reply filtering
		if (item.in_reply_to_status_id === null) {
			$tweetList.append('<li class="tweet_content_' + i + '">' +
				'<p class="tweet_link_' + i + '">' +
				item.text.replace(/#(.*?)(\s|$)/g, '<span class="hash">#$1 </span>')
					.replace(/(\b(https?|ftp|file):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/ig, '<a href="$&">$&</a> ')
					.replace(/@(.*?)(\s|\(|\)|$)/g, '<a href="http://twitter.com/$1">@$1 </a>$2') +
				'</p></li>');
		}
	});

	$('#tweetStream').html($tweetList);
});
Yukaridaki kod 2 tane değişken tanımlaması ile başlıyor. Birisi api url'i diğeri de html kodunu üreteceğimiz taşıyıcı değişken. Gördüğünüz gibi getJSON fonksiyonu ile url'i belirtip ikinci parametre olarak callback fonksiyonunu tanımladık. Callback fonksiyonu, dönen json nesnesini içerir, bu örnekte "data" adındaki değişken olarak geçiyor. data dizisini dönerek tüm elemanları html kodu üreterek ekleyecegiz listeye.

Döngü içindeki ilk kontrolde eğer taşıyıcı değişken daha üretilmediyse html listesi olarak üretiliyor. Sonrasında bu liste içine satır olarak ekleyecegiz tüm twitter girdilerini.

Bir diğer kontrol ise sadece doğrudan yazılan tweet'leri işleyecegiz, bunu da yazılan tweet'in cevap olmamasını kontrol ederek yapıyoruz. Sonra da taşıyıcı listeye ekliyoruz tweet edilen yazıyı işleyerek. Bu aşamada ise regular expressions ile @username, #hashtag veya url gibi özel yazıları linklere dönüştürüyoruz.

Döngü bittiğinde de html'inizdeki herhangi bir elemanın içine bu üretilen listeyi basabilirsiniz, bu örnekte tweetStream kimliğine sahip nesnenin içine basılıyor.

Bu kodun calışan örneğini anasayfadaki sağdaki kolonda görebilirsiniz.
Home.js dosyasında yukarıdaki örnegi görebilirsiniz.

Hazırlayan: Mehmet Fatih YILDIZ

Popüler Etiketler

php coding apple iphone ipad facebook opengraph api optimization fql konsol terminal web app open source session cookie social macosx license mobile startups javascript js örnek kod google search ajax jquery firefox zaman html form input textarea select xml http server network app developer mssql music ie css3 support browser gimp rss lifestream parse chart grafik mysql db code browsers itunes workspace icon ikon download banner calendar logo notebook laptop lisans ubuntu button tebrik css radio switch applications free osx player less compile compiler windows linux on-the-fly twitter bootstrap html5 iOS ruffles wanda oyun digital howto nasıl connect box www subdomain redirect crossdomain newsletter mail ipucu regex medya date sql diff ui ux login webkit plugin media screen pharma hack wordpress export tool portfolio job mfyz language cache mootools xmlhttprequest table share meta spam cms wireless blog nedir doritos kampanya tytz link sitemap seo htaccess apache dokuman statistics istatistik insanlar database service svn subversion proje tarih query url mod_rewrite assets icons kontrol yapıları if while object injection imza signature development style widget auth optimizasyon analyse procedure generator kitap xhtml route router internet explorer pear mdb2 prepare execute ios app store store in-app purchase purchase verification integration storekit itunes connect design fstab ntfs subscription kurulum internet pgsql sosyal editor framework ide phpstorm jetbrains deployment version control git graph