22 Şubat 2017 Çarşamba

Unity Google Play Servisleri Entegrasyonu

Yorum Bırak


Kullanıcıların oyununuzda oturum açıp Google Play Oyun Hizmetleri'ni kullanabilmesi için oyununuzu Geliştirici Konsolu'na (Play Developer) kaydettirmeniz gerekmektedir. Bu yazıda, Geliştirici Konsolu'nda bir Play Oyun Hizmetleri projesi oluşturup onu Unity projenize nasıl bağlayacağınıza bakacağız. Bu kısımda oyunumuzun hazır olduğunu varsayıp sadece google play entegrasyonu kısmına bakacağız.

Oyun Projemizi Oluşturalım

  1. Google Play Geliştirici Konsolu'na gidip ve oturum açalım. Henüz bir hesabınız yoksa, hesap oluşturmanız gerekecek.
  2. Oyun Hizmetleri'ni tıklayın ve ardından sağ üstteki Yeni oyun ekle düğmesini tıklayın.
  3. 'Oyunumda henüz herhangi bir Google API kullanmıyorum' başlıklı sekmeyi seçin.
  4. Oyununuzun adını yazın ve oyun kategorisini seçip Devam et'i tıklayın.
  5. Son olarak, formun üst kısmındaki Kaydet'i tıklayarak bu oyunun ayarlarınızı kaydedin.

Android Uygulamamızı Bağlayalım

  1. Sol kenar çubuğundaki Bağlı Uygulamalar(Linked Apps) sekmesini tıklayalım, ardından Android'i tıklayalım.
     Not: Bir 'Bağlantılı Uygulamalar' düğmesi görmüyorsanız, pencerenizi tam ekrana getirin veya sol taraftaki 'hamburger' düğmesini tıklayın.
  2. Paket Adı (Package Name) altında, Unity projenizi oluştururken seçtiğiniz Paket Tanımlayıcı'yı  (Bundle Identifier) (Dosya> Yapı Ayarlarını açıp Oynatıcı Ayarlarını tıklayarak bulabilirsiniz - File>Build Settings>Player Settings) koyalım. Her iki yerde de aynı string ifadeyi kullandığımızdan emin olalım. Ardından Kaydet ve devam et'i tıklayalım.
  3. Bir sonraki ekranda Authorize your app now'i tıklayın. Bu kısımda Marka Bilgilerini girmeniz gereken bir dialog gelebilir. Burası oturum açma ekranında görünen bilgileri kontrol edebileceğiniz yerdir, ancak bunu şimdilik atlayacağız. 'Devam Et'i tıklamanız yeterlidir.
  4. İstemci Kimliği Ayarları (Client ID Settings) iletişim kutusunda bir 'Sertifika parmak izi imzalama (SHA1) imzalama'  girmeniz gerekmektedir. Bunu Android debug keystore'dan oluşturmanız gerekecek. Bunu oluşturmak için aşağıdaki keytool komutunu kullanabiliriz (keytool, Oracle JDK'nın bir parçasıdır ve makinenizde JDK'nızın bin dizinine önceden kurulmuş olmalıdır):

    #  $DEBUG_KEYSTORE kısmını kendi android debug keystore lokasonunuz ile değiştirin
    # Bu lokasyon normalde Mac/Linux bilgisauarlarda : $HOME/.android/debug.keystore 
  5. #Windows bilgisayarlarda: C:\Users\<USERNAME>\.android\debug.keystore şekindedir.
    keytool -list -v -keystore $DEBUG_KEYSTORE -alias androiddebugkey -storepass android -keypass android
      5. Komut çalıştırdıktan sonra çıkan SHA1 parmak izini kopyalayın. Ardından Create Client'ı                   tıklayın. Her şeyi doğru yapmışsanız, 'Successfully linked your Client ID' mesajını, ardından             bir  İstemci Kimliği (Client ID) stringi görmelisiniz. Bu dizeye ihtiyacınız olmayacaktır, bu                 nedenle yazmaya zahmet etmeyin.

     
