1

首先,请记住,我自己从来没有使用过 Javascript(只使用了一些 100% 工作的脚本)和 Objet 编程(12 年前在 Pascal 上学习编程)。

现在,我必须创建一个德语和法语的小型在线商店。

我制作了设置 cookie 的功能,让语言保持选中状态。

但现在,我至少想要一件事:如果没有任何名为“Language”的 cookie,请创建一个并将其设置为法语。

我怎样才能做到这一点?

我的功能:

function setCookie(sName, sValue) {
var expDate = new Date();
expDate.setTime(expDate.getTime() + (365 * 24 * 3600 * 1000)); // ici 1 an
document.cookie = sName + "=" + escape(sValue) + ";expires=" + expDate.toGMTString() + ";path=/";
}

和页面:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <link href="./css/style.css" rel="stylesheet" media="all" type="text/css"  />
        <script type="text/Javascript" src="./javascript/cookie.js"></script>
        <title></title>
        <?php 
            require_once './includes/google_analytics.php';
        ?>
    </head>
    <body onload="setCookie('language','fr');">
    <p>
        Language : <a href="<?php echo $_SERVER['PHP_SELF']?>" onclick="setCookie('language','fr')">fr</a> /
        <a href="<?php echo $_SERVER['PHP_SELF']?>" onclick="setCookie('language','de')">de</a>
    </p>
    <?php       
        require_once './includes/menu.php';
    ?>

        <div id="contener">

        <!-- --------------------------------------------- -->    

    <?php 
        require_once './includes/header.php';
    ?>

        <!-- --------------------------------------------- --> 

        <!-- --------------------------------------------- --> 

    <?php 
        require_once './includes/footer.php';
    ?>

        </div>
    </body>
</html>

我想用“onload”做测试。

4

3 回答 3

0

我知道这个答案看起来很长,但它有非常方便的实用方法。您可以使用这两种实用 cookie 方法 -

// Store the name/value pair as a cookie, encoding the value with
// encodeURIComponent() in order to escape semicolons, commas, and spaces.
// If daysToLive is a number, set the max-age attribute so that the cookie
// expires after the specified number of days. Pass 0 to delete a cookie.
function setCookie(name, value, daysToLive) {
    var cookie = name + "=" + encodeURIComponent(value);
    if (typeof daysToLive === "number")
    cookie += "; max-age=" + (daysToLive*60*60*24);
    document.cookie = cookie;
}

// Return the document's cookies as an object of name/value pairs.
// Assume that cookie values are encoded with encodeURIComponent().
function getCookies() {
    var cookies = {}; // The object we will return
    var all = document.cookie; // Get all cookies in one big string

    if (all === "") // If the property is the empty string
        return cookies; // return an empty object

    var list = all.split("; "); // Split into individual name=value pairs

    for(var i = 0; i < list.length; i++) { // For each cookie
        var cookie = list[i];
        var p = cookie.indexOf("="); // Find the first = sign
        var name = cookie.substring(0,p); // Get cookie name
        var value = cookie.substring(p+1); // Get cookie value
        value = decodeURIComponent(value); // Decode the value
        cookies[name] = value; // Store name and value in object
        }
return cookies;
}

接着 -

    /* a js function to check and set cookie */
function checkAndSetCookie(sName, sdefaultValue) {
    var cookies = getCookies();
    if(typeof(cookies[sName])==="undefined"){
        setCookie(sName, sdefaultValue, 365 * 24 * 3600 * 1000)
    }
}

将html更改为-

<!-your html -->
<body onload="checkAndSetCookie('language','fr')">

或者

<!-- add just before body -->
<script type="text/javascript">
   checkAndSetCookie('language','fr');
</script>
<body>
于 2013-08-20T12:47:29.073 回答
0

这是检查 cookie 是否已设置的一种方法:

if (document.cookie.indexOf("language=") < 0)
    setCookie("language", "fr");

请注意,如果任何 cookie 的名称以 结尾,这也不会设置 cookie language


编辑:
这是一个适当的函数来检查是否已经存在具有特定名称的 cookie。

function cookieIsset(name)
{
    var cookies = document.cookie.split(";");
    for (var i in cookies)
    {
        if (cookies[i].indexOf(name + "=") == 0)
            return true;
    }
    return false;
}

你可以用它做

if (!cookieIsset("language"))
    setCookie("language", "fr");

如何onload
在您所在的<head>地区添加以下内容:

<script type="text/javascript">
document.onload = function () {
    // code ...
};
</script>

PHP 解决方案:
因为 OP 原来有标签。

if (!isset($_COOKIE['language']))
    setCookie('language', 'fr');
于 2013-08-20T12:44:47.827 回答
0

关键是您使用的是 XHTML - 在 XHTML 下 document.cookie 是一个只读属性。
这意味着无论您尝试什么,都无法从 JavaScript 设置 cookie。但是,仍然设置 cookie 的一种可能方法是设置 AJAX 调用,将相关参数传递给后台脚本。然后可以使用所述后台脚本来设置cookie。

于 2018-08-30T15:39:48.610 回答