2

私はウェブページにリンクを持っています

<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 を使用できる Web ページには名前がありません。

4

4 に答える 4

3

私は提案します

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プラグインのハイパーリンクをクリック可能にする方法は?

于 2011-09-10T09:04:21.227 に答える
2

dynatree では、li 要素にアンカー タグを配置できるようになりました。したがって、次のように簡単に実行できます。

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

こちらのナビゲーション例をご覧ください。

于 2011-11-14T09:17:15.180 に答える
0

これは文書化された方法です:

onActivate: function(node) {
   if( node.data.href ) {
      window.open(node.data.href, node.data.target);
      return false;
   }
},
于 2013-06-18T14:46:32.367 に答える
0

この解決策を試しましたか:

$(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; 
      }
   });
});
于 2010-08-02T10:08:57.037 に答える