テーブルのセルをクリックしても、セル内のチェックボックスにチェックをつける方法

ネット上でアンケートをやっていると、<td>タグ内にチェックボックスがあることがあります。中には、そのセルの中のどこをクリックしてもチェックしてくれるものもあるのですが、チェックボックスをちゃんとクリックしなければチェックしないというのがほとんどです。

では、今回はセル内のどこをクリックしてもチェックボックスにチェックを入れる方法をお伝えします。親ノードが<div>タグとかだと、<label>で囲めばいいのですが、<td>タグだとその方法はできません。
 まず考えられるのが、以下のようなソースです。

<table>
    <tr>
        <td onclick="getElementById('checkbox1').click();">
            <input type="checkbox" id="checkbox1">
        </td>
    </tr>
</table>

分かりやすいように実際の表示では、幅高さともに100pxにし、上下中心位置に配置し、黒い単線をつけています。

では早速クリックしてみましょう。クリッククリック! おっ!できてるできてる。と思ってもらえたらうれしいです。
 ただ、これだと肝心のチェックボックスをクリックするとチェックがつかないときがあります。理由は単純、2度クリックするのと同じことをやっているからです(今確認してみると、OperaとIEではちゃんとチェックがつきました)。では、続いてこれの対処法を書いていきます。

<table>
    <tr>
        <td onclick="getElementById('checkbox2').click();">
            <input type="checkbox" id="checkbox2" onclick="this.click()">
        </td>
    </tr>
</table>

そう、2度で戻ってしまうなら、3度クリックしたことにすればいいのです! この方法でも、IEやOperaでちゃんとチェックがつくようですし。

なんだか遠回しなような気もしますが、これ以外いい方法が思いつきません。もっといい方法があれば誰か教えてください。

コメント

  1. 匿名 より:

    ありがとう

  2. 匿名 より:

    助かりました

タイトルとURLをコピーしました