6. Sol kenar çubuğundaki Test sekmesini tıklayın. Ardından Add Testers'i tıklayın ve bu oyunu                test etmek için kullanacağınız tüm Google hesaplarını ekleyin. Bunlar, Android geliştirme                    cihazınızdaki hesaplarla aynı olmalıdır.

Developer Konsol'dan LeaderBoard Oluşturma

  1.  Google Play Developer Console'daki projenize geri dönüp Leaderboards tabına tıklayalım.
  2.  Add Leaderboard kısmına tıklayıp skorları tutacağımız bilgileri girelim
  3. Name: "Top Skorlar"
  4. Score Formatting: Numeric
  5. Number of Decimal places: 0 (virgülden sonraki puanlar içindir, biz tam değerler gireceğiz bu yüzden bu kısımı 0 yaptık)
  6. Ordering: "Larger is better".(Burası da Sıralama kısmı, büyük skorlar daha iyidir bizim için)
  7. Kaydet deyip bitirelim.
Şimdi oluşturduğunuz Leaderboard ile ilgili  bilgileri görebilmelisiniz.

Play Games Unity Plugin Ayarları

Geliştirici Konsolu'nda bir oyun projesi oluşturduğumuza göre, Unity projemizi Play Oyun Hizmetleri ile etkileşim kuracak şekilde yapılandırmaya hazırız.

 Play Oyun Hizmetleri Plugin'i Import Etme

  1. Unity için google play servisleri plugini buradan indirebilirsiniz.
  2. İndirikten sonra Unity'i açıp Assets > Import Package > Custom Package menüsünden indirdiğimiz dosya içerisinden current-build/GooglePlayGamesPlugin-*.unitypackage from the play-games-plugin-for-unity plugini seçip import diyoruz.
  3. Böylece plugini unity oyunu içerisine import ettik. Şimdi de gerekli ayarları yapacağız.
  4. Unity projesini açın ve Window > Google Play Games > Setup > Android Setup'ı tıklayalım.
  5.  "constants class name" için GPGSIds kullanın.
  6. Play Oyun konsoluna geri dönelim ve leaderboard resources  listesine gidelim (hala orda olmalısınız ...). Sayfanın ortasındaki Kaynakları Al'ı (Get Resources ) tıklayın ve Android içeriğini panoya kopyalayın.
  7. Pano içeriğini Resources Definition metin alanına yapıştırın.
  8. Diğer ayarları ve web client Id'yi boş bırakabilirsiniz.
  9. Setup'ı tıklayın.

Kurulumun başarıyla yapıldığına dair bir onay olacak, Setup'ı tıklayın. İşlemleri başarıyla tamamladığımızda girdiğimiz bilgiler aşağıdakine benzer olmalıdır:
Unity Google Play Servisleri Entegrasyonu

Google Play Hesabı ile Oturum Açma ve Skor Kaydetme

Bu aşamaya kadar herşeyi başarılı bir şekilde yaptıysak unity pluginimiz google play servislerine bağlanmaya hazır olması gerekmektedir. Şimdi de oyun kodumuz içerisinde servisleri initialize edip oturum açacağız.

using System.Collections;
using GooglePlayGames;
using GooglePlayGames.BasicApi;
using UnityEngine;

public class MainMenuEvents : MonoBehaviour {

 
    public void Start() {

        // Bu kısımda servisi initialize ediyoruz
        PlayGamesClientConfiguration config = new 
            PlayGamesClientConfiguration.Builder()
            .Build();

        // Enable debugging output (recommended)
        PlayGamesPlatform.DebugLogEnabled = true;
        
        // Initialize and activate the platform
        PlayGamesPlatform.InitializeInstance(config);
        PlayGamesPlatform.Activate();

    }

}


