2014年05月04日
川俣晶の縁側ソフトウェア技術雑記total 3942 count

jQueryMobileのチェックボックスをスクリプトから作成する方法

Written By: 川俣 晶連絡先

「検索してもjQueryMobileのサイト見ても良く分からなかったので、試行錯誤的に見つけた。ただのメモだ」

「TypeScript用?」

「jQueryMobileの問題名のでJavaScriptでも同じでいいはずだ」

HTMLパート §

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="utf-8" />

    <title>TypeScript HTML App</title>

    <link rel="stylesheet" href="app.css" type="text/css" />

    <script src="Scripts/jquery-2.1.0.js"></script>

    <script src="Scripts/jquery.mobile-1.4.2.js"></script>

    <script src="app.js"></script>

</head>

<body>

    <div id="content"></div>

</body>

</html>

TypeScriptパート §

$(document).on("pageinit", function (event) {

    // チェックボックス作る

    var input = document.createElement("input");

    $(input).attr("type", 'checkbox');

    $(input).attr("name", "Sample");

    $(input).attr("value", "on");

    $("#content").append(input);

    $("input:checkbox").checkboxradio();    // これ重要。無いと落ちる

    // チェックボックスにチェックを入れる

    $("input:checkbox").prop('checked', "true");

    $("input:checkbox").checkboxradio("refresh");

});

解説 §

「で、どこがポイント?」

「$("input:checkbox").checkboxradio();のところ。これが無いと例外が出て落ちる」

「なんでこれが必要なの?」

「HTMLのチェックボックスはjQueryMobileのcheckboxradio widgetで置き換えられるが、スクリプトからDOMに挿入した場合置換はそのままでは行われない。ところが、checkboxradio("refresh");の処理はcheckboxradio widgetを前提としているので、初期化する前に使うんじゃねーよ、コラ!と怒られてしまう」

「じゃあさ。checkboxradio("refresh");使わなければ面倒なおまじないは要らないの?」

「それだとHTMLに直接書いたチェックボックスと外見が微妙に違ってしまう。あっちは自動的にjQueryMobileが置き換える」

「結局必要なんだね」

Facebook

キーワード【 川俣晶の縁側ソフトウェア技術雑記
【技術雑記】の次のコンテンツ
2014年
05月
13日
ASP.NET Web APIで認証情報がセットされない問題と解決
3days 0 count
total 4783 count
【技術雑記】の前のコンテンツ
2014年
05月
03日
AzureのTableで前方一致検索を行う方法
3days 0 count
total 4130 count
2014年05月04日
川俣晶の縁側ソフトウェア技術雑記total 3942 count

jQueryMobileのチェックボックスをスクリプトから作成する方法

Written By: 川俣 晶連絡先

「検索してもjQueryMobileのサイト見ても良く分からなかったので、試行錯誤的に見つけた。ただのメモだ」

「TypeScript用?」

「jQueryMobileの問題名のでJavaScriptでも同じでいいはずだ」

HTMLパート §

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="utf-8" />

    <title>TypeScript HTML App</title>

    <link rel="stylesheet" href="app.css" type="text/css" />

    <script src="Scripts/jquery-2.1.0.js"></script>

    <script src="Scripts/jquery.mobile-1.4.2.js"></script>

    <script src="app.js"></script>

</head>

<body>

    <div id="content"></div>

</body>

</html>

TypeScriptパート §

$(document).on("pageinit", function (event) {

    // チェックボックス作る

    var input = document.createElement("input");

    $(input).attr("type", 'checkbox');

    $(input).attr("name", "Sample");

    $(input).attr("value", "on");

    $("#content").append(input);

    $("input:checkbox").checkboxradio();    // これ重要。無いと落ちる

    // チェックボックスにチェックを入れる

    $("input:checkbox").prop('checked', "true");

    $("input:checkbox").checkboxradio("refresh");

});

解説 §

「で、どこがポイント?」

「$("input:checkbox").checkboxradio();のところ。これが無いと例外が出て落ちる」

「なんでこれが必要なの?」

「HTMLのチェックボックスはjQueryMobileのcheckboxradio widgetで置き換えられるが、スクリプトからDOMに挿入した場合置換はそのままでは行われない。ところが、checkboxradio("refresh");の処理はcheckboxradio widgetを前提としているので、初期化する前に使うんじゃねーよ、コラ!と怒られてしまう」

「じゃあさ。checkboxradio("refresh");使わなければ面倒なおまじないは要らないの?」

「それだとHTMLに直接書いたチェックボックスと外見が微妙に違ってしまう。あっちは自動的にjQueryMobileが置き換える」

「結局必要なんだね」

Facebook

キーワード【 川俣晶の縁側ソフトウェア技術雑記
【技術雑記】の次のコンテンツ
2014年
05月
13日
ASP.NET Web APIで認証情報がセットされない問題と解決
3days 0 count
total 4783 count
【技術雑記】の前のコンテンツ
2014年
05月
03日
AzureのTableで前方一致検索を行う方法
3days 0 count
total 4130 count
【技術雑記】のコンテンツ全リスト【技術雑記】の表紙

このコンテンツを書いた川俣 晶へメッセージを送る

[メッセージ送信フォームを利用する]

メッセージ送信フォームを利用することで、川俣 晶に対してメッセージを送ることができます。

この機能は、100%確実に川俣 晶へメッセージを伝達するものではなく、また、確実に川俣 晶よりの返事を得られるものではないことにご注意ください。

このコンテンツへトラックバックするためのURL

http://mag.autumn.org/tb.aspx/20140504102413
サイトの表紙【技術雑記】の表紙【技術雑記】のコンテンツ全リスト 【技術雑記】の入手全リスト 【技術雑記】のRSS1.0形式の情報このサイトの全キーワードリスト 印刷用ページ

管理者: 川俣 晶連絡先

Powered by MagSite2 Version 0.25 (Alpha-Test) Copyright (c) 2004-2017 Pie Dey.Co.,Ltd.