91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Angular中ng-repeat與ul li的多層嵌套重復問題

發布時間:2020-08-22 17:23:50 來源:腳本之家 閱讀:164 作者:SongHaoHui96 欄目:web開發

學習ng-repeat的過程中常常使用到ng-repeat=”item in array”來循環輸出所需要的元素,但是當我們需要使用ng-repeat進行多層嵌套時則容易出現數據重復的問題。

如在加載與點擊事件于js中進行兩次http請求獲取data分別為list01[]數組和list02[]賦值再如下顯示則會導致it1下每個ul都會重復輸出list02[]數組中的內容

<ul ng-repeat="it1 in list01">
  <li ng-click="show(it1)">{{it1.value}}</li>
  <ul ng-repeat="it2 in list02">
    <li>{{it2.value}}</li>
  </ul>
</ul>

輸出如:

  1-1
  1-2
  1-1
  1-2

而非

  1-1
  1-2
  2-1
  2-2

其實這個也不是問題,只要換一種思維方式將列表和父級元素相關聯形成樹狀結構就好了

HTML中代碼如下

<ul ng-repeat="it1 in list01">
  <li ng-click="show(it1)">{{it1.name}}</li>
  <ul ng-repeat="it2 in it1.child" ng-show="it1.showChild" >
    <li ng-click="show(it1, it2)">{{it2.name}}</li>
    <ul ng-repeat="it3 in it2.child" ng-show="it2.showChild" >
      <li ng-click="show(it1, it2, it3)">{{it3.name}}</li>
      <ul ng-repeat="it4 in it3.child" ng-show="it3.showChild">
        <li>{{it4.name}}</li>
      </ul>
    </ul>
  </ul>
</ul>

js中代碼如下

$http.get('ng01.json').success(function (_data) {
  $scope.list01 = [];
  $scope.list01 = _data.data;
});
$scope.show = function (it1, it2, it3) {
  if(it3 != null){
    $http.get("ng04.json").success(function (_data) {
      $scope.list04 = [];
      $scope.list04 = _data.data;
      for(var x in $scope.list03){
        $scope.list03[x].showChild = false;
      }
      it3.showChild = true;
      it3.child = _data.data;
     });
     return;
  }
  if(it2 != null){
    $http.get("ng03.json").success(function (_data) {
      $scope.list03 = [];
      $scope.list03 = _data.data;
      for(var x in $scope.list02){
        $scope.list02[x].showChild = false;
      }
      it2.showChild = true;
      it2.child = _data.data;
    });
    return;
  }
  $http.get("ng02.json").success(function (_data) {
    $scope.list02 = [];
    $scope.list02 = _data.data;
    for(var x in $scope.list01){
      $scope.list01[x].showChild = false;
    }
    it1.showChild = true;
    it1.child = _data.data;
  });
}

json文件都是這樣的

{
 "success":1,
 "data":[
  {"name":"01"},
  {"name":"02"}
 ]
}

總結

以上所述是小編給大家介紹的Angular中ng-repeat與ul li的多層嵌套,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

萨迦县| 柏乡县| 康定县| 南丹县| 天长市| 宕昌县| 尉氏县| 贺兰县| 平和县| 石嘴山市| 丽水市| 旺苍县| 探索| 保德县| 林州市| 东安县| 叙永县| 昭平县| 武胜县| 陇南市| 祥云县| 台江县| 兴安县| 焦作市| 镇赉县| 宜章县| 株洲县| 巴林右旗| 格尔木市| 龙川县| 黄骅市| 安多县| 土默特左旗| 孝昌县| 神木县| 万年县| 攀枝花市| 汾西县| 枣阳市| 金堂县| 永胜县|