Oyunumuzun Start metodu içerisinde servisimizi initialize ettik. Şimdi de SignIn metodunu ve callback metodunu yazalım:

   public void SignIn() {
        if (!PlayGamesPlatform.Instance.localUser.authenticated) {
            //  Play Game Servisleri için SignIn metodu, 
            PlayGamesPlatform.Instance.Authenticate(SignInCallback, false);
        } 
    }

Aşağıda da callback metodumuz var, bu metod SignIn işlemi tamamlanınca çalışır.

public void SignInCallback(bool success) {
        if (success) {
            Debug.Log("Giriş başarılı!");
            // bu kısımda giriş yaptıktan sonra yapmak istediğiniz ekstra şeyler varsa yazabilirsiniz
        } else {
            Debug.Log("Giriş başarısız");
            //bu kısıma gelindiyse giriş başarısızdır.
        }
    }

SignIn metodumuzu da nerde giriş yapmak istiyorsak orda çalıştırabiliriz. İstersek button click eventine verebiliriz, istersek de direk otomatik giriş yapmasını istiyorsak Start metodumuzun en altına koyabiliriz.

Skor Kaydetme ve Skor Listesini Gösterme

Google Play hesabımızla giriş işlemini de yaptığımıza göre şimdi de skorları kaydetme işlemine bakabiliriz:

if (PlayGamesPlatform.Instance.localUser.authenticated)
            {
int kaydedilecekSkor=10;
                //  'using GooglePlayGames' referansını eklemeyi unutmayalım
                PlayGamesPlatform.Instance.ReportScore(kaydedilecekSkor,                    GPGSIds.serviseKaydettiğimizString,
                    (bool success) =>
                    {
                        Debug.Log("Skor başarıyla kaydedildi ");
                    });
            }

Yukarıdaki kısımda skor kaydetme işlemini yaptık. Ben şimdilik 10 şeklinde bir skor kaydettim. Siz buraya kendi skorunuzu parametre ile gönderip metod haline geriebilirsiniz. GPGSIds.serviseKaydettiğimizString kısmı da google play kaynaklarında unitye eklerken kullandığımız kısım. 

Şimdi de skorları gösterme dialogunu açalım:

 public void ShowLeaderboards() {
        if (PlayGamesPlatform.Instance.localUser.authenticated) {
            PlayGamesPlatform.Instance.ShowLeaderboardUI();
        }
        else {
          Debug.Log("Skorlar gösterilemiyor- giriş yapılmadı");
        }
    }

Bu kısımda da skorlar dialogunu gösterdik.

Sonuç

Sonuç olarak google play konsole da oyunumuzun ayarlarını yapıp, untiy'e plugini import ettik ve android  için gerekli ayarları yaptık. Daha sonra servisleri intialize etme, oturum açma, skorları gönderme ve skor listesini gösterme işlemlerini yaptık. Siz de bu yazıdan ilerleyerek kendi oyununuza google play servislerini entegre edebilirsiniz.

Bu yazıda buradan yararlanılmıştır.
Yazıyı Oku

Asp.Net Mvc ile Mail Gönderme İşlemi

2 yorum
Bir web ortamında e-postanın en yaygın kullanımlarından birisi, ziyaretçilerin bir form aracılığıyla site sahipleriyle iletişim kurmalarını sağlamaktır. Aşağıdaki adımlarda, yeni bir MVC 5 uygulaması oluşturup mail gönderme işlemine bakacağız.

Visual Studio'yu açın ve New Project bağlantısından veya File »New» Project seçeneğinden yeni bir proje oluşturalım. C # şablonlarından ASP.NET Web Project'i seçin ve Ok tıklayın.

Asp.Net Mvc ile Mail Gönderme İşlemi


MVC'yi seçin ve diğer seçenekleri olduğu gibi bırakarak Ok'i tıklayın.

Models klasörüne yeni bir class dosyası ekleyin ve adını EmailFormModel.cs olarak kaydedin. Varolan kodun içerğini aşağıdakiyle değiştirin:

using System.ComponentModel.DataAnnotations;

