jQueryでDOMを操作する方法

一个新手
リリース: 2017-09-27 09:53:20
オリジナル
3011 人が閲覧しました

1. jQueryの操作スタイル

2. jQueryのアニメーションの簡単な操作

4. jQueryの操作スタイル

1. css 操作 :

機能: スタイルの設定または変更、スタイル属性の操作

a、css (名前/属性名、値/属性値) を設定します。b. 複数のスタイルを設定します。パラメータはオブジェクト css (obj);

$('#box').css(‘background’,'#000')
ログイン後にコピー
Get style:.css(name)

特徴、jQ の CSS メソッドはすべてインライン スタイルです;

jq 暗黙的反復、コレクションの属性を取得するとき、JQ 0 番目の属性が自動的に出力されます。

操作を設定する際、複数の要素がある場合は、すべての要素に同じ値を設定します

$('#box').css({'background':'gray',
'width':'400px',
'height':'200px'
})
ログイン後にコピー

....

2. クラスの操作

関数: スタイルを扱うクラス

box.eq(0).css('width',190);
box.eq(1).css('width',110);
ログイン後にコピー

2. jq 操作の属性

1.attr 操作

a.添加addClass(name);参数类名不用带点,并且不会覆盖之前的作用;
$("box").addClass("one");
b.移除removeClass("name");
$("box").removeClass("one");
c.判断hasClass是否有具体的类,返回值为布尔值
$("box").hasClass("one");//false
d.切换样式类toggleClass,需要切换的样式类名,如果有,移除该样式,如果没有,添加该样式。
$("box").toggleClass("one");切换样式类
ログイン後にコピー
1. 属性を取得する際は、css メソッドと同様に、最初の要素に対応する属性のみが取得されます。 2. 属性を取得するとき、その属性が存在しない場合は、unknown が返されます。d. 属性を削除しますremoveAttr(name);

パラメータ: 空を渡すと、削除する必要がある属性の名前が返されます。操作は行われません。すべての属性が削除されるわけではないことに注意してください。 RemoveClass を区別します。

a.设置单个属性,attr(name,value);
$(“img”).attr(“title”,”哎哟,不错哦”);
b.设置多个属性(attr(obj));
$("img").attr({
title:"哎呦,不错哦“,
alt:"你很棒棒哟”,
style:"opacity:.5"
});
c.获取属性attr(name)
$(“img”).attr("title");
ログイン後にコピー
2. Propはブール属性を操作します

checked、selected、disabledなどのブール型の属性については、attrメソッドは使用できず、propメソッドのみが使用可能です。

属性を設定する

$("img").removeAttr("title");
ログイン後にコピー

選択した属性をすべての選択、パラメータに追加します(属性名、true/false)

属性を取得します

$(“:checked”).prop(“checked”,true);
ログイン後にコピー
3. jQueryの基本アニメーション

jqueryはこれらの3つのセットを提供します。アニメーション これらはすべて標準の通常の効果であり、jquery はカスタム アニメーションの機能も提供します。

1. 表示と非表示

show ([speed], [callback]) および hide(); パラメーターが渡されない場合は、 を直接表示および非表示にします。パラメータ: 速度: 時間 (ミリ秒値)、固定文字列 'fast') = 200 nomal = 400 throw=600;

callback: アニメーション終了後に実行されるコールバック関数

hide()同show()方法一致

show/hide修改的是元素的width、height、opacity。

2.滑入与滑出

slideUp()与slideDown()

*如果不传参数,默认为nomal!(与show和hide区分 )

参数:时间,固定字符串

callback:执行动画结束后执行的回调函数

滑入滑出切换slideToggle(speed,callback)

$(selector).slideToggle(speed,callback);
ログイン後にコピー

//如果是隐藏状态,那么执行slideDown操作,如果是显示状态,那么执行slideUp操作。

3.淡入与淡出

fadeIn()与fadeOut()

用法与show好fadeOut一致

淡入淡出切换:

fadeToggle(speed,callback);
ログイン後にコピー

//如果当前元素处于隐藏状态,那么执行fadeIn操作,如果处于显示状态,那么执行fadeOut操作。

fade系列方法:修改的是元素的opacity

4.基本动画小结

1. jQuery给我们提供了三组动画,show/hide、slideUp/slideDown、fadeIn/fadeOut

2. 动画切换方法:slideToggle、fadeToggle,toggle()。

3. show/slideDown/fadeIn三个是显示效果、hide/slideUp/fadeOut三个是隐藏效果。

4. show/hide修改的是元素的height,width,opacity。slide系列方法修改的是元素的height。fade系列方法修改的是元素的opacity。这三种方法修改的这些值,都是带数字的,因为带了数字才能做渐变。

5.自定义动画animate

animate:自定义动画

$(selector).animate({params},[speed],[callback]);
ログイン後にコピー

// {params}:要执行动画的CSS属性,带数字可以是对象(必写)

// speed:执行动画时长

时间和速度:毫秒数,字符串’swing‘两边慢,中间快/’linner‘匀速

// callback:动画执行完后立即执行的回调函数

例:

设置数值型的属性做动画

box.animate({

left:800;

width:800;

height:800 逐渐变大

transform:'rotate(360deg)'

},1000,'swing',function)

6.动画队列问题

在同一个元素上执行多个动画,那么对于这个动画来说,后面的动画会被放到动画队列中,等前面的动画执行完成了才会执行。

7.停止动画

stop()函数暂停当前执行动画

stop(clearQueue,jumpToEnd)
ログイン後にコピー

第一个参数:是否清楚队列,第二个参数:是否跳转最终效果,最后一帧

四、jQuery操作dom节点增删操作

1.创建元素

$(htmlStr)//html格式的字符串

$(“<span>这是一个span元素</span>”);
ログイン後にコピー

2.添加元素append/prepend

append方法:添加到当前的最后面。

参数:字符串(标签)或者jq对象

字符串:$(“p”).append(“这是一个span元素”);
JQ对象:var $span = $(“<span>这是一个span元素</span>”);
$(“p”).append($span);
ログイン後にコピー

prepend:追加到当前元素的最前面。

*如果添加的是已经存在的元素,那么会把之前的元素给干掉。(类似于剪切的功能)。

3.清空元素empty

empty:清空指定节点的所有元素,自身保留(清理门户)

1)$(“p”).empty();//清空p的所有内容(推荐使用,会清除子元素上绑定的内容,源码)
2)$(“p”).html(“”);//使用html方法来清空元素,不推荐使用,会造成内存泄漏,绑定的事件不会被清除。
ログイン後にコピー

4.删除元素remove

remove:相比于empty,自身也删除(自尽)

$(“p”).remove();
ログイン後にコピー

5.克隆元素clone

$(selector).clone();
ログイン後にコピー

复制$(selector)所匹配到的元素(深度复制)和原来的元素没有任何关系了。即修改新元素,不会影响到原来的元素。

以上がjQueryでDOMを操作する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート