Ana içeriğe atla

JavaScript ile Cümledeki Kelime Sayisi Nasil Bulunur

Bir text alana girilen metnin kaç kelimeden olustugunu JavaScript ile nasil bulabiliriz. JavaScript kullanmamizin avantaji, kullanici metni yazarken ayni anda kelime sayisini bularak ekranda gösterebiliriz.
Ilk olarak kelimeleri neye göre ayiracagiz. Türkçede kelimeler birbirinden boslukla ayrilir. Noktalama isaretleri kullanildiktan sonra bir bosluk birakilir. Birinci yöntemde kullanicilarimizin bu kurala uydugunu farz edelim.
Sayfamizda head taglari arasina asagidaki JavaScript kodlarini yazalim
<script language="javascript" type="text/javascript">
    function KelimeSayisiBul() {
        var a = document.getElementById('Metin1').value;
        var kelimeler = new Array();
        kelimeler = a.split(' ');
        var cnt = kelimeler.length;
        document.getElementById('kelimeSayisiLabel').innerHTML = cnt;
    }   
</script>

Sayfamizda body taglari arasina da asagidaki gibi bir text alan ve label eklersek, text alanin keyup olayinda da yukarida tanimladigimiz KelimeSayisiBul fonksiyonunu çagirirsak text alana yazdigimiz cümlenin kaç adet kelimeden olustugunu aninda labelda görebiliriz.
<table>
    <tr>
        <td>
            <input id="Metin1" onkeyup="KelimeSayisiBul();" type="text"/>
        </td>
        <td>
            Kelime Sayisi:
            <label id="kelimeSayisiLabel">0</label>
        </td>
    </tr>
</table>

Peki, yukaridaki örnekte eksikler nelerdir.
Ilk olarak noktalama isaretlerinden sonra bosluk birakilmadiginda ve kelimeler arasinda birden fazla bosluk birakildiginda yukaridaki yapi hatali çalisir. Ilk olarak noktalama isaretlerini bularak bunlari bosluga çevirelim sonrasinda cümlemizi yukaridaki örnekte oldugu gibi bosluklara göre ayiralim edelim. Eger kelimeler arasinda birden fazla bosluk birakildi ise bosluga göre ayirma yaptigimizda olusan dizinin bazi elemanlarinin bos oldugunu görürüz. Öyleyse bu kontrolü de yaparsak cümlemizin tam olarak kaç kelimden olustugunu görebiliriz.
Yukaridaki ifadelere göre JavaScript kodumuzu asagidaki gibi degistirmemiz yetecektir.
<script language="javascript" type="text/javascript">
    function KelimeSayisiBul2() {
        var a = document.getElementById('Metin2').value;
        a = a.replace(/[,.?!;:]/gi, ' ');

        document.getElementById('kelimeSayisiLabel2').innerHTML = a;
        var kelimeler = new Array();
        kelimeler = a.split(' ');
        var l = 0;
        var cnt = 0;
        while (l < kelimeler.length) {
            if (kelimeler[l] != '')
                cnt++;
            l++;
        }
        document.getElementById('kelimeSayisiLabel2').innerHTML = cnt;
    }
</script>


Yukarida bahsettigimiz iki yöntemi de barindiran  html ve JavaScript kodlari :
<html >
<head>
    <title>Untitled Page</title>

    <script language="javascript" type="text/javascript">
        function KelimeSayisiBul() {
            var a = document.getElementById('Metin1').value;
            var kelimeler = new Array();
            kelimeler = a.split(' ');
            var cnt = kelimeler.length;
            document.getElementById('kelimeSayisiLabel').innerHTML = cnt;
        }   
    </script>

    <script language="javascript" type="text/javascript">
        function KelimeSayisiBul2() {
            var a = document.getElementById('Metin2').value;
            a = a.replace(/[,.?!;:]/gi, ' ');

            document.getElementById('kelimeSayisiLabel2').innerHTML = a;
            var kelimeler = new Array();
            kelimeler = a.split(' ');
            var l = 0;
            var cnt = 0;
            while (l < kelimeler.length) {
                if (kelimeler[l] != '')
                    cnt++;
                l++;
            }
            document.getElementById('kelimeSayisiLabel2').innerHTML = cnt;
        }
    </script>

