利用自定義指令封裝表格,遇到了個奇怪的問題,自定義指令里ng-transclude里的ng-repeat作用于tr時不起作用,但是換了下ul和li,ng-repeat又可以正常顯示。搞不懂了額
代碼如下
<body ng-app="aaa" ng-controller="aa">
<test>
<ul>
<li ng-repeat="data in $data">
<span>{{data.name}}</span>
<span>{{data.age}}</span>
</li>
</ul>
</test>
<hr>
<test>
<tbody>
<tr ng-repeat="data in $data">
<td>{{data.name}}</td>
<td>{{data.age}}</td>
</tr>
</tbody>
</test>
<hr>
<table>
<tr ng-repeat="c in cc">
<td>{{c.name}}</td>
<td>{{c.age}}</td>
</tr>
</table>
</body>
<script>
var app = angular.module("aaa", []);
app.controller("aa", function($scope) {
$scope.cc = [
{name: '小明', age: 12},
{name: '小白', age: 23}
];
});
app.directive("test", function() {
return {
restrict: "E",
template: "<div>2333<table ng-transclude></table></div>",
transclude: true,
link: function($scope) {
$scope.$data = [
{name: 'zyh', age: 22},
{name: 'ljy', age: 24},
{name: 'jj', age: 23},
];
// $scope.$data = [1, 2, 3];
}
};
});
</script>
運行的結(jié)構(gòu)如下:
控制臺無報錯,求大佬解救一下小白啊。。
(以下為說法錯誤)
var ngTranscludeDirective = ngDirective({
link: function($scope, $element, $attrs, controller, $transclude) {
if (!$transclude) {
throw minErr('ngTransclude')('orphan',
'Illegal use of ngTransclude directive in the template! ' +
'No parent directive that requires a transclusion found. ' +
'Element: {0}',
startingTag($element));
}
$transclude(function(clone) {
$element.empty();
$element.append(clone);
});
}
});
ng-transclude 這個指令,不是在節(jié)點中間插入內(nèi)容,而是把節(jié)點清空,在節(jié)點的后面 append 內(nèi)容。
tbody 又不能單獨存在(一定要包在 table 中),但是 ul 當然可以單獨存在。
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內(nèi)教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓領(lǐng)域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務(wù)負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。