2011-10-08 15 views
6

Ben çalışıyorum Google Ajax Crawlable

ajax sayfa yüklemesini kontrol etmek için $(window) bind hashchange kullanıyorum.

gibi benim url: değişimin iki çeşit

  1. domain.com/#!/apple&num=1 =>domain.com/#!/apple&num=2

  2. domain.com/#!/apple&num=1 =>domain.com/#!/banana&num=1

böylece orada vardır

$(window) bind hashchange hash bölümünün apple =>banana değişkenini değiştirip değiştirmediğini nasıl kontrol edebilirim? Teşekkürler.

$(window).bind('hashchange', function() { 
    // make a judge like if(){}else{} 
}); 
+0

İkinci güncellenmiş karma değer sadece meyve ismini değil, aynı zamanda sayıyı da değiştirdi. –

cevap

13

Karma değeri bir değişkende saklayın ve değişkeni işlevin sonunda güncelleyin. Düşünün:

(function(){ 
    var lastHash = location.hash; 
    $(window).bind('hashchange', function() { 
     var newHash = location.hash; 
     // Do something 
     var diff = compareHash(newHash, lastHash); 
     alert("Difference between old and new hash:\n"+diff[0]+"\n\n"+dif[1]); 

     //At the end of the func: 
     lastHash = newHash; 
    }); 

    function compareHash(current, previous){ 
     for(var i=0, len=Math.min(current.length, previous.length); i<len; i++){ 
      if(current.charAt(0) != previous.charAt(0)) break; 
     } 
     current = current.substr(i); 
     previous = previous.substr(i); 
     for(var i=0, len=Math.min(current.length, previous.length); i<len; i++){ 
      if(current.substr(-1) != previous.substr(-1)) break; 
     } 

     //Array: Current = New hash, previous = old hash 
     return [current, previous]; 
    } 
})() 
+0

Ne harika bir çalışma. Teşekkürler. – Giberno

3

Bir değişkende orijinal karma depolamak ve sonra değişikliği yargılamak için yeni karma incelemek istiyorum. Bu işlem bittiğinde, yeni karmayı orijinal olarak ayarlayın:

var originalHash = window.location.hash; 
$(window).bind('hashchange', function() { 
    var newHash = window.location.hash; 
    //do your stuff based on the comparison of newHash to originalHash 

    originalHash = newHash; 
}); 
+1

(window.location) değişikliğini algılayabilir ve kullanabilir miyim? (jquery olmadan) – BergP