Ana içeriğe atla

TypeScript Nedir?

Konuya ufak bir örnekle başlayacağım...
C# programlama dilinde programlama yapıyorsanız yazdığınız kodların CLR aracılığıyla makine diline veya Java dilinde JVM aracılığıyla makine koduna dönüştürüldüğünü ve böyle çalıştırıldığını biliyorsunuzdur. Hemen hemen tüm browserlar (tarayıcılar) programlama dili olarak sadece JavaScript çalıştırabilecek ve bu dili anlayabilecek kapasitededir. Yani bir anlamda JavaScript web dünyasının makine kodudur diyebiliriz. Typescript kodları da derlenerek JavaScript kodlarında dönüştürülür ve web projelerinde bu kodlar çalıştırılır. Yani tarayıcılar Typescript kodunu anlamadığı için JavaScript'e dönüştürülmüş kodları çalıştırabilirler. (Geleceğin teknolojilerinden bir tanesi de Typescript programlama dilini anlayabilen derleyiciler olabilir)

JavaScript altyapı olarak nesne yönelimli bir dil olsa da günümüzde nesne yönelimli programlama farklı bir seviyeye gelmiş durumda ve bu açıdan JavaScript ile nesne yönelimli kalıpları uygulamak çok zor ve zahmetli bir süreçtir. Aynı zamanda JavaScript programlama dilinde değişken türlerinin tanımlanamıyor olması ve özellikle nesne yönelimli programlama mantığının encapsulation, interface, abstraction, polimorfizm ve başka kuralının uygulanamıyor olması günümüz için JavaScript teknolojilerinin en büyük problemlerinden bir tanesidir. (var türünde bir değişken tanımlamak işimizi her zaman kolaylaştırıyor diye düşünüyorsanız da henüz çok büyük projeler geliştirmemişsiniz demektir.... )


İşte JavaScript dünyasının bu gibi problemlerinin çözümü için TypeScript programlama dili ortaya çıkmıştır. Typescript programlama dili özellikle Angular teknolojisi tarafından tercih edilen programlama dili olduktan sonra, açık kaynak kodlu bir proje olduğu için de yaygınlığı ve kullanım oranı da giderek artmaktadır. 

