Maison >interface Web >js tutoriel >Comment définir les valeurs des options dans les ng-options d'AngularJS lorsque votre source de données n'a pas de propriété de valeur explicite ?
De nombreux développeurs rencontrent des difficultés pour définir la propriété value lors de l'utilisation des ng-options directive dans AngularJS. Voici une explication complète pour résoudre ce problème.
La directive ng-options vous permet de remplir dynamiquement un champ
ng-options="{expression_for_value} as {expression_for_label} for {expression_for_items_in_source}
Dans l'exemple fourni, où « resultOptions » est un tableau d'objets contenant à la fois les propriétés "value" et "text", vous utiliserez cette syntaxe :
ng-options="obj.value as obj.text for obj in resultOptions"
Cela entraînera des options avec "obj.value" comme valeurs correspondantes et "obj.text" comme valeur étiquettes affichées.
Mise à jour : Les versions plus récentes d'AngularJS vous permettent de définir explicitement la valeur à l'aide de l'expression « suivre par » :
ng-options="obj.text for obj in array track by obj.value"
Comprendre les Syntaxe :
N'oubliez pas la syntaxe en établissant des parallèles avec les compréhensions de liste de Python. Dans l'exemple Python ci-dessous, les valeurs "x2" représentent les valeurs sélectionnées et les valeurs de la liste représentent les étiquettes affichées :
my_list = [x**2 for x in [1, 2, 3, 4, 5]] > [1, 4, 9, 16, 25]
Dans les options de sélection d'AngularJS, nous faites la différence entre la « valeur » pour la logique du code et le « texte » à des fins d'affichage. C'est là que le mot-clé "as" entre en jeu :
person.id as person.name for person in people
Dans cet exemple, "person.id" représente la valeur sélectionnée, tandis que "person.name" est l'étiquette affichée. De même, pour les objets JavaScript, déconstruisez les éléments en utilisant des paires "(clé, valeur)".
En comprenant ces nuances, vous pouvez définir efficacement les valeurs des options dans les ng-options d'AngularJS.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!