javascript - Ng-Repeat 不重复(或返回任何内容)

标签 javascript html json angularjs angularjs-ng-repeat

我是 AngularJS 的新手,目前仍在使用它。为了自学这些概念,我正在处理一些手工构建的 JSON 文件。

我首先使用它来构造弹出 javascript 菜单的元素,方法是在 Controller 访问 JSON 文件的列表元素上使用 ng-repeat。效果很好。然后,我尝试使用稍微复杂的数据模型在不同的 JSON 文件上重复相当复杂的表行结构。在运行时,这会返回一条注释,与之前的实验一样,但没有与之相关的元素。

我使用两个 Controller 作为一个应用程序的一部分。我认为问题可能在于如何访问 JSON 文件中的数据。

不包括 CSS,因为我认为这不会影响它。 “MenuCtrl” Controller 仍然正常运行(在整个页面的元素上调用 ng-app),因此我只包含我认为相关的 HTML。

Controller .js:

  var profileApp = angular.module('profileApp', []);
  profileApp.controller('BookCtrl', function ($scope, $http){
    $http.get('books.json').success(function(data) {
      $scope.bookItems = data;
    });
  });
  profileApp.controller('MenuCtrl', function ($scope, $http){
    $http.get('profile.json').success(function(data) {
      $scope.profileItems = data;
    });
  });

书籍.json:

[
  {
"title": "The Design of Everyday Things",
"author": "Donald Norman",
"img": "img/norman.jpg",
"isbn": "",
"description":".",
"id1": "hoverA",
"id2": "hover1"
  },
  {
"title": "Plans and Situated Actions",
"author": "Lucille Suchman",
"img": "img/planssitu.jpg",
"isbn": "",
"description":".",
"id1": "hoverB",
"id2": "hover2"
  },
  {
"title": "Where The Action Is",
"author": "Paul Dourish",
"img": "img/wheretheaction.jpg",
"isbn": "",
"description":".",
"id1": "hoverC",
"id2": "hover3"
  },
  {
"title": "Information Processing and Human-Machine Interaction",
"author": "Jens Rasmussen",
"img": "img/rasmussen.jpg",
"isbn": "",
"description":".",  
"id1": "hoverD",
"id2": "hover4"
  },
  {
"title": "The Imaginary App",
"author": "Paul D. Miller and Svitlana Matviyenko",
"img": "img/imaginary.jpg",
"isbn": "",
"description":".",
"id1": "hoverE",
"id2": "hover5"
  },
  {
"title": "The Gutenberg Galaxy",
"author": "Marshall Mcluhan",
"img": "img/guten.jpg",
"isbn": "",
"description":".",
"id1": "hoverF",
"id2": "hover6"
  }
]

HTML 的相关部分:

<div  align="center">
<p class="central">Bibliography</br></p></br>
<table class="content1" ng-controller="BookCtrl" >
    <colgroup>
        <col span="1" class="col1">
        <col span="1.5" class="col2">
    </colgroup>
    <tbody ng-repeat="book in bookItems" >
    <tr >
        <td align="center"><div class="center"><div class="round3"><a href=""><img class="book" ng-src="{{book.img}}"></img></a></div></div></td>
        <td></td>
        <td class="wrapword" style="padding-left:10px;"><p><span class="content2"><strong>{{book.title}}</strong></span>
            <span class="small2">{{book.author}}</br>
            <span class="hide2" id="{{book.id1}"}>See Description</span>
            <span class="hide" id="{{book.id2}}">{{book.description}}</span>
            </span>
        </p></td>
    </tr>
    </tbody>
</table>
</div>

检查运行页面的元素时得到的结果:

<table class="content1 ng-scope" ng-controller="BookCtrl">
    <colgroup>
        <col span="1" class="col1">
        <col span="1.5" class="col2">
    </colgroup>
    <!-- ngRepeat: book in bookItems -->
</table>

最佳答案

您提到了 TBODY 中的 ng-repeat,我已更正。现在应该可以工作了。

<div  align="center">
<p class="central">Bibliography</br></p></br>
<table class="content1" ng-controller="BookCtrl" >
    <colgroup>
        <col span="1" class="col1">
        <col span="1.5" class="col2">
    </colgroup>
    <tbody  >
    <tr ng-repeat="book in bookItems">
        <td align="center"><div class="center"><div class="round3"><a href=""><img class="book" ng-src="{{book.img}}"></img></a></div></div></td>
        <td></td>
        <td class="wrapword" style="padding-left:10px;"><p><span class="content2"><strong>{{book.title}}</strong></span>
            <span class="small2">{{book.author}}</br>
            <span class="hide2" id="{{book.id1}"}>See Description</span>
            <span class="hide" id="{{book.id2}}">{{book.description}}</span>
            </span>
        </p></td>
    </tr>
    </tbody>
</table>
</div>

关于javascript - Ng-Repeat 不重复(或返回任何内容),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28204822/

相关文章:

javascript - React Router createBrowserRouter() 不渲染子元素

javascript - Bootstrap 4 输入分机值

html - 用 div 标签替换 html 表格

jquery - 是否可以使用不同的 <div> 标签提供不同的背景图片?

javascript - 无法显示在 HTML 上收到的 JSON 数据

javascript - JQuery ajax 功能不起作用

javascript - Angular 2 获取 header 响应

javascript - Spotfire:如何通过 Javascript 重新加载/刷新文本区域 html

html - 在 :before pseudo element behind of element 中发送图像

javascript - 异步获取数据,将结果聚合到一个对象。默认情况下,对象是否被 javascript 锁定?