とほほのjQuery入門

目次

Attributes(Attribute/Property)

obj.attr(attributeName) (1.0)
      obj.attr(attributeName, value) (1.0)
      obj.attr(attributes) (1.0)
      obj.attr(attributeName, function(index, attr)) (1.1)

.attr(attributeName) の形式は obj の属性値を参照します。

JavaScript
alert($("img#img1").attr("src"));

.attr(attributeName, value) の形式は obj の属性値を設定します。

JavaScript
$("img#img1").attr("src", "image/xxx.gif");

.attr(attributes) の形式は下記の記法で obj の属性値を設定します。

JavaScript
$("img#img1").attr({
    src: "image/xxx.gif",
    width: "100",
    height: "100"
});

.attr(attributeName, function(index, attr)) の形式は関数の戻り値を attributeName属性に設定します。

JavaScript
$("img#img1").attr("height", function(i, val) {
    return val * 2;
});

obj.removeAttr(attributeName) (1.0)

obj から attributeName で指定した属性を削除します。jQuery 1.7 からは空白で区切った複数の属性を指定できます。

JavaScript
$("#img1").removeAttr("height width");

obj.prop(propertyName) (1.6)
      obj.prop(propertyName, value) (1.6)
      obj.prop(properties) (1.6)
      obj.prop(propertyName, function(index, oldValue)) (1.6)

attr() と似ていますが、attr() がHTMLの属性値を扱うのに対して、prop() は JavaScriptのプロパティを扱います。通常、両者は同じ値となりますが、稀に異なるものがあります。例えば、a要素の href属性は、属性値とプロパティで値が異なることがあります。

JavaScript
val = $("#a1").attr("href");    // #prop
val = $("#a1").prop("href");    // http://www.example.com/jquery.html#prop
JavaScript
<a id="a1" href="#prop">prop()</a>

また、チェックボックスなどの checked属性も属性値とプロパティで値が異なります。

JavaScript
val = $("#c1").attr("checked");    // "checked"
val = $("#c1").prop("checked");    // true
JavaScript
<input type="checkbox" id="c1" checked>

obj.removeProp(propertyName) (1.6)

obj から attributeName で指定したプロパティを削除します。

JavaScript
$("#d1").prop("lang", "japan");
$("#d1").removeProp("lang");

Attributes(HTML/Text/Value)

obj.html() (1.0)
      obj.html(htmlString) (1.0)
      obj.html(function(index, oldhtml)) (1.4)

html() の形式は、obj の内側のHTML文字列を参照します。

JavaScript
val = $("p#p1").html();             // <p id="p1"><b>BBB</b></p> → <b>BBB</b>

html(htmlString) の形式は、obj の内側のHTML文字列を htmlString に置換します。

JavaScript
$("p#p1").html("<p>BBB</p>");      // <p id="p1"><p>BBB</p></p>

html(function(index, oldhtml)) の形式は、obj の内側のHTML文字列を function の戻り値に置換します。

JavaScript
$("p#p1").html(function(i, val) {
    return "[" + val + "]";        // <p id="p1">BBB</p> → <p id="p1">[BBB]</p>
});

obj.text() (1.0)
      obj.text(text) (1.0)
      obj.text(function(index, text)) (1.4)

text() の形式は、obj の内側のテキストを参照します。

JavaScript
val = $("p#p1").text();             // <p id="p1"><b>BBB</b></p> → BBB

html(htmlString) の形式は、obj の内側のテキストを htmlString に置換します。

JavaScript
$("p#p1").text("<p>BBB</p>");       // <p id="p1">&lt;p&gt;BBB&lt;/p&gt;</p>

text(function(index, oldhtml)) の形式は、obj の内側のテキストを function の戻り値に置換します。

JavaScript
$("p#p1").text(function(i, val) {
    return "[" + val + "]";        // <p id="p1">BBB</p> → <p id="p1">[BBB]</p>
});

obj.val() (1.0)
      obj.val(value) (1.0)
      obj.val(function(index, value)) (1.4)

val() の形式はフォーム要素(input, textarea, select等)の値を参照します。

JavaScript
val = $("input#userName").val();

val(value) の形式はフォーム要素の値を設定します。

JavaScript
$("input#userName").val("Tanaka");

val(function(index, value)) の形式はフォーム要素の値に関数の戻り値を設定します。

JavaScript
$("input#userName").val(function(i, val) {
    return val.toUpperCase();
});

radioボタンの値を参照するには :checked を用います。値を設定するには値を配列にします。

JavaScript
val = $("input[name='color1']:checked").val();
$("input[name='color1']").val(["Black"]);

checkboxの値を参照するには :checked と map() を用い、取得した jQuery配列を get() で JavaScript配列に変換します。値を設定するには値を配列にします。

JavaScript
val = $("input[name='color2']:checked").map(function() {
    return $(this).val();
}).get();                          // [ "Black", "White" ]
$("input[name='color2']").val(["Black", "White"]);

単一選択selectの値を参照したり設定するには、通常のval()を用います。

JavaScript
val = $("#select1").val();
$("#select1").val("Black");

複数選択selectの値を参照するには通常の val()、値を設定するには値を配列にします。

JavaScript
val = $("#select2").val();              // [ "Black", "White" ]
$("#select2").val(["Black", "White"]);

Attributes(Class)

obj.addClass(className) (1.0)
      obj.addClass(function(index, currentClass)) (1.4)

addClass(className) の形式は、obj の class に className を加えます。

JavaScript
$("#d1").addClass("border");

addClass(function(index, currentClass)) の形式は、obj の class に function の戻り値をクラス名として加えます。i はインデックス番号、currentClass は現在設定されているクラス名を示します。

JavaScript
$("#d1").addClass(function(i, class) {
    return "border";
});

obj.removeClass(className) (1.0)
      obj.removeClass(function(index, currentClass)) (1.4)

obj から classNamefunction の戻り値で指定したクラスを削除します。

JavaScript
$("#d1").removeClass("border");

obj.hasClass(className) (1.2)

obj の中に className クラスを持つ要素がひとつでもあれば true を、さもなくば false を返します。

JavaScript
val = $("div").hasClass("red");    // true or false

obj.toggleClass(className) (1.0)
      obj.toggleClass(className, state) (1.3)
      obj.toggleClass(function(index, class, state)[, state]) (1.4)

obj に対して className で指定したクラスが存在する場合は削除し、存在しない場合は追加します。

JavaScript
$("#d1").toggleClass("border");

state に true を指定すると有無に関わらず追加し、false を指定すると有無に関わらず削除します。

JavaScript
$("#d1").toggleClass("border", true);

toggleClass([switch]) の形式は、obj に最初に設定されていたすべてのクラスを対象とします。switch が true の場合は追加し、false の場合は削除し、省略した場合は有無を切り替えます。

JavaScript
$("#d1").toggleClass();

toggleClass(function(...)) の形式は、className の代わりに関数の戻り値をクラス名とします。

JavaScript
$("#d1").toggleClass(function(i, class, switch) { return "border"; });