Foruma hoş geldin 👋, Ziyaretçi

Forum içeriğine ve tüm hizmetlerimize erişim sağlamak için foruma kayıt olmalı ya da giriş yapmalısınız. Foruma üye olmak tamamen ücretsizdir.

Web Geliştirmede `inputmode` ile Mobil Kullanıcı Deneyimini Devrimleştirin 📱

codrix

Üye
Katılım
14 Mart 2026
Mesajlar
12
Web Geliştirmede `inputmode` ile Mobil Kullanıcı Deneyimini Devrimleştirin 📱

Selam dostlar! 👋 Uzun süredir forumda takılıyorum ve bugün sizlerle, özellikle mobil kullanıcılar için hayat kurtarıcı ama çok az bilinen bir HTML özelliğinden bahsetmek istiyorum: `inputmode`.

Hepimiz mobilde bir form doldururken yaşadığımız o sinir bozucu anları biliriz. Telefon numarası girerken klavyede harfler çıkması, e-posta adresi yazarken ".com" butonunun bir türlü gelmemesi... İşte tüm bu sorunların basit ve şık bir çözümü var. Gelin birlikte inceleyelim. 🚀

`inputmode` Nedir ve Neden Önemli?

`inputmode`, bir `<input>` veya `<textarea>` elementine ekleyebileceğiniz bir HTML özniteliğidir. Amacı, tarayıcıya (özellikle mobil tarayıcılara) "Bu alanda kullanıcıdan ne tür bir veri bekliyorsun?" sorusunun cevabını vermektir. Tarayıcı da bu bilgiyi kullanarak, kullanıcı o alana tıkladığında en uygun sanal klavyeyi otomatik olarak açabilir.

Bu, kullanıcıya ekstra bir tıklama yaptırmadan, doğrudan ihtiyacı olan klavyeye ulaşmasını sağlar. Kullanıcı deneyimi (UX) açısından muazzam bir iyileştirmedir! 💡

`inputmode` Değerleri ve Kullanım Alanları

Şimdi gelin, bu sihirli özniteliğin alabileceği değerlere ve ne zaman kullanmamız gerektiğine bakalım.

  • `inputmode="numeric"`: Rakamlar için mükemmeldir. Telefon numarası, PIN kodu, yaş gibi alanlarda kullanın. Mobilde sayısal tuş takımını (0-9) açar.
    Kod:
    <input type="text" inputmode="numeric" pattern="[0-9]*" id="phone">
  • `inputmode="decimal"`: Ondalıklı sayılar için. Fiyat, ağırlık, ölçü gibi alanlar. Klavyede nokta (.) veya virgül (,) içeren sayısal bir tuş takımı açar.
  • `inputmode="tel"`: Telefon numaraları için özel olarak tasarlanmıştır. `numeric`'ten farkı, genellikle "*" ve "#" gibi telefon tuşlarını da içerebilmesidir. Telefon numarası alanlarında birinci tercihiniz bu olmalı.
  • `inputmode="email"`: E-posta adresleri için. Klavyede "@" ve ".com" gibi e-posta yazımını hızlandıran tuşları öne çıkarır. `type="email"` ile birlikte kullanmak çok etkilidir.
  • `inputmode="url": Web adresi (URL) girişi için. Klavyede ".com", "/" ve "www." gibi tuşları kolay erişilebilir yapar.
  • `inputmode="search"`: Arama kutuları için. Klavyede "Ara" butonunun "Go" yerine "Search" olarak görünmesini sağlar ve genellikle daha uygun bir düzen sunar.
  • `inputmode="none"`: Sanal klavyenin hiç açılmamasını istediğiniz durumlar için. Örneğin, özel bir tarih seçici (datepicker) kullandığınız bir alanda, varsayılan klavyenin çıkmasını engellemek için kullanabilirsiniz.

Pratik Örnek: Mükemmel Bir İletişim Formu

Teoriyi pratiğe dökelim. İşte `inputmode` kullanarak geliştireceğiniz bir iletişim formu örneği:

Kod:
<form>
  <label for="name">Ad Soyad:</label>
  <input type="text" id="name" required> <!-- Varsayılan klavye iyi -->

  <label for="email">E-posta:</label>
  <input type="email" id="email" inputmode="email" required> <!-- @ tuşu hazır! -->

  <label for="phone">Telefon:</label>
  <input type="tel" id="phone" inputmode="tel" pattern="[0-9\s]+" required> <!-- Telefon tuş takımı -->

  <label for="age">Yaş:</label>
  <input type="text" id="age" inputmode="numeric" pattern="\d*" size="3"> <!-- Sayısal tuş takımı -->

  <label for="website">Web Sitesi:</label>
  <input type="url" id="website" inputmode="url"> <!-- .com tuşu hazır! -->

  <label for="message">Mesajınız:</label>
  <textarea id="message" rows="5"></textarea> <!-- Varsayılan klavye -->

  <button type="submit">Gönder</button>
</form>

Bu formu mobilde test ettiğinizde, her alana tıkladığınızda ihtiyacınıza yönelik farklı bir klavyenin açıldığını göreceksiniz. Kullanıcı için bu, paha biçilemez bir konfor demektir. ⚙️

`inputmode` ve `type` İlişkisi

Akıllara şu soru gelebilir: "Zaten `type="number"` veya `type="tel"` kullanıyorum, `inputmode`'a gerek var mı?"
Evet, var! İkisi birbirini tamamlar.

* `type` özniteliği, verinin türünü ve tarayıcının yerleşik doğrulamasını (validation) belirler.
* `inputmode` özniteliği ise sadece kullanıcı arayüzünü (UI) ve klavye deneyimini optimize eder.

Örneğin, `type="number"` mobilde bazen istenmeyen yukarı/aşağı oklar (spin button) getirebilir. Bu durumda, `type="text"` ile birlikte `inputmode="numeric"` ve `pattern` özniteliği kullanmak, daha temiz bir arayüz ve daha iyi bir klavye deneyimi sunabilir.

Tarayıcı Desteği ve Geriye Dönük Uyumluluk

`inputmode` modern tarayıcıların neredeyse tamamında (Chrome, Firefox, Safari, Edge) ve tüm mobil tarayıcılarda desteklenir. 🎉

En güzel yanı nedir biliyor musunuz? Geriye dönük uyumluluğu (progressive enhancement) mükemmeldir. Eski bir tarayıcı bu özniteliği tanımıyorsa, basitçe görmezden gelir ve standart klavyeyi açar. Hiçbir şey bozulmaz! Bu da demek oluyor ki, hemen bugün projelerinize eklemeye başlayabilirsiniz, hiçbir riski yok.

Son Söz

Web geliştirme, kullanıcıyı merkeze alan detaylarla güzelleşir. `inputmode` da işte tam olarak böyle bir detay. Kodunuza eklemesi saniyeler sürer, ancak kullanıcılarınıza sağladığı konfor ve profesyonellik hissi çok büyüktür.

Bir sonraki projenizde veya mevcut formlarınızı revize ederken, hangi alanın hangi `inputmode` değerini hak ettiğini bir düşünün. Küçük dokunuşlarla büyük farklar yaratabileceğinize eminim.

Sorularınız olursa yorumlarda bekliyorum. İyi kodlamalar! 💻
 

Tema özelleştirme sistemi

Bu menüden forum temasının bazı alanlarını kendinize özel olarak düzenleye bilirsiniz.

Zevkine göre renk kombinasyonunu belirle

Tam ekran yada dar ekran

Temanızın gövde büyüklüğünü sevkiniz, ihtiyacınıza göre dar yada geniş olarak kulana bilirsiniz.

Geri