namespace MVCEmail.Models
{
    public class EmailFormModel
    {
        [Required, Display(Name="Your name")]
        public string FromName { get; set; }
        [Required, Display(Name = "Your email"), EmailAddress]
        public string FromEmail { get; set; }
        [Required]
        public string Message { get; set; }
    }
}

Views\Home klasörü içerisine Contact.cshtml View dosyasını oluşturalım ve içindeki kodu aşağıdaki kod ile değiştirelim:

@model MVCEmail.Models.EmailFormModel
@{
    ViewBag.Title = "Contact";
}
<h2>@ViewBag.Title.</h2>

@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()
    <h4>Send your comments.</h4>
    <hr />
    <div class="form-group">
        @Html.LabelFor(m => m.FromName, new { @class = "col-md-2 control-label" })
        <div class="col-md-10">
            @Html.TextBoxFor(m => m.FromName, new { @class = "form-control" })
            @Html.ValidationMessageFor(m => m.FromName)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(m => m.FromEmail, new { @class = "col-md-2 control-label" })
        <div class="col-md-10">
            @Html.TextBoxFor(m => m.FromEmail, new { @class = "form-control" })
            @Html.ValidationMessageFor(m => m.FromEmail)
        </div>
    </div>
    <div class="form-group">
        @Html.LabelFor(m => m.Message, new { @class = "col-md-2 control-label" })
        <div class="col-md-10">
            @Html.TextAreaFor(m => m.Message, new { @class = "form-control" })
            @Html.ValidationMessageFor(m => m.Message)
        </div>
    </div>
    <div class="form-group">
        <div class="col-md-offset-2 col-md-10">
            <input type="submit" class="btn btn-default" value="Send" />
        </div>
    </div>
}

@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
}
HomeController dosyasının içerisine en üste aşağıdaki referansları ekleyelim:


using MVCEmail.Models;
using System.Net;
using System.Net.Mail;
Aşağıdaki AsynchronousContact yöntemini HomeController.cs dosyasına ekleyin ve ayarları yorum kısmında belirtilen geçerli değerlerle değiştirelim:


[HttpPost]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Contact(EmailFormModel model)
{
    if (ModelState.IsValid)
    {
        var body = "<p>Email From: {0} ({1})</p><p>Message:</p><p>{2}</p>";
        var message = new MailMessage();
        message.To.Add(new MailAddress("recipient@gmail.com"));  // replace with valid value 
        message.From = new MailAddress("sender@outlook.com");  // replace with valid value
        message.Subject = "Your email subject";
        message.Body = string.Format(body, model.FromName, model.FromEmail, model.Message);
        message.IsBodyHtml = true;

        using (var smtp = new SmtpClient())
        {
            var credential = new NetworkCredential
            {
                UserName = "user@outlook.com",  // geçerli mail adresi ile değiştirin
                Password = "password"  // geçerli şifre ile değiştirin
            };
            smtp.Credentials = credential;
            smtp.Host = "smtp-mail.outlook.com";
            smtp.Port = 587;
            smtp.EnableSsl = true;
            await smtp.SendMailAsync(message);
            return RedirectToAction("Sent");
        }
    }
    return View(model);
}

HomeController'a aşağıdaki metodu ekleyelim:

public ActionResult Sent()
{
    return View();
}
Views\Home klasörü içerisine Sent.cshtml View dosyasını oluşturalım ve içindeki kodu aşağıdaki kod ile değiştirelim:

@{
    ViewBag.Title = "Sent";
}
<h2>Your message has been sent</h2>

Varsayılan olarak, e-posta iletileri düz metin olarak oluşturulur. Bir HTML e-postası göndermek isterseniz, HTML'yi Body özelliğine (bu örnekte olduğu gibi) iletirsiniz ve açıkça IsBodyHtml özelliğini true olarak ayarlarsınız.

