WordPress est constitué d’une multitude de fonctions dites « Helpers » qui ont pour vocation de faciliter la vie des développeurs. Comme un bon développeur est un développeur fainéant, je vais vous présenter les bienfaits de la fonction add_query_arg().
A quoi sert add_query_arg() ?
La fonction add_query_arg() est un helper permettant de faciliter l’ajout d’arguments dans une URL. Le but premier étant de pouvoir construire dynamiquement et simplement des URLs complexes.
Comment add_query_arg() fonctionne ?
La fonction add_query_arg() accepte 3 paramètres :
name | mixed | le nom de l'argument |
value | mixed | la valeur de l'argument du premier paramètre |
url | string | l’url sur laquelle ces arguments doivent s'appliquer. Par défaut, l'URL courante |
add_query_arg() : l’exemple par le code
Cas facile
Créons un lien capable de re-diriger comme suit : http://monsite.com/?foo=bar
Vous auriez peut-être fait de la sorte, sans variables :
[pastacode lang= »php » manual= »%3C%3Fphp%20echo%20home_url(%20’%3Ffoo%3Dbar’%20)%3B » message= » » highlight= » » provider= »manual »/]
Et avec une variable :
[pastacode lang= »php » manual= »%3C%3Fphp%20echo%20’https%3A%2F%2Fmonsite.com%3Ffoo%3D’%20.%20%24baz%3B » message= » » highlight= » » provider= »manual »/]
Et maintenant l’exemple ci-dessous avec le add_query_arg() qui va nous permettre d’atteindre le même résultat :
[pastacode lang= »php » manual= »%3C%3Fphp%20echo%20add_query_arg(%20’foo’%2C%20’bar’%2C%20home_url()%20)%3B » message= » » highlight= » » provider= »manual »/]
En réalité ça devient cool, utile et « rentable » lorsque l’on a 2+ arguments dans l’URL. Surtout que l’on peut jouer avec une URL comprenant déjà des arguments, rien n’est « écrasé ». Il faut aussi prendre en considération que le slash final va être également automatiquement généré, si nécessaire.
Pas besoin d’être ingénieur pour comprendre que l’on se casse la tête pour rien ?!
Cas plus compliqué
Encore un peu perplexe ? Il est utile d’utiliser ce helper, mais dans quels cas ? Prenons un exemple un peu plus compliqué mais surtout concret, permettant d’afficher un bouton afin de calculer un itinéraire GMAP :
https://www.google.com/maps?q={mon_addresse}&key={gmap_api_key}
Ce qu’il faut savoir c’est que le comportement de add_query_arg() change selon les arguments que lui sont passés. Si le premier argument est un tableau, ce helper comprendra seul que les associations des clés/valeurs seront à utiliser dans la construction de l’URL et que l’argument 2 sera l’URL.
[pastacode lang= »php » manual= »%3C%3Fphp%20%24query_vars%20%3D%20array(%0A%09’q’%20%20%20%3D%3E%20urlencode(%20130%20Avenue%20Jean-Jaur%C3%A8s%2C%2075001%2C%20Paris%20)%2C%0A%09’key’%20%3D%3E%20’oaOIpozPIEpizp11jKZAk’%2C%0A)%3B%0Aecho%20add_query_arg(%20%24query_vars%2C%20’https%3A%2F%2Fwww.google.com%2Fmaps’%20)%3B » message= » » highlight= » » provider= »manual »/]
Lorsque nous sommes sur 2+ arguments, cet helper va gérer seul l’ajout du ?
pour le premier argument mais également les &
pour les n suivants.
Cas complexe
Passons maintenant à un cas beaucoup plus complexe, qui va nécessiter l’utilisation de tableaux multidimensionnels, qui, passés en argument de add_query_arg(), va associer les clés de chaque tableau constituant ainsi les « groupements » des arguments construit par l’association des clés/valeurs.
WHAT ?! A n’y rien comprendre, alors voici une représentation qui vaudra 1000 explications :
[pastacode lang= »php » manual= »%3C%3Fphp%20add_query_arg(%20%5B%20’foo’%20%3D%3E%20%5B%20’bar’%20%3D%3E%20’baz’%20%5D%20%5D%2C%20’https%3A%2F%2Fmonsite.com’%20)%3B%0A%2F*%20https%3A%2F%2Fmonsite.com%2F%3Ffoo%5Bbar%5D%3Dbaz%20*%2F » message= » » highlight= » » provider= »manual »/]
Prenons donc maintenant un exemple à la hauteur de notre ambition et qui sera ni plus ni moins que la page des missions update du site arianespace.com : http://www.arianespace.com/mission-updates/?taxonomy[payload]=bsat-4a&taxonomy[client]=intelsat&taxonomy[mission]=none&taxonomy[post_tag]=none&date[year]=2017&date[month]=09&taxonomy[mission-update-category]=ariane-5
Avant donc de passer à la construction de notre tableau des arguments, analysons ensemble cette URL. On remarque qu’elle est découpée en « groupe » avec taxonomy d’un côté et date de l’autre. Donc nos deux tableaux de « niveau 0 ».
Que pour le « groupement » taxonomy, on y retrouve payload, client, mission, post_tag, mission-update-category et que date est constitué uniquement de year et month, qui seront respectivement au « niveau 1″.
On construit ainsi le tableau des query_vars :
[pastacode lang= »php » manual= »%3C%3Fphp%20%24query_vars%20%3D%20%5B%0A%09’taxonomy’%20%3D%3E%20%5B%20%0A%09%09’payload’%20%20%09%09%09%09%20%20%3D%3E%20’bsat-4a’%2C%0A%09%09’client’%20%20%20%09%09%09%09%20%20%3D%3E%20’intelsat’%2C%0A%09%09’mission’%20%20%09%09%09%09%20%20%3D%3E%20’none’%2C%0A%09%09’post_tag’%20%09%09%09%09%20%20%3D%3E%20’none’%2C%0A%09%09’mission-update-category’%20%3D%3E%20’ariane-5’%2C%20%0A%09%5D%2C%0A%09’date’%20%3D%3E%20%5B%20%0A%09%09’year’%20%20%3D%3E%202017%2C%0A%09%09’month’%20%3D%3E%2009%2C%20%0A%09%5D%2C%0A%5D%3B » message= » » highlight= » » provider= »manual »/]
Le plus dur est derrière nous ! Utilisons le :
[pastacode lang= »php » manual= »%3C%3Fphp%20add_query_arg(%20%24query_vars%2C%20get_post_type_archive_link(%20’mission-update’%20)%20)%3B » message= » » highlight= » » provider= »manual »/]
Conclusions sur le add_query_arg
Il devient donc très utile d’utiliser ce helper, et ainsi économiser du temps pour la construction d’URL :
- devient rentable lorsque l’on à ajouter 2 arguments ou plus dans l’URL
- gestion des séparateurs : `?` pour le premier argument et `&` pour les n suivants
- « n’écrase » pas les arguments déjà présents dans l’URL
- gère automatiquement le slash final
- l’URL est encodée avec urlencode_deep()
- l’URL n’est pas escape, il faut donc la wrapper dans esc_url()
Pour finir, laissez-moi dans les commentaires des suggestions d’utilisations pour lesquels vous vous seriez dit : « Cette fonction vient de me faire gagner du temps ! ».
Mais également si c’est la première fois que vous en entendez parler, dites-moi s’il a été facile pour vous de l’utiliser.
WordPressement vôtre