Comment définir et désactiver un cookie à l'aide de jQuery, par exemple créer un cookie nommé test
et définir la valeur sur 1
?
Comment définir et désactiver un cookie à l'aide de jQuery, par exemple créer un cookie nommé test
et définir la valeur sur 1
?
Mise à jour avril 2019
jQuery n'est pas nécessaire pour la lecture / manipulation des cookies, alors n'utilisez pas la réponse d'origine ci-dessous.
Accédez à https://github.com/js-cookie/js-cookie à la place et utilisez la bibliothèque qui ne dépend pas de jQuery.
Exemples de base:
// Set a cookie
Cookies.set('name', 'value');
// Read the cookie
Cookies.get('name') => // => 'value'
Voir les documents sur github pour plus de détails.
Voir le plugin:
https://github.com/carhartl/jquery-cookie
Vous pouvez alors faire:
$.cookie("test", 1);
Supprimer:
$.removeCookie("test");
De plus, pour définir un délai d'expiration d'un certain nombre de jours (10 ici) sur le cookie:
$.cookie("test", 1, { expires : 10 });
Si l'option expire est omise, le cookie devient un cookie de session et est supprimé à la fermeture du navigateur.
Pour couvrir toutes les options:
$.cookie("test", 1, {
expires : 10, // Expires in 10 days
path : '/', // The value of the path attribute of the cookie
// (Default: path of page that created the cookie).
domain : 'jquery.com', // The value of the domain attribute of the cookie
// (Default: domain of page that created the cookie).
secure : true // If set to true the secure attribute of the cookie
// will be set and the cookie transmission will
// require a secure protocol (defaults to false).
});
Pour relire la valeur du cookie:
var cookieValue = $.cookie("test");
Vous pouvez spécifier le paramètre de chemin si le cookie a été créé sur un chemin différent du chemin actuel:
var cookieValue = $.cookie("test", { path: '/foo' });
MISE À JOUR (avril 2015):
Comme indiqué dans les commentaires ci-dessous, l'équipe qui a travaillé sur le plugin d'origine a supprimé la dépendance jQuery dans un nouveau projet ( https://github.com/js-cookie/js-cookie ) qui a la même fonctionnalité et la même syntaxe générale que la version jQuery. Apparemment, le plugin d'origine ne va nulle part.
$.removeCookie('nameofcookie', { path: '/' });
Il n'est pas nécessaire d'utiliser jQuery en particulier pour manipuler les cookies.
Depuis QuirksMode (y compris les caractères d'échappement)
Jeter un coup d'œil à
la source
Vous pouvez définir les cookies comme comme
Vous pouvez obtenir les cookies comme
Et enfin, vous pouvez effacer les cookies comme celui-ci
J'espère que cela aidera quelqu'un :)
ÉDITER:
Si vous souhaitez définir le cookie sur tout le chemin / page / répertoire, définissez l'attribut path sur le cookie
Merci, vicky
la source
é
,北
etc. Je recommande la référence suivante: tools.ietf.org/html/rfc6265Vous pouvez utiliser un plugin disponible ici ..
https://plugins.jquery.com/cookie/
puis pour écrire un cookie faire
$.cookie("test", 1);
pour accéder au cookie défini faire
$.cookie("test");
la source
Voici mon module global que j'utilise -
la source
Assurez-vous de ne pas faire quelque chose comme ça:
Ensuite, si le cookie n'existe pas, le débogueur renverra un message inutile comme ".cookie pas une fonction".
Déclarez toujours d'abord, puis effectuez le fractionnement après avoir vérifié la valeur null. Comme ça:
la source
}
qui manque ou y a-t-il plusieurs lignes de code manquantes?Voici comment définir le cookie avec JavaScript:
le code ci-dessous provient de https://www.w3schools.com/js/js_cookies.asp
vous pouvez maintenant obtenir le cookie avec la fonction ci-dessous:
Et enfin, voici comment vous vérifiez le cookie:
Si vous souhaitez supprimer le cookie, définissez simplement le paramètre expires sur une date passée:
la source
Un exemple simple de définir un cookie dans votre navigateur:
Copiez / collez simplement et utilisez ce code pour définir votre cookie.
la source
jquery-1.9.0.min.js
sera rechargé pour tout le monde lorsque le nom de fichier est mis à jourjquery-1.9.1.min.js
, sinon le navigateur ne fera AUCUNE demande au serveur pour vérifier le contenu mis à jour. Si vous mettez à jour le code à l'intérieurjquery.cookie.js
sans modifier son nom de fichier, il peut ne PAS être rechargé dans les navigateurs qui ont déjà mis en cache lajquery.cookie.js
ressource.jquery.cookie.js
version sans changer son nom de fichier (à moins que votre serveur ne s'occupe de la mise en cache à l'aide d'E-Tags).Vous pouvez utiliser la bibliothèque sur le site Web de Mozilla ici
Vous pourrez définir et obtenir des cookies comme celui-ci
la source
Je pense que Fresher nous a donné un bon moyen, mais il y a une erreur:
Vous devez ajouter "valeur" près de getTime (); sinon le cookie expirera immédiatement :)
la source
Je pensais que la réponse de Vignesh Pichamani était la plus simple et la plus propre. Ajoutant simplement à sa capacité de définir le nombre de jours avant l'expiration:
EDIT: également ajouté l'option «n'expire jamais» si aucun numéro de jour n'est défini
Définissez le cookie:
la source
Je sais qu'il y a beaucoup de bonnes réponses. Souvent, je n'ai besoin que de lire les cookies et je ne veux pas créer de surcharge en chargeant des bibliothèques supplémentaires ou en définissant des fonctions.
Voici comment lire les cookies sur une seule ligne de javascript . J'ai trouvé la réponse dans l' article du blog de Guilherme Rodrigues :
Cela lit le cookie nommé
key
, agréable, propre et simple.la source
la source