Mesaj oluşturulduktan sonra gönderilmesi gerekmektedir. Bu görevden SmtpClient sınıfı sorumludur. SmtpClient nesnesinin yapılandırması genellikle çoğu e-posta gönderme hatasının oluştuğu yerdir, bu nedenle doğru ayarları kullandığınızdan emin olmalısınız. Hem Outlook hem de Gmail için bu ayarar hemen hemen aynıdır:

GmailOutlook/Live
Hostsmtp.gmail.comsmtp-mail.outlook.com
Port587587
EnableSsltruetrue
User NameYour email addressYour email address
PasswordYour account passwordYour account password
Burada sunulan hizmetlerden herhangi birini kullanmıyorsanız, doğru değerler için mail sağlayıcınızın belgelerine bakmalısınız.

Son olarak, F5 tuşuna basarak uygulamayı çalıştıralım, Contacts sayfasına gidip bir mail göndermeyi deneyelim. İşlem başarılı olursa bizi Sent sayfasına yönlendirecektir ve "Your message has been sent"
yazısı karşımıza çıkacaktır.
Yazıyı Oku

21 Şubat 2017 Salı

Asp.Net Core ile Merhaba Dünya Uygulaması

Yorum Bırak

Asp.Net Core ile Merhaba Dünya Uygulaması

Bu yazıda, Visual Studio 2017 kullanarak basit bir .NET Core konsol uygulaması oluşturma işlemine bakacağız. Visual Studio 2017, .NET Core uygulamaları oluşturmak için tam özellikli bir geliştirme ortamı sağlar. Uygulama .NET Core'un hedeflediği herhangi bir platformda ve .NET Core'un yüklü olduğu herhangi bir sistemde çalışabilir.

Uygulamayı geliştirmek için makinenizdeVisual Studio 2017 yüklü olmalıdır. Henüz kurmadıysanız, Visual Studio Professional veya Visual Studio Enterprise deneme sürümünü indirebilir veya ücretsiz Visual Studio Community Edition'ı Visual Studio Yüklemelerinden indirebilirsiniz. Yüklemeye başlarken, Visual Studio, aşağıdaki şekilde gösterildiği gibi, isteğe bağlı bileşenleri seçmenize izin verecek şekilde yüklenebilir. .NET Çekirdeği ve Docker (Önizleme) özelliğini seçiyoruz.

Basit bir "Merhaba Dünya" konsolu uygulaması oluşturarak başlayalım. Aşağıdaki adımları izleyelim:


  1. Visual Studio'yu başlatalım ve File menüsünden New, Project seçelim. Yeni Proje iletişim kutusunda, soldaki bölmede Visual C # düğümünü genişletip, ardından .NET Core düğümünü seçelim.
  2.   Sağdaki bölmede, Kosol Uygulamasını (.NET Core) seçelim. Aşağıdaki resimde gösterildiği gibi, projenin adı olan HelloWorld'ü girip, solution için dizin oluştur seçeneğini işaretleyelin.



Asp.Net Core ile Merhaba Dünya Uygulaması


3. Aşağıdaki resimde görüldüğü Main metodu içerisinde ekrana "Hello World" bastıran default bir kod örneği açıldı. Uygulamayı çalıştırdığımızda Main metodu çalışacak ve ekrana aşağıdaki resimdeki gibi yazıyı basacaktır.

Mevcut uygulamamızı konsol penceresini kapatmadan önce duraklatalım. Aşağıdaki kodu WriteLine (String) metodu  çağırdıktan hemen sonra ekleyelim böylece konsol açıldıktan sonra kapanması için klaveyeden giriş yapmamızı isteyecektir.



Şimdi de uygulamamızı, kullanıcının adını soracak şekilde geliştirip, konsol penceresine tarih ve saat ile birlikte görüntüleyelim. Programı değiştirmek ve test etmek için aşağıdakileri yapalım:

Aşağıdaki C # kodunu Main metodumuz içerisine yazalım:

