2013-07-08 6 views
16

Ich versuche es einfach zu machen denken. Verwenden Sie ng-include in Schleife, um mehrere HTML-Seiten in die gerenderte Seite einzufügen.Syntaxfehler: Token 'mod' ist unerwartet und erwartet [:] in Spalte 12 des Ausdrucks [Partials/{{mod}} .html] beginnend mit [mod}} .html]

<div ng-controller="pageCTRL"> 
<div ng-repeat="mod in modules"> 
    <div ng-include src='partials/{{mod}}.html'></div> 
</div> 
</div> 

$scope.modules = ["mod_nav","mod_feature","mod_footer"]; 

Aber alles, was ich bekomme ist das.

Error: Syntax Error: Token 'mod' is unexpected, expecting [:] at column 12 of the expression [partials/{{mod}}.html] starting at [mod}}.html]. 
at Error (<anonymous>) 
at throwError (angular.js:6066:11) 
at consume (angular.js:6104:7) 
at object (angular.js:6394:9) 
at primary (angular.js:6278:17) 
at unary (angular.js:6265:14) 
at multiplicative (angular.js:6251:39) 
at additive (angular.js:6239:16) 
at relational (angular.js:6230:16) 
at equality (angular.js:6221:16) <div ng-include="" src="partials/{{mod}}.html"> 

Haben Sie eine Lösung, wie es geht?

gemacht Code sieht wie folgt aus:

<div ng-include="" src="partials/mod_nav.html"></div> 

so sehe ich nicht, was ich falsch mache

Antwort

30

ng-include ‚s src einen Ausdruck erwartet, kein String:

<div ng-include src="'partials/' + mod + '.html'"></div> 
+0

von ng doc: ...