2

良いチュートリアルを見つけました:チュートリアル

しかし、ローカルでは機能しません。問題は、responsetext が私の php コード全体を返すことです。ajaxclock.html をダブルクリックして、Firefox を使用します。驚いたことに、それはサーバー上で動作します。

ここにコード: ajaxclock.html

<!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" xml:lang="en" lang="en">
<head>
    <title>AJAX Tutorial</title>
</head>
<body>
    <div id="time"></div>
    <button onclick="getTime();">Aktualisieren</button>
    <script type="text/javascript" src="script.js"></script>
</body>
</html> 

script.js

var req = getXmlHttpRequestObject();
window.onload = getTime();

function getXmlHttpRequestObject()
{
    if(window.XMLHttpRequest) 
    {
         return new XMLHttpRequest();
    } 
    else if(window.ActiveXObject) 
    {
        return new ActiveXObject("Microsoft.XMLHTTP");
    } 
    else 
    {
        alert('Ajax funktioniert bei Ihnen nicht!');
    }
}

function getTime()
{
    if(req.readyState == 4 || req.readyState == 0) 
    {
        req.open('GET', 'ajaxclock.php', true);
        req.setRequestHeader("Content-Type","text/plain");
        req.onreadystatechange = setMessage;
        req.send(null);
    }
}

function setMessage()
{
    if(req.readyState == 4) 
    {
        var response = eval('(' + req.responseText+ ')');
        document.getElementById('time').innerHTML = response.time;
    }
}

ajaxclock.php

<?php echo '{"time": "'.date("H:i:s").'"}'; ?>
4

2 に答える 2

6

驚いたことに、それはサーバー上で動作します。

PHP はサーバー側のテクノロジーです。これは、サーバー (具体的には、PHP プログラムを実行するように構成されたサーバー) でのみ機能します。

このようなサーバーなしで使用すると、PHP は何も実行されず、生の状態でブラウザーに配信されます。

于 2012-04-17T06:10:41.603 に答える