ホームページ  >  記事  >  ウェブフロントエンド  >  ブートストラップ フレームワークでツリービューを使用してデータを動的にロードする方法

ブートストラップ フレームワークでツリービューを使用してデータを動的にロードする方法

亚连
亚连オリジナル
2018-06-13 13:59:445190ブラウズ

この記事では、データを動的にロードするためのブートストラップ ツリービューの使用を実装し、必要な友人が参照できるクイック検索機能を追加します。はブートストラップに基づいており、シンプルかつエレガントな方法で、ビュー ツリー、リスト ツリーなどの継承ツリー構造を表示します。

Bootstrap Tree View は、実用的な Bootstrap ツリー メニューの特殊効果プラグインです。Bootstrap で作成された多くのページでは、この機能が必要です。色、背景色、アイコン、リンクなど、多くのパラメーターのカスタマイズ機能がサポートされています。 一時的に http://jonmiles.github.io/bootstrap-treeview/ に移動してください。それでは、早速始めましょう。

ユーザーは、州や都市の地域名情報 (ユーザー参照用、記述の標準化とテンプレートのインポートに使用) を迅速にクエリし、ツリー構造で表示する必要があります。

最終効果表示:

1. データテーブルの構造 データソースは、自己関連付け構造である省および市の地域情報テーブルです。図に示すように:

2. フロントページ

1. ページの紹介

<link rel="stylesheet" href="项目静态资源路径/bootstrap-treeview/css/bootstrap.css" rel="external nofollow" >
 <script type="text/javascript" src="项目静态资源路径/js/jquery/3.1.0/jquery-3.1.0.min.js"></script>
 <script type="text/javascript" src="项目静态资源路径/bootstrap/bootstrap.js"></script>
 <script type="text/javascript" src="项目静态资源路径/bootstrap-treeview/js/jquery.js"></script>
 <script type="text/javascript" src="项目静态资源路径/bootstrap-treeview/js/bootstrap-treeview.js"> </script>

2. ページ表示領域

<!-- 省市区地域查询展示 -->
 <p class="container">
  <p class="row">
  <p class="col-sm-4">
   <h4>快捷搜索</h4>
   <!-- <form> -->
   <p class="form-group">
    <label for="input-search" class="sr-only">快捷搜索:</label>
    <input type="input" class="form-control" id="input-search" placeholder="请输入要查询的省市区名称信息..." value="">
   </p>
   **_ <!-- 该部分为复选框,用于丰富搜索体验,本文忽略
<p class="checkbox">
    <label>
    <input type="checkbox" class="checkbox" id="chk-ignore-case" value="false"/>
     忽略大小写
    </label>
   </p>
   <p class="checkbox">
    <label>
    <input type="checkbox" class="checkbox" id="chk-exact-match" value="false">
     准确匹配
    </label>
   </p>
   <p class="checkbox">
    <label>
    <input type="checkbox" class="checkbox" id="chk-reveal-results" value="false">
     显示结果
    </label>
   </p> -->_**
   <button type="button" class="btn btn-success" id="btn-search">搜索</button>
   <button type="button" class="btn btn-default" id="btn-clear-search">清除</button>
   <!-- </form> -->
  </p>
  <p class="col-sm-4">
   <h4>省市区名称层级树</h4>
   <p id="treeview-searchable" class=""></p>
  </p>
  <p class="col-sm-4">
   <h4>查询结果展示</h4>
   <p id="search-output"></p>
  </p>
  </p>
  </p>
3.js スクリプト

$(function () {
  var defaultData;
   $.ajax({
    type: "post",
    url: "项目请求路径方法.json",
    dataType: "json",
    success: function (result) { 
    defaultData=result;
     var initSearchableTree = function() {
     return $(&#39;#treeview-searchable&#39;).treeview({
      data: defaultData,
      nodeIcon: &#39;glyphicon glyphicon-globe&#39;,
      emptyIcon: &#39;&#39;, //没有子节点的节点图标
      //collapsed: true,
     });
     };
     var $searchableTree = initSearchableTree();
     $(&#39;#treeview-searchable&#39;).treeview(&#39;collapseAll&#39;, { 
     silent : false//设置初始化节点关闭
    });
     var findSearchableNodes = function() {
     return $searchableTree.treeview(&#39;search&#39;, [ $.trim($(&#39;#input-search&#39;).val()), { ignoreCase: false, exactMatch: false } ]);
     };
     var searchableNodes = findSearchableNodes();
     // Select/unselect/toggle nodes
     $(&#39;#input-search&#39;).on(&#39;keyup&#39;, function (e) {
     var str = $(&#39;#input-search&#39;).val(); 
     if($.trim(str).length>0){
      searchableNodes = findSearchableNodes();
     } else {
     $(&#39;#treeview-searchable&#39;).treeview(&#39;collapseAll&#39;, { 
      silent : false //设置初始化节点关闭
     });
     }
     //$(&#39;.select-node&#39;).prop(&#39;disabled&#39;, !(searchableNodes.length >= 1));
     });
    var search = function(e) {
      var pattern = $.trim($(&#39;#input-search&#39;).val());
      var options = {
      ignoreCase: $(&#39;#chk-ignore-case&#39;).is(&#39;:checked&#39;),
      exactMatch: $(&#39;#chk-exact-match&#39;).is(&#39;:checked&#39;),
      revealResults: $(&#39;#chk-reveal-results&#39;).is(&#39;:checked&#39;)
      };
      var results = $searchableTree.treeview(&#39;search&#39;, [ pattern, options ]);
      var output = &#39;<p>&#39; + results.length + &#39; 匹配的搜索结果</p>&#39;;
      $.each(results, function (index, result) {
      output += &#39;<p>- <span style="color:red;">&#39; + result.text + &#39;</span></p>&#39;;
      });
      $(&#39;#search-output&#39;).html(output);
     }
     $(&#39;#btn-search&#39;).on(&#39;click&#39;, search);
     $(&#39;#input-search&#39;).on(&#39;keyup&#39;, search);
     $(&#39;#btn-clear-search&#39;).on(&#39;click&#39;, function (e) {
      $searchableTree.treeview(&#39;clearSearch&#39;);
      $(&#39;#input-search&#39;).val(&#39;&#39;);
      $(&#39;#search-output&#39;).html(&#39;&#39;);
      $(&#39;#treeview-searchable&#39;).treeview(&#39;collapseAll&#39;, {
      silent : false//设置初始化节点关闭
     });
     });
    
    },
    error: function () {
     alert("省市区地域信息加载失败!")
    }
   });
  });

3. メインの背景コード 背景は SpringMVC+ を使用しますSpring+Mybatis フレームワーク。以下はコントローラー層のコードです

​​
@ResponseBody
@RequestMapping(value = "/queryAreaInfo", method = { RequestMethod.POST }, produces = MediaType.APPLICATION_JSON_VALUE)
 public List<Object> queryAreaInfo() {
 List<AreaVO> areaInfo=new ArrayList<>();
 try {
 //获取缓存中的省市区信息(本项目直接从缓存中获取,也可以单独写方法到Service、Dao层查询)
 EcncSysConfig sysConfig = new EcncSysConfig();
 areaInfo = sysConfig.INIT_SYS_ECNC_AREAVO;
 } catch (Throwable e) {
 e.printStackTrace();
 }
 //盛放省份
 List<Object> result=new ArrayList<>();
 for (AreaVO areaVO : areaInfo) {
 Map<String, Object> map= new HashMap<>();
 if("2".equals(areaVO.getGrade())){
 map.put("text", areaVO.getName());
 //盛放地市
 List<Object> cList=new ArrayList<>();
 for (AreaVO cVO : areaInfo) {
  Map<String, Object> cMap=new HashMap<>();
  if (cVO.getParentId() != null && cVO.getParentId().equals(areaVO.getId())) {
  cMap.put("text", cVO.getName());
  //盛放区县
  List<Object> rList=new ArrayList<>();
  for (AreaVO rVO : areaInfo) {
  Map<String, Object> rMap=new HashMap<>();
  if (cVO.getId().equals(rVO.getParentId())) {
  rMap.put("text", rVO.getName());
  rList.add(rMap);
  }
  }
  cMap.put("nodes", rList);
  cList.add(cMap);
  }
 }
 map.put("nodes", cList);
 result.add(map);
 }
 }
 return result;
 }

上記は私がまとめたもので、将来的には皆さんのお役に立てれば幸いです。

関連記事:

ui-route を使用して AngularJS で多層ネストされたルーティングを実装する (詳細なチュートリアル)

Vue+jquery を使用してテーブルの指定された列のテキストを縮小する方法

方法それを実現するには vue を使用します ショッピングモール

Web マウス効果を実装する方法 (詳細なチュートリアル)

以上がブートストラップ フレームワークでツリービューを使用してデータを動的にロードする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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