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...

( C#) Ders 4 - Diziler, Çok Boyutlu Diziler, Düzenli ve Düzensiz Çok Boyutlu Diziler Nasil Kullanilir. foreach Döngüsünün Kullanimi.

C# da Diziler Diziler için ayni tipteki verilerin tutuldugu bir koleksiyon diyebiliriz. Örnegin integer verinin bir yigin seklinde tutulmasi için dizileri kullaniriz. C# da diziler referans tipinde degiskenlerdendir. C# da tanimlanan tüm diziler System.Array sinifindan türemis bir nesnedir. C# da diziler asagidaki gibi tanimlanir. ? 1 <veri tipi>[] <degisken ismi> = new <veri tipi>[<dizinin boyutu>]; 10 adet integer veri tutan bir dizinin tanim ise ? 1 int [] integerDizi = new int [10]; Bir dizinin boyutlari sabittir ve kullanilmadan önce belirlenmelidir. Dizi boyutunu belirlemek için baska bir degiskende kullanabilirsiniz. ? 1 2 int boyut = 10; int [] integerDizi = new int [boyut]; Diziyi tanimlama ve baslangiç degerlerini atama islemini ayri satirlardada yapabilirsiniz. ? 1 2 int [] integerDizi; integerDizi = new int [10]; Ayrica dizileri tanimlarken, dizi içine atmak istedigin...

(C#) Ders 2 - Degisken Tipleri, Degisken Tanimlama ve Operatörler

C# Hakkinda Temel Bilgiler Bu dersimizde C# dili hakkinda temel bilgiler ögrenecegiz. Biraz açarsak bu dersimizde veri tipleri, degiskenler ve operatörleri nasil kullanacagimizla ilgili bilgiler verecegiz. Temel Veri Tipleri ve CTS(Common Type System) Karsiliklari C# da iki çesit veri tipi vardir: Deger Tipleri (Value type) Referans Tipleri(Reference Type) Degiskenler bellekte bulunan verilerdir. Bir degiskeni kullandigimiz zaman o degiskenin bellekte bulundu yerdeki bilgiyi kullaniriz. Deger tipleri veriyi direk olarak bellek bölgesinden alirken referans tipleri baska bir nesneye referans gösterirler. Yani referans tipleri içinde veri degil adres bilgisi tutarlar. Veri tipleri stack dedigimiz bellek bölgesinde tutulurlar, referans tipleri ise heap bellek bölgesinde saklanirlar. int, double, float gibi veri tipleri deger tiplerine örnek gösterilebilir. Herhangi bir sinif türü ise referans tipine örnek gösterilebilir. Deger tipleri birbirine esitlenirken degiskenin ba...