【发布时间】:2025-11-28 20:30:01
【问题描述】:
我编写了一个新指令 (showfor) 以使用 angular 和 bootstrap 在我的 UI 中启用 popover。 “showfor”指令在 html 中有效,但在数据内容中无效。我需要弹出框来显示列表(而不是整个数组)。任何形式的帮助将不胜感激。
代码是:
'use strict';
var isbnApp = angular.module('plunker', []);
isbnApp.directive('mypopover', function() {
return function(scope, element) {
element.popover();
};
});
isbnApp.directive('showfor',function(){
return{
restrict:"AEC",
template:"<li data-ng-repeat='item in records'>{{item.imageType}}</li>"
};
});
isbnApp.controller('popCtrl', function($scope) {
$scope.records = [{
"imageType": "JPEG",
"rendition": "cover_80"
}, {
"imageType": "TIFF",
"rendition": "cover_20"
}];
});
<!DOCTYPE html>
<html ng-app="plunker">
<head>
<meta charset="utf-8" />
<title>Content Discovery</title>
<script data-require="jquery@*" data-semver="3.1.1" src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<script data-require="angular.js@*" data-semver="1.6.5" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.6.5/angular.min.js" type="text/javascript"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.3.9/js/tether.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/js/bootstrap.min.js"></script>
<script src="app.js"></script>
<link rel="stylesheet" href="style.css" />
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.6/css/bootstrap.min.css" />
</head>
<body>
<div class="container" data-ng-controller="popCtrl">
<br />
<a mypopover="" tabindex="0" role="button"
class="btn btn-primary btn-sm"
data-container="body" data-toggle="popover"
data-html="true" title="<b>Coltrane Data</b>"
data-content="<showfor></showfor>">
Coltrane
</a>
<showfor></showfor>
</div>
</body>
</html>
【问题讨论】:
-
如果你给
data-content="<showfor>{{passengers}}</showfor>"它会显示列表,这是你想要的吗? -
嗨@NarenMurali,不,我希望指令显示迭代数组而不是数组本身的列表。
标签: angularjs angularjs-ng-repeat popover bootstrap-4 custom-directive