[英]Issues with Jquery.cookie plugin
我研究了有關該主題的一些問答和文章,似乎我在這里犯了一個錯誤。 我已將此代碼包含在$(document).ready javascript中,並將其加載到index.html的末尾。 所使用的兩個ID均已正確插入HTML並瀏覽Jquery.cookies文檔,但看不到遺忘的內容。 是否應該在HTML的開頭加載cookie函數?
按鈕可切換到正確語言的HTML HTML文件...
<div class="col-xs-12 col-sm-6 col-md-6"><br>
<h1>Comment aimeriez vous être servi?</h1><a href="fr.html">
<div id="set_fr_button" class="btn btn-primary btn-lg text-center">En Français</div></a>
</div>
<div class="col-xs-12 col-sm-6 col-md-6"><br>
<h1>How would you liked to be served?</h1><a href="en.html">
<div id="set_en_button" class="btn btn-primary btn-lg text-center">In English</div></a>
</div>
包含cookie代碼的JS文件...
$(function () {
var url = 'mannydesigns.co';
var en_page = 'en.html';
var fr_page = 'fr.html';
if ($.cookie('default_page') != null) {
if (window.location.href != url + '/' + $.cookie('default_page')) {
window.location.href = url + '/' + $.cookie('default_page');
}
}
$('#set_en_button').click(function () {
$.cookie('default_page', en_page, { expires: 999 });
});
$('#set_fr_button').click(function () {
$.cookie('default_page', fr_page, { expires: 999 });
});
});
不知道您遇到什么問題,但是我在您的代碼中發現了一些問題。
首先,您不需要鏈接中的<div>
。
<div class="col-xs-12 col-sm-6 col-md-6"><br>
<h1>Comment aimeriez vous être servi?</h1>
<a href="fr.html" id="set_fr_button" class="btn btn-primary btn-lg text-center">En Français</a>
</div>
<div class="col-xs-12 col-sm-6 col-md-6"><br>
<h1>How would you liked to be served?</h1>
<a href="en.html" id="set_en_button" class="btn btn-primary btn-lg text-center">In English</a>
</div>
其次,您的點擊事件功能將永遠無法使用,您應該使用e.preventDefault();
以防止在設置Cookie之前加載新頁面。
$(function () {
var url = 'mannydesigns.co';
var en_page = 'en.html';
var fr_page = 'fr.html';
if ($.cookie('default_page') != null) {
if (window.location.href != url + '/' + $.cookie('default_page')) {
window.location.href = url + '/' + $.cookie('default_page');
}
}
$('#set_en_button').click(function (e) {
e.preventDefault();
$.cookie('default_page', en_page, { expires: 999 });
window.location.href = $(this).attr('href');
});
$('#set_fr_button').click(function (e) {
e.preventDefault();
$.cookie('default_page', fr_page, { expires: 999 });
window.location.href = $(this).attr('href');
});
});
伙計們,對我有用的是隔離此代碼並最后加載它,當它起作用時,我意識到當我已經在主頁上時該代碼也在添加URL,因此找不到正確的HTML頁面...因此,有效的最終代碼如下(基本上是相同的,刪除了我的if語句中的url,沒有e.preventdefault,因為不需要它):
$(function () {
var url = 'mannydesigns.co';
var en_page = 'en.html';
var fr_page = 'fr.html';
if ($.cookie('default_page') != null) {
if (window.location.href != '/' + $.cookie('default_page')) {
window.location.href = '/' + $.cookie('default_page');
}
}
$('#set_en_button').click(function () {
$.cookie('default_page', en_page, { expires: 999 });
});
$('#set_fr_button').click(function () {
$.cookie('default_page', fr_page, { expires: 999 });
});
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.