0

通常のスタイルシートとアクセス可能なバージョンの間でスタイルシートを変更するコードをいくつか書きました。理論的にはこれは機能しますが、ページを更新するとすぐにデフォルト バージョンに戻ります。ある種の Cookie を保存する必要があることはわかっており、Google で見つけたいくつかのスクリプトを試しましたが、どれも機能しません。他のスタイルシートが要求されるまで、選択したスタイルシートをサイト全体に固定するために何が必要かを誰かが知っている場合は、それをいただければ幸いです。

これまでのコード:

<link type="text/css" href="style.css" rel="stylesheet" title="normal" />
<link type="text/css" href="css/accessible.css" rel="alternate stylesheet" title="accessible" />

<form>
    <input type="submit" onclick="switch_style('normal');return false;" name="theme" value="" id="normal" title="View the site in it's original format">
    <input type="submit" onclick="switch_style('accessible');return false;" name="theme" value="" id="accessible" title="View the site in it's simplest form">
</form>

これは私が組み込んだ JavaScript で、どこかにバグがあるようですが、私の人生では見つけることができません。

var style_cookie_name = "style" ;
var style_cookie_duration = 30 ;

function switch_style ( css_title )
{
var i, link_tag ;
for (i = 0, link_tag = document.getElementsByTagName("link") ;
i < link_tag.length ; i++ ) {
if ((link_tag[i].rel.indexOf( "stylesheet" ) != -1) &&
  link_tag[i].title) {
  link_tag[i].disabled = true ;
  if (link_tag[i].title == css_title) {
    link_tag[i].disabled = false ;
  }
}
set_cookie( style_cookie_name, css_title,
  style_cookie_duration );
}
}
function set_style_from_cookie()
{
var css_title = get_cookie( style_cookie_name );
if (css_title.length) {
switch_style( css_title );
}
}
function set_cookie ( cookie_name, cookie_value,
lifespan_in_days, valid_domain )
{
var domain_string = valid_domain ?
                   ("; domain=" + valid_domain) : '' ;
document.cookie = cookie_name +
                   "=" + encodeURIComponent( cookie_value ) +
                   "; max-age=" + 60 * 60 *
                   24 * lifespan_in_days +
                   "; path=/" + domain_string ;
}
function get_cookie ( cookie_name )
{
var cookie_string = document.cookie ;
if (cookie_string.length != 0) {
    var cookie_value = cookie_string.match (
                    '(^|;)[\s]*' +
                    cookie_name +
                    '=([^;]*)' );
    return decodeURIComponent ( cookie_value[2] ) ;
}
return '' ;
}
4

1 に答える 1

1

get_cookie 関数にいくつかの小さなエラーがあります。

削除する:

function get_cookie ( cookie_name )
{
var cookie_string = document.cookie ;
if (cookie_string.length != 0) {
    var cookie_value = cookie_string.match (
            '(^|;)[\s]*' +
            cookie_name +
            '=([^;]*)' );
    return decodeURIComponent ( cookie_value[2] ) ;
}
return '' ;
}

と置換する:

function get_cookie ( cookie_name )
{
var cookie_string = document.cookie ;
if (cookie_string.length != 0) {
    var cookie_value = cookie_string.match(
        '(^|;) ?' + 
        cookie_name + 
        '=([^;]*)(;|$)' );
    return decodeURIComponent ( cookie_value[2] ) ;
}
return '' ;
}

あなたや同じ問題を抱えている他の誰かに役立つことを願っています。

于 2014-01-25T18:07:46.843 に答える