ホームページ  >  記事  >  ウェブフロントエンド  >  jQuery zTree ツリー プラグインの動的読み込み

jQuery zTree ツリー プラグインの動的読み込み

小云云
小云云オリジナル
2018-01-12 09:53:191378ブラウズ

この記事では主に jQuery zTree ツリー プラグインの動的読み込み効果のサンプル コードを紹介します。必要な方は参考にしていただければ幸いです。

要件:

プロジェクト内の家系図データの量が非常に多いため、一般的な読み込み方法は、ページの読み込み時に zTree.init メソッドを通じてデータを読み込み、次の時点ですべてのデータをページに読み込みます。一度。このプロジェクトでは、家系図のレベルは非常に広く深く、数万のレベルがあるため、一度ロードするとまったくロードすることはできません。したがって、データの読み込みを容易にし、エクスペリエンスを向上させるために、動的読み込み (増分読み込み) 方法を最適化する必要があります。

サーキット ブレークを解決します:

これは簡単に処理できます。親ノードのクリック イベントを見つけて、データをロードし、ノードをアタッチするだけです。時間は限られており、タスクは多く、研究する時間がまったくありませんでした。ボタンを押して「zTree 動的読み込み」を検索することしかできませんでした。結果は表示され、タイトルは正しかったのですが、内部のコードにはノードの追加に関するものが見つかりませんでした。一方で、要求に応じてプロンプトが表示されました。 , しかし一方で、同様のものは見つかりませんでした。無言… はい、公式 Web サイトがないので、すべての API 関数を参照して、最終的に addNodes という関数を見つけました。幸せ!

制御コード

<p class="UserTree">
  <ul id="treeDemo" class="ztree"></ul>
</p>

スクリプトコード(イベントクリック時のノード展開と動的読み込みの実装):

<script>
  var zNodes;
  var zTree;
  $(function () {
    $.ajax({
      cache: true,
      type: "get",
      url: "/User/NextLeve",
      async: false,
      success: function (data) {
        zNodes = data;
      },
      error: function (data) {
        alert("error");
      }
    });
    zTree = ZTreeCustom.init($("#treeDemo"), setting, zNodes);
    zTree.expandAll(false);
  })
  var setting = {
    view: {
      nameIsHTML: true
    },
    data: {
      simpleData: {
        enable: true
      },
      keep: {
        parent: true
      }
    },
    open: false,
    callback: {
      onClick: nodeClick,
      onExpand: function (event, treeId, treeNode) {
        addSubNode(treeNode);
      }
    }
  };
  function showIconForTree(treeId, treeNode) {
    return !treeNode.isParent;
  };
  function searchM() {
    var username = $("#txtName").val()
  }
  function nodeClick(event, treeId, treeNode, clickFlag) {
    addSubNode(treeNode);
  }
  function addSubNode(treeNode) {
    if (!treeNode.isParent) return;
    var s = treeNode.children;
    if (s != undefined)
      return;
    $.ajax({
      cache: true,
      type: "get",
      url: "/User/NextLeve",
      data: { userId: treeNode.id },
      async: true,
      success: function (data) {
        zTree.addNodes(treeNode, data);
      },
      error: function (data) {
        alert("error");
      }
    });
  }
</script>

バックエンドリクエスト:

データソースはリクエストパス「/User/NextLeve?userId=xxx」で、次の構造を持つリストの json データ (つまり、List タイプの .ToJson() データ)。 userId を指定でき、空の場合は、デフォルトで現在ログインしているユーザーが取得されます。

この効果は、親ノードをクリックするか、親ノードを展開するときに子ノードを動的にロードすることで実装されます。

関連する推奨事項:

jQuery での zTree ツリー プラグインの使用の共有

詳細な例の説明 jQuery EasyUI と zTree ツリー構造を組み合わせて Web ページを作成する

zTree プラグインを使用した jQuery の例の説明ドラッグアンドドロップ機能を実装するには

以上がjQuery zTree ツリー プラグインの動的読み込みの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。