Плагин JQuery DynaTree - как вызвать гиперссылку - PullRequest
2 голосов
/ 02 августа 2010

У меня есть ссылка на веб-странице

<li data="url: 'www.mypage.com?index.php?CId=2&MId=14&MTId=1'">mylink

В моем скрипте js у меня есть

$(document).ready(function() {

 $("#tree").dynatree({
 persist: true,

 onPostInit: function(isReloading, isError) {
        this.reactivate();
 },

 onActivate: function(dtnode) {
        var isInitializing = dtnode.tree.isInitializing(); 
        var isReloading = dtnode.tree.isReloading(); 
        var isUserEvent = dtnode.tree.isUserEvent(); 

       if( dtnode.data.url )
          window.open(dtnode.data.url); 

}   

    });

});

Что мне делать вместо window.open, поэтому URL-адрес перезагружается в том жеокно, не открывая новое?На веб-странице нет названия, где я мог бы использовать способ iFrame.

Ответы [ 4 ]

3 голосов
/ 10 сентября 2011

Я бы предложил

onActivate: function(node) { 
    if( node.data.href ){
        // use href to change the current frame:
        window.location.href = node.data.href; 
        // or load data into a div tag:
//      $("#div").load(node.data.href);
        // or open href in another target frame:
//      window.open(node.data.href, node.data.target);
    }
}

Смотрите также здесь другой пример: Как сделать так, чтобы гиперссылки в плагине dynaTree jQuery были активными?

2 голосов
/ 14 ноября 2011

dynatree теперь позволяет помещать якорные теги в элементы li. Так что вы можете просто сделать:

<li><a href="www.mypage.com\index.php?CId=2&MId=14&MTId=1" target="_top">mylink</a>

Посмотрите примеры навигации здесь .

0 голосов
/ 18 июня 2013

Это документированный способ:

onActivate: function(node) {
   if( node.data.href ) {
      window.open(node.data.href, node.data.target);
      return false;
   }
},
0 голосов
/ 02 августа 2010

вы пробовали это решение:

$(document).ready(function() {

   $("#tree").dynatree({ persist: true,

      onPostInit: function(isReloading, isError) { this.reactivate(); },

      onActivate: function(dtnode) { 
         var isInitializing = dtnode.tree.isInitializing(); 
         var isReloading = dtnode.tree.isReloading(); 
         var isUserEvent = dtnode.tree.isUserEvent();

         if( dtnode.data.url )
            window.location.href = dtnode.data.url; 
      }
   });
});
...