<p ng-controller="listCtrl">
<h1>这是列表页面</h1>
<ul>
<li ng-repeat="item in myList"><a href="#/myDetail/{{$index}}">{{item}}</a></li>
<li ng-repeat="item in myList"><button ng-click="jump('/myDetail/'+$index)">{{item}}</button></li>
</ul>
</p>
Comme le titre l'indique, dans le code ci-dessus, je dois obtenir la valeur $index en tant que paramètre Dans le premier li, je dois ajouter {{}} pour obtenir la valeur, mais dans le second li, je ne le fais pas. pas besoin de l'ajouter ; comment distinguer cela ? ?
Pour analyser les données en HTML natif, vous devez utiliser {{}} pour lier les données, mais cela n'est pas nécessaire derrière la commande ng.
{{ $var }}
包裹的模板变量,当需要直接输出变量值,而无需额外解析(如过滤器处理、作为指令参数、作为函数参数)时使用,反之,ng-click="jump('/myDetail/'+ $index)"
est le paramètre appelé dans la commande.Le critère simple est
Si le type attribué à l'attribut actuel est un type littéral, tel qu'un attribut dans un modèle HTML, ou un attribut avec
@
comme modificateur dans une directive, alors si des doubles accolades ne sont pas ajoutées lors de l'attribution de la valeur, cela sera calculé comme un littéral Oui, si vous souhaitez l'analyser comme une variable, vous devez ajouter des doubles accolades.Si le type attribué à l'attribut actuel est un type non-chaîne, tel que diverses instructions intégrées dans le modèle angulaire, ou des attributs modifiés avec
<
、=
、&
dans les instructions, alors l'affectation sera analysée selon les règles de syntaxe de js. Dans ce cas, pas besoin d'ajouter des accolades.Expliquez d'abord les deux types dans Angular :
Ensuite, vous pouvez vous référer au contexte pour déterminer si vous écrivez une partie de type JS ou une chaîne littérale, afin qu'il soit facile de juger si vous avez besoin d'un modèle ou d'une expression.