"TypeScript Nedir?" sorusunun yanıtı ise TypeScript web uygulamaları geliştirmemizi sağlayan bir programalama dilidir ve JavaScript dünyasının değişken türleri tanımlama, kodlamadaki modüler yapı ve nesne yönelimli programlama eksiklerini gideren bir programlama dilidir. (Bazı yerlerde programlama dili olmadığına rastlayabilirsiniz. Giriş konusunda bahsettiğim gibi çalışma mantığı C#, Java, Python ve b. dillerle aynıdır. Sadece çıktısı JavaScript kodudur. Aksini iddia etmek bu dillerin de programlama dili olmadığını söylemekle aynı şeydir)

Aşağıdaki resimde TypeScript ve diğer JavaScript dillerinin karşılaştırması yer almaktadır. Gelişen bir teknoloji olan TypeScript eksiklerini giderme konusunda da başarılıdır. Bunun temel nedeni ise geliştirici kitlesinin son zamanlarda katlanarak artması ve Microsoftun da bu doğrultuda yatırımı artırmasıdır.


TypeScipt bir Microsoft teknolojisi olduğu için kodlama yapısı da C# programlama diline çok yakındır. Ama nesne mantığının uygulanmasında Java programlama dilinin kodlama kalıpları kullanılmıştır(Örneğin extends, implements gibi kelimeler)

TypeScript Özellikleri :
Typescript, JavaScript'in temel yapı taşlarını benimser. Dolayısıyla, yalnızca TypeScript'i kullanmak için JavaScript'i öğrenmeniz yeterlidir. Tüm TypeScript kodunun çalıştırılması için JavaScript diline dönüştürülmesi gerekir.
TypeScript, diğer JS kütüphenelerini destekler. Derlenmiş TypeScript, herhangi bir JavaScript kodunda tüketilebilir. TypeScript ile oluşan JavaScript kodu mevcut tüm JavaScript frameworkleri, araçları ve kütüphanelerini yeniden kullanabilir.
JavaScript, TypeScript’tir. Bunun anlamı .js uzantılı herhangi bir dosya .ts olarak yeniden adlandırabilir ve diğer TypeScript dosyalarıyla derlenebilir.
TypeScript portatiftir. TypeScript, tarayıcılar, aygıtlar ve işletim sistemleri arasında taşınabilir. JavaScript’in çalıştığı herhangi bir ortamda çalışabilir. TypeScript’in çalışması için sanal makineye (VM) veya özel bir runtime çalışma ortamına ihtiyacı yoktur.
,
TypeScript üç bileşene sahiptir
Dil: Sözdizimi(syntax), anahtar sözcükler (keywords) ve ek açıklamalardan oluşur.
TypeScript Derleyicisi: TypeScript Derleyicisi (tsc), TypeScript’te yazılmış komutları JavaScript karşılığına çevirir.
TypeScript Dil Servisi: Dil servisi, ifade tamamlama, kod formatlama, özetleme, renklendirme gibi tipik editör işlemlerinin gerçekleşmesini sağlar.

Yorumlar

Bu blogdaki popüler yayınlar

TypeScript Kurulu Versiyon Görüntüleme

"tsc" TypeScript compiler sözünün kısaltmasıdır ve TypeScript işlemlerini yapmak için kullanılan kısaltmadır. TypeScript programları yazarken herhangi bir derleyici kullanmıyorsanız bu komutu etkin kullanabiliyor olmanız gerekiyor. tsc --help komutunu kullanarak detaylı bilgileri görüntüleyebilirsiniz.  tsc aynı zamanda TypeScript  uygulamalarını derlemek için kullanılan komuttur ve tüm derleyiciler de alt yapısında bu komutu kullanarak derleme işlemlerini gerçekleştirir. tsc komutunun parametrelerinden bir tanesi de --versiyon parametresidir. Bu komut kurulu TypeScript sürümünü görüntülemek için kullanılan parametredir. Bilgisayarınızda kurulu olan TypeScript versiyonunu görüntülemek için de aşağıdaki komutu çalıştırmanız gerekiyor. tsc --version TypeScript ile uygulama geliştirirken mümkün olduğu kadar en son versiyonla çalışmak sizin yeni özellikleri kullanmanız için önemlidir. Blog içerisinden kullandığınız sürüme kadar olan özellikleri anlatan...

TypeScript Nerelerde Kullanılır?

Bir programlama dili olarak TypeScript JavaScriptle programlama yapılan tüm projelerde kullanılabilir. TypeScript bir anlamda nesne yönelimli JavaScript anlamında geldiği için çoğu yeni teknoloji de bu programlama dilinin üzerine inşa edilmiştir. Bunlarda en bilineni Angular teknolojisidir. Hatta TypeScript programlama dili Angular teknolojisinin de yaygınlaşması ve kullanımı ile birlikte tamamen bu teknoloji ile özdeşleşmiştir. Buna rağmen siz nodejs ile yazdığınız bir sunucu uygulamasında da TypeScript kullanabilirsiniz ve bu tamamen size kalmış durumda. TypeScript temel olarak .ts uzantılı dosyalarda çalışıyor. Yani siz ts uzantılı dosyalara kodlarınızı yazıyorsunuz. Bu süreçten sonra ister kullandığınız IDE, ister konsol ekranından .Net framework de ki gibi derleniyor ve javascript diline dönüştürülüp yorumlanıyor. Örneğin .Net frameworkü için derleme sonucu makine kodu iken, TypeScript için bu işlem JavaScript kodlarıdır. Yani siz TypeScript’e göre program yazarken sunuc...

TypeScript Veri Tipleri - Number

Number veri tipi TypeScript programlama dilinde tüm sayısal verileri tanımlayabileceğimiz veri türüdür ve kayan noktalı sayılar, ikilik, sekizlik ve on altılık sayı sistemleri ile desteklenmiştir. Tek farkı ise bu veri türlerinin hepsinin tek değişken türünde birleştirilmesidir. Bu özelliği ile de TypeScript bir çok programlama dilinden pozitif anlamda ayrışmaktadır. Aslında bu özelliği ile aynı zamanda JavaScript kökeninden de uzaklaşamamışdır diyebiliriz. Number veri tipini daha detaylı incelemek için örnek bir program yazalım. Yazdığımız kodları TypeScript derleyicisi ile JavaScript kodlarına dönüştürüldüğünde nasıl bir çıktı aldığımızı ve aynı zamanda da bu çıktıyı NodeJS aracılığı ile çalıştırarak nasıl bir çıktı aldığımızı da inceleyelim. Böylece number olarak tanımladığımız değişkenlerin arka tarafta nasıl bir süreçten geçtiğini detaylı incelemiş olacağız. Örnek uygulamamız için kayan noktalı sayı, tam sayı, ikilik, sekizlik ve onaltılık sayı sistemi ile değişken tanımla...