</head>
<body>
    <table>
        <tr>
            <td colspan="2">
                Sadece Bosluga göre kelime sayimi:
            </td>
        </tr>
        <tr>
            <td>
                <input id="Metin1" onkeyup="KelimeSayisiBul();"type="text" />
            </td>
            <td>
                Kelime Sayisi:
                <label id="kelimeSayisiLabel">
                    0</label>
            </td>
        </tr>
        <tr>
            <td colspan="2">
                <hr style="colorRed"></hr>
            </td>
        </tr>
        <tr>
            <td colspan="2">
                Bosluk ve Noktalama isaretlerine göre kelime sayimi(Birden fazla bosluk kontrolü
                yapar)
            </td>
        </tr>
        <tr>
            <td>
                <input id="Metin2" onkeyup="KelimeSayisiBul2();"type="text" />
            </td>
            <td>
                Kelime Sayisi:
                <label id="kelimeSayisiLabel2">
                    0</label>
            </td>
        </tr>
    </table>
</body>
</html>

Yukaridaki örnegi buradan deneyebilirsiniz.

Yorumlar

Bu blogdaki popüler yayınlar

Linux En Az Sistem Gereksinimi İsteyen Dağıtımları Değerlendirilmesi

Linux İşletim Sisteminin Dağıtımlarının En az sistem gereksinimi isteyen sürümleri, değerlendirilmesi aşağıdadır, Değerlendirilen dağıtımlar şunlardır: Ubuntu Xubuntu Lubuntu Damn Small Linux Linux Mint Fedora Opensuse Debian Rat Hat Suse Linux Suse Linux Sistem Gereksinimleri: Pentium 1-4 ya da Xeon; AMD Duron, Athlon (XP, MP ya da 64), Sempron ya da Opteron 256MB RAM 500MB boş disk alanı 800x600 yada üstü resolution Rat Hat Memory Gerekli: 4 GB of memory Önerilen: 8 GB of memory CPU Gerekli: Intel Core processor, 2.4GHz, 512K cache or equivalent Önerilen: Intel multi-core processor, 2.4GHz dual processor, 512K cache or equivalent Storage 5 GB alan temel kurulum için. 40 GB alan Channel başına. 10 GB alan Cache dizini için(/var/cache/rhn) Disk yapılandırması olarak Raid 5 tavsiye edilir. Database İlk kurulum için 12 GB alan önerilir. Client ve channel hesaplamaları ise, 250 KB alan client system başına, 500 KB alan çhannel başına, ayrıca 230 KB channel da...

Bilgisayarın Sağlıklı ve Doğru Kullanımı

Bilgisayar genelde oturarak kullanıldığı için uzun süreli kullanımlar vücudumuza zarar verebilmektedir.Yazı yazmak,internet erişimi ya da oyun oynamak için uzun süreli kullanım;başta bel,boyun ve omurgalarımızın sağlığını tehdit eder.Diğer yandan sürekli aynı noktaya bakmak göz sağlığımıza zarar verir.Bu nedenle bilgisayar kullanıcısının oturma pozisyonuna çok dikkat etmesi ve uzun süre çalışmaması gerekir. Bilgisayar Kullanırken Oturma Şekli Önerileri ·         Bilgisayarı,uygun yükseliğe sahip olan masa ve sandalye üzerinde dik oturma konumunda kullanmak gerekir.Klavye ve farenin çok uzakta olmaması gerekir.Oturan kişinin gözü ile bilgisayar arasında 50-60 cm uzaklık olmalıdır.Kollar yatay ve rahat konumda olmalıdır.   ·         Masa yüksekliği yaklaşık 70 cm olmalıdır.Dizüstü bilgisayarlar için yükseltici olarak bilinen altlıklar yararlı olabilir.   ·         Oturma sırasında sırt desteklemeli ve...

Web Debugging - Hata Ayiklama (Fiddler Aracinin Kullanimi)

Debugging, hata ayiklama, programcinin olmazsa olmazi diyebiliriz. Kodlama sirasinda çikan hatalarda ya da hatasiz çalisan programda istenen sonuç dönmeyince, nerde hata yaptim diye satirlari incelemeye baslariz. Genelde kodlama sirasinda çikan hatalarimizda derleyici neyi yanlis yaptigimizi söylerken, runtime' da hatalarla karsilasinca ya da islemde bir yanlislik varsa isler biraz zorlasir. Pek çogumuz breakpoint'lerle adim adim inceleme yapariz, eger javascript kodlarimiz varsa alert'ler kullanarak isin içinden çikmaya çalisiriz. Tabi bu durum her zaman ise yaramayabilir, ya da çok can sikici bir hale dönüsebilir. Bu durumlarda browserda aslinda neler oldugunu ögrenmek için http requestlari takip edebilecegimiz programlar var. Fiddler bunlardan birisi. Fiddler Nedir Fiddler, bilgisayar ve internet arasindaki tüm web trafigini takip eden ve detayli bir sekilde analiz yapmamizi saglayan ücretsiz bir http debugging (Hata Ayiklama) programidir. Bu program, http trafigini...