ホームページ > ウェブフロントエンド > jsチュートリアル > jQuery は zTree プラグインを使用して、ドラッグ アンド ドロップ ツリー コード共有を実装します。

jQuery は zTree プラグインを使用して、ドラッグ アンド ドロップ ツリー コード共有を実装します。

小云云
リリース: 2018-02-02 13:31:00
オリジナル
1644 人が閲覧しました

これまで出会ったツリープラグインの中で、zTreeは比較的シンプルで使いやすいと思います。ビジネス要件の 1 つは、ツリー上のオブジェクトを自由にドラッグ アンド ドロップできるようにすることでした。そのため、zTree を使用していくつかの研究を行いました。

この記事では主に、zTree プラグインを使用してドラッグ可能なツリーを js で実装する例を紹介します。編集者はそれが非常に優れていると考えたので、参考として共有します。編集者をフォローして見てみましょう。皆さんのお役に立てれば幸いです。

まず、zTree に必要な関連パッケージをダウンロードし、公式ダウンロード リンクを添付します: zTree ダウンロード 関連ファイルを導入した後、zTree を構築できます。まずページに ul タグを追加し、次にツリーに id を追加し、calss を ztree にするとフロントエンド ページが完成します。

注: 以下のコードはすべて私自身のニーズに従って書かれたものであり、構成プロセスとコールバック関数の使用を参照するためにのみ不完全です。

フロントエンドページ:


 <ul id="modelTree" class="ztree"></ul>
ログイン後にコピー

次に、JavaScript を作成する前に、上で詳しく説明した zTree の API を読む必要があります。最初の設定は、zTree 全体のコア構成であり、ドラッグ アンド ドロップ機能が必要なため、他のパラメータに依存する編集を構成しました。必要な構成について。関連するコールバック関数もコールバックで構成されます。

設定構成:


 var setting = {
 data: {
  key:{
   name:&#39;nodeName&#39;
  },
  simpleData: {
   enable: true,
   idKey: &#39;nodeId&#39;,
   pIdKey: &#39;parentNodeId&#39;
  },
  keep:{
   leaf:true,
   parent:true,
  }
 },
 edit:{
  drag:{
   isCopy: false,
   isMove: true,
   prev: true,
   next: true,
   inner: true,
   autoOpenTime: 0,
   minMoveSize: 10


  },
  enable:true,
  editNameSelectAll: true,
  removeTitle: "删除节点",
  renameTitle: "编辑节点名称",
  showRemoveBtn: false,
  showRenameBtn: false,
 },

 callback: {
  beforeClick: beforeClick,

  beforeDrag:beforeDrag,
  beforeDragOpen:beforeDragOpen,
  beforeDrop:beforeDrop,
  onDrag:onDr},
};
ログイン後にコピー

設定を構成した後、各コールバック関数を完了し、必要に応じて内容を決定します。 ここでは、親の種類に基づいてドラッグ アンド ドロップできるかどうかを決定します。ノードとその他のいくつかのルールにより、ドラッグが成功するかどうかに対応する制限があります。

コールバック関数:


 //拖拽之前调用的函数
function beforeDrag(treeId,treeNode){
 if(treeNode[0].nodeType == &#39;GROUP&#39;){
  return false;
 }
 if(treeNode.parentId == null && treeNode.modelType !=null){
  return true;
 }
 var node = treeNode[0].getParentNode();
 var modelType = treeNode[0].getParentNode().modelType;
 if(modelType == &#39;INTERFACE&#39;){
  return false;
 }else {
  return true;
 }
}

//预留被拖拽的回调函数
function onDrag(event, treeId, treeNode){
 //暂时没用到
}

//拖拽移动到展开父节点之前调用的函数
function beforeDragOpen(){
 return true;
}

//拖拽操作结束之前调用的函数
function beforeDrop(treeId, treeNode, targetNode, moveType){
 BRS.fileLoading(&#39;show&#39;);
 var result = false;
 if(targetNode == null || (moveType != "inner" && !targetNode.parentTId)){
  BRS.fileLoading(&#39;hide&#39;);
  return false;
 }
 if(targetNode.modelType != null){
  if((targetNode.modelType == &#39;INTERFACE&#39; && moveType == &#39;inner&#39;) || targetNode.getParentNode().modelType == &#39;INTERFACE&#39;){
   BRS.fileLoading(&#39;hide&#39;);
   return false;
  }
 }
 var objDetail = {
  url: &#39;/api/model/&#39; + treeNode[0].id,
  async:false,
 }
 jsonAjax(objDetail,function (detailData) {
  var data = {
   nodeType : detailData.nodeType,
   code : detailData.code,
   name : detailData.name,
   builtIn : detailData.builtIn,
   iconUrl : detailData.iconUrl,
   modelType : detailData.modelType.code,
   interfaceModelId : detailData.interfaceModelId,
  };
  data.id = treeNode[0].id;
  if(moveType != &#39;inner&#39;){
   data.groupId = targetNode.parentId;
  }else{
   data.groupId = targetNode.id;
  }
  var obj = {
   type:"put",
   showSuccessMsg: false,
   param: {
    params:JSON.stringify(data)
   },
   async:false,
   url: &#39;/api/model&#39;,
  }
  jsonAjax(obj,function(updateData){
   if(updateData != null){
    result = true;
  ing(&#39;hide&#39;);
 return result;
}

//预留拖拽结束的回调函数
function onDrop(event, treeId, treeNode, targetNode, moveType){
 befod(&#39;hide&#39;);
 return result;
}

//预留拖拽结束的回调函数
function onDrop(event, treeId, treeNode, targetNode, moveType){
 beforeClick(treeId, treeNode[0]);
}
ログイン後にコピー

上記の設定と関連関数が完了したら、zTree の初期化メソッドを呼び出し、Ajax リクエストによって返されたパラメーターを通じて必要なツリーを埋めることができます。


// 初始化对象分组树
 var treeObj = $("#modelTree");
 $.fn.zTree.init(treeObj, setting, data);
 zTree_Menu = $.fn.zTree.getZTreeObj("modelTree");
ログイン後にコピー

最終的に形成されたツリー (ドラッグアンドドロップ可能):

関連する推奨事項:

zTree プラグインの複数選択ドロップダウン メニューのサンプル コード_JavaScript スキル

jQuery の使用zTree プラグインの AngularJS メソッド_AngularJS

jQuery は、zTree プラグインを使用してツリー メニューと非同期ローディングを実装します_jquery

以上がjQuery は zTree プラグインを使用して、ドラッグ アンド ドロップ ツリー コード共有を実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート