Maison > interface Web > js tutoriel > Comment publier des données de formulaire codées en URL avec le service $http d'AngularJS sans jQuery ?

Comment publier des données de formulaire codées en URL avec le service $http d'AngularJS sans jQuery ?

Linda Hamilton
Libérer: 2024-12-03 17:12:14
original
487 Les gens l'ont consulté

How to POST URL-Encoded Form Data with AngularJS's $http Service Without jQuery?

POSTing de données de formulaire codées en URL avec $http sans jQuery

Lorsque vous effectuez des appels AJAX à l'aide du service $http d'AngularJS, vous pouvez rencontrer des difficultés lors de l'envoi de données de formulaire qui nécessitent Encodage d'URL. Cela peut être particulièrement frustrant pour ceux qui recherchent une solution sans jQuery.

Problème

Les tentatives d'envoi de données de formulaire à l'aide du service $http d'Angular avec les approches suivantes ont abouti à des échecs :

  • données : {nom d'utilisateur : $scope.userName, mot de passe : $scope.password}
  • params : {nom d'utilisateur : $scope.userName, mot de passe : $scope.password}
  • données : JSON.stringify({nom d'utilisateur : $scope.userName, mot de passe : $scope.password})

Solution

Pour POST avec succès les données de formulaire codées en URL, vous avez besoin pour transformer l'objet de données en paramètres d'URL. Selon Ben Nadel, Angular sérialise par défaut les données sortantes au format JSON et les publie avec le type de contenu "application/json".

Pour modifier ce comportement et publier les données du formulaire, mettez à jour le code comme suit :

data: {username: $scope.userName, password: $scope.password}
Copier après la connexion
transformRequest: function(obj) {
    var str = [];
    for(var p in obj)
    str.push(encodeURIComponent(p) + "=" + encodeURIComponent(obj[p]));
    return str.join("&");
},
Copier après la connexion

Ce code convertit l'objet JavaScript en une chaîne codée en URL, permettant un POSTing réussi des données de formulaire sans jQuery.

Solution améliorée avec Angular 1.4

Pour AngularJS v1.4 et versions ultérieures, l'utilisation des services nouvellement ajoutés offre une solution encore plus simple :

data: {username: $scope.userName, password: $scope.password},
headers: {
    'Content-Type': 'application/x-www-form-urlencoded'
}
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal