F.Ko-Jiの「一秒後は未来」ではウェブやSEO、API、RSSといった技術的ネタから、ちょっとした豆知識や梅酒、エンタメ系まで様々な情報を不定期にお届けしています。

F.Ko-Jiの「一秒後は未来」 > Javascript > livedoor ReaderでのOPMLインポート後画面の“チェックボックス操作”を再現するJavaScriptサンプル

livedoor ReaderでのOPMLインポート後画面の“チェックボックス操作”を再現するJavaScriptサンプル

  • B!
スポンサード リンク

昨日書いた「チェックボックスをマウスでなめるようにドラッグするだけで切り替えるJavaScriptのサンプル」に対して「livedoor Readerのとは少し違う」というツッコミがありましたので、再度サンプルを作り直してみました。

修正点は以下の通り。

  • チェックボックスを囲むリストエレメントでも操作は有効
  • リストエレメントもしくはチェックボックス上でmousedownしたらチェック状態を切り替える
  • マウスをドラッグすると、他のチェックボックスは最初に切り替わったチェックボックスの状態へのみ切り替わる

(JavaScriptが無効なRSSリーダーから見ている場合はページを訪問してください。)

ソースコード

/* サンプルのli要素には class="sample_li" をつけてます。 */
/* require prototype.js */
if (typeof SAMPLE == "undefined") {
    var SAMPLE = {};
}
SAMPLE.isMousedown = false;
SAMPLE.isChecked = false;
SAMPLE.clickedElement = undefined;
SAMPLE.mousedown = function(e) {
    e = e || window.event;
    var target = e.target || e.srcElement;
    SAMPLE.clickedElement = target;
    if (target.type == "checkbox") {
        target.click();
        SAMPLE.isMousedown = true;
        SAMPLE.isChecked = target.checked;
    }
    else if (target.className == "sample_li") {
        target = target.firstChild;
        if (target.type == "checkbox") {
            target.click();
            SAMPLE.isMousedown = true;
            SAMPLE.isChecked = target.checked;
        }
    }
}
SAMPLE.mouseup = function(e) {
    e = e || window.event;
    var target = e.target || e.srcElement;
    if (target == SAMPLE.clickedElement && target.type == "checkbox") {
        target.click();
    }
    SAMPLE.isMousedown = false;
}
SAMPLE.mouseover = function(e) {
    e = e || window.event;
    var target = e.target || e.srcElement;
    if (target.className == "sample_li") {
        target = target.firstChild;
    }
    if (SAMPLE.isMousedown && target.type == "checkbox") {
        if (SAMPLE.isChecked && !target.checked || !SAMPLE.isChecked && target.checked) {
            target.click();
        }
    }
}
Event.observe(document, "mousedown", SAMPLE.mousedown);
Event.observe(document, "mouseup", SAMPLE.mouseup);
Event.observe(document, "mouseover", SAMPLE.mouseover);

確かにこのインタフェースなら使いやすいですね。

[2010-01-12] RSS フィードの URL が変わりました。お手数ですが RSS リーダーへの再登録をお願いします。
Subscribe with livedoor Reader Add to Google Subscribe with Fastladder My Yahoo!に追加 Bloglinesで閲読登録 はてなRSSに追加 エキサイトリーダーに登録


コメントを投稿

(承認されるまでコメントは表示されません。)

Javascript / ユーザビリティ

English version

前のエントリー: « ブログにトラフィックを集めるための29の方法
次のエントリー: 日本や海外のRSS関連情報をお届けするFeedmedia »

トラックバック

このエントリーのトラックバックURL:

タイトル:

URL:

リンク用HTMLタグ:

Agile Media Network

AMN Partner Blog

広告掲載について

東京ナイロンガールズ
最近の注目記事
持っているガジェット
powered by Gadget Party
最近のつぶやき
えもにゅ

↑ 気持ち記録サービス「えもにゅ」です

このブログの読者になる

F.Ko-Jiの「一秒後は未来」 - RSSフィード

クマでもわかるこのブログの便利な更新チェック方法

DailyFeed

あわせて読みたいブログパーツ

フィードメーター - F.Ko-Jiの「一秒後は未来」

月別アーカイブ


<< March 2010
SuMoTuWeThFrSa
 123456
78910111213
14151617181920
21222324252627
28293031 
人気エントリー
TopHatenar
携帯からのアクセスは
QRコード
http://mob.fkoji.com/