TypeScript, düz JavaScript'e derlenen, JavaScript'in türü belirtilmiş bir üst kümesidir. Aşağıdaki snippet'te TypeScript kullanılarak Google Haritalar'ın basit kullanımı gösterilmektedir.
let map: google.maps.Map;
const center: google.maps.LatLngLiteral = {lat: 30, lng: -110};
function initMap(): void {
map = new google.maps.Map(document.getElementById("map") as HTMLElement, {
center,
zoom: 8
});
}
Başlarken
DefinitelyTyped projesi, Google Haritalar dahil olmak üzere birçok paket için tür beyan dosyalarını barındıran açık kaynak bir projedir. Google Haritalar JavaScript beyan dosyaları (GitHub'daki kaynak dosyalarına bakın), @types/google.maps paketinden NPM kullanılarak yüklenebilir.
npm i -D @types/google.maps
Alfa ve Beta Özellikleri
Türler genellikle alfa veya beta sürümlerinde bulunan özelliklere, işlevlere ya da sınıflara sahip değildir. Bu tür durumların çoğunda nesne doğru türe atanabilir.
Aşağıdaki hata, MapOptions
için mapId
beta özelliğinden kaynaklanmaktadır.
error TS2345: Argument of type '{ center: google.maps.LatLng; zoom: number; mapId: string; }' is not assignable to parameter of type 'MapOptions'. Object literal may only specify known properties, and 'mapId' does not exist in type 'MapOptions'.
Yukarıdaki hata, aşağıdaki yayınla düzeltilebilir.
{ center: {lat: 30, lng: -110}, zoom: 8, mapId: '1234' } as google.maps.MapOptions
Çakışan @types paketleri
Bazı kitaplıklar @types/google.maps dışında bir paket kullanabilir. Bu durum, çakışmalara neden olabilir. Tutarsız türlerle ilgili sorunları önlemek için skipLibCheck derleyici seçeneğini kullanın.
{
"compilerOptions": {
"skipLibCheck": true
}
}
typeRoots öğesini belirtme
Angular gibi bazı çerçeveler, @types/google.maps ve diğer tüm "@types" paketlerinden yüklenen türleri dahil etmek için typeRoots derleyici seçeneğinin belirtilmesini gerektirebilir.
{
...
"compilerOptions": {
...
"typeRoots": [
"node_modules/@types",
],
...
}
}