Javascript

document.ready olayı

Sayfalara ait istemci dosyalarında document.ready olayı işleyicisi tanımlamak yerine ortak olay işleyici metot kullanılır. document.ready olayına abone olmak isteyen metotlar $ol metodu ile global listeye ($oa) eklenir. global.js dosyasında bu listedeki her metot document.ready olayına ekleniyor.

//onload function array
var $oa=[];

//add function to onload array
function $ol(f){
        if(typeof(f)=='function'){
        $oa.push(f);
    }
}

$(function(){
    //send onload array to jQuery
    $($oa).each(function(i,item){
        $(item);
    });
});

//örnek abone metot
$ol(function(){ 
        $("#deactiveMembershipBtn").on('click',function(e){
        var deactiveMembership = $("#deactiveMembership");
        $('#DeactivateMembershipForm').trigger('reset');
        $.fancybox(deactiveMembership);
        e.preventDefault();
    });
});

Dinamik oluşan içeriklerde istemci validasyonu kuralları

Sayfa yüklendikten sonra dinamik olarak oluşturulan formların istemci validasyon kuralları otomatik olarak oluşmuyor. Bunun için aşağıdaki yöntem kullanılıyor.

İstemci kodundan Resource mesajlarına erişim

İstemci kodları kullanıcıya mesaj göstereceği zaman kullanılan mesajlar Resource ile uygulama tarafında tanımlıysa, bu mesajlar için Hidden input elemanları oluşturuluyordu ve istemci kodunda bu mesajlar kullanılıyordu. Bunun yerine artık Resource mesajlarını bir javascript arrayine yazan bir T4 template oluşturuldu. Kullanılacak tüm mesajların bir kerede javascript kodlarının erişimine hazır hale getirilmesi sağlandı. Hidden input kullanımı kaldırıldı.

Kullanım: İstemci kodlarında erişilmek istenen mesaj bu dosyaya eklenir. Aşağıdaki gibi kullanılır.

Örnek T4 template:

messages.tt

Bu dosyada değişiklik yapılıp kaydedildiğinde messages.js yeniden oluşturuluyor.

İstemci kodundan Url bilgilerine erişim

İstemci tarafında kullanılması gereken Url bilgileri aşağıdaki partial dosyasında tanımlanır. Bu partial Layout dosyalarına eklenmelidir. Bu şekilde kullanılacak url bilgilerinin Routing yapısı tarafından oluşturulması sağlanır.Yararları:

  • Gelecekte yapılabilecek Route tanımı değişiklikleri kullanılan url bilgilerini etkilemez.

  • Url oluşturma işlemi merkezileştirilmiştir, kod tekrarı ve tekrara dayalı olası güncelleme sorunları yaşanmaz.

Örnek Tanımlar:

~\Views\Shared\_Urls.cshtml

Last updated

Was this helpful?