タイトルが非常にわかりにくい場合は申し訳ありませんが、この例を複製しようとしています: http://plnkr.co/edit/NBDgqKOy2qVMQeykQqTY?p=preview正常に動作しますが、ajax 経由でデータをロードすると動作しません。元のコントローラーは次のとおりです。
app.controller('MainCtrl', function($scope) {
$scope.links = [
{
text: 'Menu Item 1',
url: '#',
},{
text: 'Menu Item 2',
url: '#',
submenu: [
{
text: 'Sub-menu Item 3',
url: '#',
},{
text: 'Sub-menu Item 4',
url: '#',
submenu: [
{
text: 'Sub-sub-menu Item 5',
url: '#',
},{
text: 'Sub-sub-menu Item 6',
url: '#',
}
]
}
]
},{
text: 'Menu Item 3',
url: '#',
}
];
});
私がいる間:
app.controller('SiteTreeCtrl', function ($scope, $http) {
$http.post('/ajaxsite/tree', { section: "website" }).success(function (data) {
$scope.folders = data.links;
});
});
問題は、データの前にhtml テンプレートがロードされ、データの準備ができたときにバインディングが既に適用されていることです。
作業例 (ajax なし): http://plnkr.co/edit/NBDgqKOy2qVMQeykQqTY?p=preview
動作しない例 (ajax): http://plnkr.co/edit/lF5VkRT67IybRQm5yTuB?p=preview
そのための最善の方法は何ですか?