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

JavaScript ile Popup Pencereleri

Popup pencereleri bir sayfa içinde ek bir pencere açma islemidir. Popup pencereler JavaScript kullanarak açilirlar. Popup pencereler yaygin olarak reklam göstermek amaciyla kullanilir. Diger bir kullanim amaci ise yardim sayfalari tasarlamak içindir. Ihtiyaciniz dogrultusunda farkli amaçlar için kullanilabilirler. Popup pencereler; Sayfa yüklenmesinde,Sayfadan çikildiginda,Kullanici bir linki tikladiginda açilabilir. Sayfa yüklenirken veya kapatilirken bir popup açmak için body etiketi içine asagidaki kodu yazmaniz yeterlidir. Sayfa yüklenirken ? 1 <body onload= "javascript: alert(Load islemi!')" > Sayfa Kapatilirken ? 1 <body onunload= "javascript: alert('UnLoad islemi!')" Link tiklandiginda ? 1 <a href= "javascript: alert('link Tiklandi!')" >Popup Aç!</a> Popup olarak yeni bir pencere açmak istiyorsak window.open() metodunu kullaniriz. Window.open metodun