Каков «лучший» способ получить и установить значение одного файла cookie с помощью JavaScript?

Я хочу увеличивать значение cookie каждый раз, когда на страницу ссылаются, даже если страница загружается из кеша. Каков самый «лучший» или самый краткий способ реализовать это?

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
17
0
18 604
3
Перейти к ответу Данный вопрос помечен как решенный

Ответы 3

Большинство старых функций обработки файлов cookie, которые я видел, используют простые строковые манипуляции для хранения получаемых значений, например, это, вы можете использовать другие библиотеки, например cookie-js, небольшую утилиту (<100 строк) для доступа к файлам cookie.

Я лично использую jQuery в своих проектах, и я использую Плагин jQuery Cookie, это действительно просто:

var cookieName = "increment";

if ($.cookie(cookieName) == null){
  $.cookie(cookieName, 1, { expires: 10 });
}else{
  var newValue = Number($.cookie(cookieName)) + 1;
  $.cookie(cookieName, newValue, { expires: 10 });
}
Ответ принят как подходящий

Украдено с http://www.quirksmode.org/js/cookies.html#script

function createCookie(name,value,days) {
    if (days) {
        var date = new Date();
        date.setTime(date.getTime()+(days*24*60*60*1000));
        var expires = "; expires = "+date.toUTCString();
    }
    else var expires = "";
    document.cookie = name+" = "+value+expires+"; path=/";
}

function readCookie(name) {
    var nameEQ = name + " = ";
    var ca = document.cookie.split(';');
    for(var i=0;i < ca.length;i++) {
        var c = ca[i];
        while (c.charAt(0)==' ') c = c.substring(1,c.length);
        if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
    }
    return null;
}

function eraseCookie(name) {
    createCookie(name,"",-1);
}

используй это:

var oldCount = parseInt(readCookie('hitCount'), 10) || 0;
createCookie('hitCount', oldCount + 1, 7);

как указано в комментариях, вы должны привести к типу int, поскольку файлы cookie хранятся и возвращаются в виде строк. Использование foo++ или ++foo фактически произведет трансляцию за вас, но безопаснее точно знать, с чем вы работаете:

var x = "5";  // x = "5" (string)
x += 1;       // x = "51" (string!)
x += 5;       // x = "515" (string!)
++x;          // x = 516 (number)

readCookie возвращает подстроку, вы должны преобразовать ее как число при увеличении 1, иначе у вас будет, 1, 11, 111, 1111 ...

Christian C. Salvadó 04.11.2008 09:58

Вам не хватает escape и unescape для значения

hultqvist 09.03.2012 18:13

Обратите внимание, что toGMTString теперь устарела в пользу toUTCString.

BeauCielBleu 18.06.2014 11:23

лучший способ всегда самый простой:

function getCookie(name) {
  return (name = (document.cookie + ';').match(new RegExp(name + '=.*;'))) && name[0].split(/=|;/)[1];
}

// the default lifetime is 365 days
function setCookie(name, value, days) {
  var e = new Date;
  e.setDate(e.getDate() + (days || 365));
  document.cookie = name + " = " + value + ';expires=' + e.toUTCString() + ';path=/;domain=.' + document.domain;
}

эти функции ожидают, что значение будет простой строкой, но вы всегда можете JSON.stringify его, если хотите, или, возможно, сделать с ним что-то еще ...

Престижность для 1-строчки в getCookie +1

user4244405 29.03.2019 01:16

Другие вопросы по теме