Console.WriteLine("\nAdınız nedir? ");
var isim = Console.ReadLine();
var tarih = DateTime.Now;
Console.WriteLine("\nMerhaba, {0}, tarih: {1:d} at {1:t}", isim, tarih);
Console.Write("\nÇıkış yapmak için bir tuşa basınız...");
Console.ReadKey(true);

Kodu çalıştıralım ve ekrana "Adınız nedir?" diye sorduğunu göreceğiz. Örneğin "odan" girelim ve enter'a basalım. Bize "Merhaba odan" ve içinde bulunduğunuz tarihin bastıracaktır. Böylece .Net Core ile basit bir uygulama hazırlamış olduk. Siz de kodları değiştirip kendi uygulamanızı daha geliştirebilirsiniz.
Yazıyı Oku

16 Şubat 2017 Perşembe

C Sharp Dosya Okuma

Yorum Bırak

C Sharp Dosya Okuma

C sharp dosya işlemlerinden olan dosya okuma işlemine bakacak olursak:

class DosyadanOku
    {
        static void Main()
        {
            // Dosya pathini kendi dosyanızın olduğu yer ile aşağıdan değiştirebilirsiniz


            // Tüm dosyayı bir string olarak okuyoruz
            string text = System.IO.File.ReadAllText(@"C:\Users\Public\TestKlasor\dosya.txt");

            // Console'a dosya içeriğini yazdırıyoruz.
            System.Console.WriteLine("dosya.txt içeriği= {0}", text);

           
        }
    }



Yukarıdaki işlemde ReadAllText metodu ile txt dosyamızı tek bir string olarak okuduk ve console'a okuduğumuz dosya içeriğini bastırdık.


class DosyadanOku
    {
        static void Main()
        {
            // Dosya pathini kendi dosyanızın olduğu yer ile aşağıdan değiştirebilirsiniz

           // Bu kısımda da dosyayı okuyup string arraye atıyoruz
           string[] lines = System.IO.File.ReadAllLines(@"C:\Users\Public\TestKlasor\dosya.txt");
            // Dosya içeriğini foreach döngüsü ile okuyup 
            System.Console.WriteLine("dosya.txt içeriği = ");
            foreach (string line in lines)
            {
                // satır satır dosya içeriğini console'a yazdırıyoruz
                Console.WriteLine(line + "\n");

            }


            Console.WriteLine("Çıkış yapmak için bir tuşa basınız.");
            System.Console.ReadKey();

}
    }

Yukarıdaki işlemde ReadAllLines metodu ile dosya içeriğini csharp ile okuyarak string array'e attık ve onu da satır satır console'a bastırdık.


Yazıyı Oku

15 Şubat 2017 Çarşamba

Javascript Tarih Formatlama

Yorum Bırak
Javascript Tarih Formatlama

Javascript'te tarihleri 10 Mayıs 2010 şeklinde formatlamak istiyorsak aşağıdaki fonksiyonu kullanabiliriz:

function formatDate(date) {
  var monthNames = [
    "Ocan", "Şubat", "Mart",
    "Nisan", "Mayıs", "Haziran", "Temmuz",
    "Ağustos", "Eylül", "Ekim",
    "Kasım", "Aralık"
  ];

  var day = date.getDate();
  var monthIndex = date.getMonth();
  var year = date.getFullYear();

  return day + ' ' + monthNames[monthIndex] + ' ' + year;
}

formatDate fonksiyonuna elimizdeki tarihi parametre olarak gönderdiğimizde bize 10 Mayıs 2010 tipinde formatlayarak döndürecektir.

Yazıyı Oku

Javascript ile Yazı Boyutunu Değiştirme

Yorum Bırak
Javascript ile Yazı Boyutunu Değiştirme

Javascript kullanarak html elementlerin stillerini değiştirebiliriz. Yazı boyutu, yazı rengi vs gibi birçok özelliği kolay bir şekilde javascript kullanarak değiştirebiliriz. Aşağıdaki örneği inceleyecek olursak:

Yazıyı Oku

Javascript ile Html İçeriğini Değiştirme

Yorum Bırak

Javascript ile Html İçeriğini Değiştirme

Javascript kullanarak html içeriğini manipüle edebiliriz. Aşağıdaki örneği inceleyecek olursak:

Yazıyı Oku

Java'da Dosya Nasıl Oluşturulur?

Yorum Bırak
Java'da Dosya Nasıl Oluşturulur?
 File.createNewFile() metodu Java'da dosya oluşturmak için kullanılır. Sonuç olarak boolean bir değer döndürür; eğer dosya başarılı bir şekilde oluşturuldu ise true, eğer dosya zaten varsa veya dosya oluşturma işlemi başarısız olduysa false döndürür.

Aşağıdaki kodu inceleyecek olursak:

Yazıyı Oku

14 Şubat 2017 Salı

JavaScript - Aritmetik Operatörlerin Kullanımı

Yorum Bırak
JavaScript - Aritmetik Operatörlerin Kullanımı

Operatör Nedir?

Basit bir ifadeyi ele alalım: 4 + 5 9'a eşittir. Burada 4 ve 5'e işlenen, '+' işaretine ise operatör denir. JavaScript aşağıdaki operatör türlerini desteklemektedir:
Yazıyı Oku

13 Şubat 2017 Pazartesi

Javascript Veri Tipleri, Değişkenler ve Scope Kavramı

Yorum Bırak
Javascript Veri Tipleri, Değişkenler ve Scope Kavramı

Bu yazıda Javascript'te kullanılan veri tipleri, javascript scope kavramı ve javascript programlarken değişken isimlerinin nasıl kullanılması gerektiğine bakacağız.

Javascript Veri Tipleri

Bir programlama dilinin en temel özelliklerinden biri desteklediği veri türleri kümesidir. Bunlar, bir programlama dilinde temsil edilebilecek ve değiştirilebilen değerler türleridir.

JavaScript üç ilkel veri türü ile çalışmanıza izin verir -


  • Sayılar (numbers) -> Örneğin: 123, 120,50 vb.
  • Metin dizeleri (strings) -> Örneğin: "Bu metin dizesi" vs.
  • Boolean -> Örneğin: doğru (true) ya da yanlış(false).


JavaScript ayrıca, her biri tek bir değeri tanımlayan, null ve undefined iki veri türü tanımlar. JavaScript, bu ilkel veri türlerine ek olarak, nesne olarak bilinen bileşik bir veri türünü desteklemektedir.

Not - JavaScript, tam sayı değerleri ile kayan nokta değerleri (floating numbers) arasında bir ayrım yapmaz. JavaScript'deki tüm sayılar kayan nokta değerleri olarak (floating numbers) temsil edilir. JavaScript, IEEE 754 standardı tarafından tanımlanan 64 bit kayan nokta biçimini (floating numbers) kullanarak sayıları temsil eder.

Javascript Değişkenleri

Diğer birçok programlama dilinde olduğu gibi, JavaScript dilinde de değişkenler vardır. Bu değişkenlere veri atanabilir ve gerektiği zaman bunlar çağırılarak değerlerine erişilip program içerisinde kullanılabilir.

JavaScript programında bir değişkeni kullanmadan önce bunu tanımlamanız gerekir. Değişkenler var anahtarıyla aşağıdaki gibi tanımlanır:

<script type="text/javascript">
   <!--
      var ad;
      var soyad;
   //-->
</script>
Ayrıca tek bir var kelimesi kullanarak birden fazla değişken tanımlaması da aşağıdaki gibi yapılabilir:

<script type="text/javascript">
   <!--
      var ad, soyad;
   //-->
</script>

Bir değişkene bir değer depolamak, variable initialization olarak adlandırılır. Değişken oluşturma işlemi sırasında veya değişkeninize ihtiyaç duyduğunuz zaman değişkeninize değer atıyabilirsiniz.

Örneğin, para adlı bir değişken oluşturabilir ve 2000.50 değerini daha sonra ona atayabilirsiniz. 

<script type="text/javascript">
   <!--
      var ad = "Ali"; //değer değişken oluşturulurken atandı
      var para;
      para = 2000.50; //değer değişken oluşturulduktan sonra atandı
   //-->
</script>

JavaScript, untyped bir dildir. Bu, JavaScript değişkeninin herhangi bir veri türünün değerini saklayabileceği anlamına gelir. Diğer pek çok dilden farklı olarak, değişken bildiriminde değişkenin ne tür bir değerde olacağını JavaScript'e söylemek zorunda değilsiniz. Bir değişkenin değer türü, bir program yürütülürken (runtime) değişebilir ve JavaScript otomatik olarak onunla ilgilenir.

Javascript'te Değişken Kapsamı (Scope)

Bir değişkenin kapsamı (scope), programın tanımlandığı bölgedir. JavaScript değişkenlerinin yalnızca iki kapsamları vardır.

Genel Değişkenler (global variables) - Bir genel değişken, genel alana sahiptir; bu, JavaScript kodunun herhangi bir yerinde tanımlanabileceği anlamına gelir.

Yerel Değişkenler (local variables)- Yerel bir değişken yalnızca tanımlandığı bir fonksiyon içinde görülecektir. Örneğin bir fonksiyonda kullanılan parametreler yalnızca o fonksiyon içinde işlevlidir.

Bir fonksiyon gövdesi içinde, yerel bir değişken, aynı ada sahip global bir değişkenden önceliğe sahiptir. Global değişkenle aynı ada sahip yerel bir değişken veya fonksiyon parametresi tanımlanırsa, global değişkeni etkin bir şekilde gizlemiş olursunuz. Aşağıdaki örneğe göz atacak olursak:

<html>
   <body onload = kapsamkontrol();>
      <script type = "text/javascript">
         <!--
            var myVar = "global"; // Global değişken tanımlaması
            function kapsamkontrol( ) {
               var myVar = "local";  // Yerel (local) değişken tanımlaması
               document.write(myVar);
            }
         //-->
      </script>
   </body>
</html>

Yukarıdaki kod bloğu çalıştırılırsa ekrana local yazısını bastığını görürsünüz, çünkü fonksiyon içindeki değişken ataması, global değişken atamasından daha önceliklidir.

Javascript Değişken İsimleri

Değişkenlerimizi JavaScript'te adlandırırken, aşağıdaki kuralları göz önünde bulundurmalıyız:

  • JavaScriptin kendisi için ayrılmış anahtar kelimelerden herhangi birini değişken ad olarak kullanmamalıyız. Bu anahtar kelimeleri aşağıda görebilirsiniz. Örneğin, break veya boolean değişken adları geçerli değildir.
  • JavaScript değişken adları bir sayı ile başlamamalıdır (0-9). Bir harf veya alt çizgi karakteriyle başlamalıdırlar. Örneğin, 123test geçersiz bir değişken adıdır, ancak _123test geçerli bir değişken adıdır.
  • JavaScript değişken adları büyük / küçük harf duyarlıdır. Örneğin, Ad ve ad iki farklı değişkentir.

Javascript İçin Ayrılmış Anahtar Kelimeler Listesi

JavaScript için ayrılmış tüm sözcüklerin listesi aşağıdaki tabloda verilmiştir. Bu listedeki kelimeler, fonksiyonlar, metodlar, döngü etiketleri veya herhangi bir nesne adı olarak kullanılamazlar.

abstract
boolean
break
byte
case
catch
char
class
const
continue
debugger
default
delete
do
double
else
enum
export
extends
false
final
finally
float
for
function
goto
if
implements
import
in
instanceof
int
interface
long
native
new
null
package
private
protected
public
return
short
static
super
switch
synchronized
this
throw
throws
transient
true
try
typeof
var
void
volatile
while
with
Yazıyı Oku