0

ウェブサイトの言語を変更したい状態を使用して、ios のようなスタイルのチェックボックスがあります。私はこのコードを使用します: langchange.js

$(document).ready(function(){
    $("#langfct").change(function() { 
        if($(this).is(":checked")) { 
            $.ajax({
                url: 'langfunc.php',
                type: 'POST',
                data: { langstate: "fr" }
            });
            alert('fr');
            window.location.reload();
        } else {
            $.ajax({
                url: 'langfunc.php',
                type: 'POST',
                data: { langstate: "en" }
            });
            alert('en');
            window.location.reload();
        }
    }); 
});

langfunc.php

    <?php
    session_start ();
    $valang = $_POST['langstate'];
    $lang = substr($_SERVER['HTTP_ACCEPT_LANGUAGE'], 0, 2);
    if ($valang == fr){
        include("french.php");
    }elseif ($valang == en) {
        include("english.php");
    } else{

    switch ($lang){
        case "fr":
            //echo "PAGE FR";
            include("french.php");//include check session FR
            break;
        case "en":
            //echo "PAGE EN";
            include("english.php");
            break;        
        default:
            //echo "PAGE EN - Setting Default";
            include("english.php");//include EN in all other cases of different lang detection
            break;
    }
    }
    ?>

チェックボックスの状態を使用して、langstate を保存し、データをリロードするにはどうすればよいですか? どうも

4

1 に答える 1

0

以下のようにコードを再構成します。問題は、ajax が完了する前にページをリロードしていて、ブロッキング アラートが原因で ajax が送信されない可能性があることです。

var lang = 'en'; //default
if($(this).is(":checked")) { 
    lang = 'fr';    
}

$.ajax({
     url: 'langfunc.php',
     type: 'POST',
     data: { langstate: lang },
     success: function() {
        alert(lang);
        window.location.reload();
     }
});
于 2013-10-06T10:46:51.077 に答える