3

OK、私はサイドバー ガジェットの専門家ではありませんが、学校用に作成するプロジェクトがあります。自分で解決しようとしましたが、本当に行き詰まりました。

Cirip API (Cirip.ro は一種の Twitter) を使用する必要があり、API を使用するにはユーザー名を入力する必要があります。設定を使用してこれを行いますが、設定を閉じても効果はありません。

これがコードですが、かなり面倒です。私は Web プログラマーではないので、javascript/html は初めてです。

http://www.box.net/shared/7yogevhzrr


編集:わかりましたので、ここでコードを少し絞り込んで最適化しましたが、まだ機能していません。できるだけシンプルにしました。

メインのhtmlにはこれがあります:

<script language="javascript">
    document.write(getUserName());
</script>

gadget.js で:

var userName;

document.onreadystatechange = function DoInit() {

    document.body.style.width = 251;
    document.body.style.height= 351;
    document.body.style.margin=2;
    userName="danieliuhasz";
    System.Gadget.settingsUI = "settings.html";
    System.Gadget.onSettingsClosing = settingsClosed;

}

function setUserName(userNameSet){

    userName = userNameSet;
}

function getUserName(){

    return userName;
}

function settingsClosed()
{

    var username = System.Gadget.Settings.read("username");
    setUserName(username);
}

settings.html で:

<body>

Username:<br />
<input name="userBox" type="text" maxlength="50" />
</body>

settings.js で:

document.onreadystatechange = function DoInit()
{    

    if(document.readyState=="complete")
    {
        var user = System.Gadget.Settings.read("userName");

        if(user != "")
        {
            userBox.value = user;
        }       
    }        
}


System.Gadget.onSettingsClosing = function(event)
{

    if (event.closeAction == event.Action.commit)
    {
        var username = userBox.value;
        if(username != "")
        {
              System.Gadget.Settings.write("username", username);
              System.Gadget.document.parentWindow.settingsClosed();

        }
    }
}

私は本当にそれを理解することはできません。この出力は「未定義」です。

4

1 に答える 1

2

このマシンには RAR アンパッカーがないため、ファイルを見ることはできませんが、設定の保存について少しアドバイスできます。さらにヘルプが必要な場合は、コードを質問に貼り付けてみてください (上記の私のコメントを参照してください)。

System.Gadget.onSettingsClosing設定を操作するときは、JavaScript コードでイベントをキャッチする必要があります。System.Gadget.Settings.writeこのイベント ハンドラでは、ガジェット ウィンドウでプロパティを設定して設定を一時的にすることも、 を使用して設定を保存することで半永久的に設定することもできます。ユーザー名/パスワードの html が次のようになっているとします。

<label for="username">Username: </label><input id="username" type="text"><br/>
<label for="password">Password: </label><input id="password" type="password">

JavaScript は次のようになります。

System.Gadget.onSettingsClosing = function (event) {
    // First, we need to make sure the user clicked the OK button to save
    if (event.closeAction == event.Action.commit) {
        // If they did, we need to store the settings
        var username = document.getElementById("username").value,
            password = document.getElementById("password").value;

        System.Gadget.Settings.write("username", username);
        System.Gadget.Settings.write("password", password);

        /* Finally, we can call a function defined in the main gadget window's
           JavaScript to let it know that the settings have changed */
        System.Gadget.document.parentWindow.settingsHaveChanged();
    }
}

メイン ガジェットの JavaScript ではsettingsHaveChanged、次の関数のようになります。

function settingsHaveChanged () {
    var username = System.Gadget.Settings.read("username"),
        password = System.Gadget.Settings.read("password");

    sendAPIRequest(username, password);
}
于 2011-01-07T11:22:48.277 に答える