ホームページ ウェブフロントエンド jsチュートリアル フロントエンド プログラマーが知っておくべき jQuery のヒント

フロントエンド プログラマーが知っておくべき jQuery のヒント

Dec 03, 2016 am 11:45 AM
jquery

フロントエンド プログラマーが知っておくべき jQuery のヒント

jQuery の animate メソッドとscrollTop メソッドを使用すると、プラグインを使わずに上部にスクロールする簡単なアニメーションを作成できます:

// Back to top
$('.top').click(function (e) {
  e.preventDefault();
  $('html, body').animate({scrollTop: 0}, 800);
});
ログイン後にコピー
<!-- Create an anchor tag -->
<a class="top" href="#">Back to top</a>
ログイン後にコピー

scrollTop の値を変更すると、スクロール バーを配置する場所を変更できます。実際に行う必要があるのは、ドキュメントの先頭までスクロールするまで、ドキュメントの本文を 800 ミリ秒間アニメーション化することだけです。

注:scrollTop のいくつかの誤った動作に注意してください。

画像をプリロードする

Web ページで、最初は表示されない (ホバー時など) 多くの画像を使用する場合は、これらの画像をプリロードできます:

$.preloadImages = function () {
  for (var i = 0; i < arguments.length; i++) {
    $(&#39;<img  alt="フロントエンド プログラマーが知っておくべき jQuery のヒント" >&#39;).attr(&#39;src&#39;, arguments[i]);
  }
};
$.preloadImages(&#39;img/hover-on.png&#39;, &#39;img/hover-off.png&#39;);
ログイン後にコピー

画像が読み込まれているかどうかを確認します

スクリプトを続行すると、すべての画像がロードされているかどうかを確認する必要がある場合があります:

$(&#39;img&#39;).load(function () {
  console.log(&#39;image load successful&#39;);
});
ログイン後にコピー

フロントエンド プログラマーが知っておくべき jQuery のヒント タグを ID またはクラスに置き換えることによって、特定の画像がロードされているかどうかを確認することもできます。

壊れた画像を自動的に修正します

すでに壊れた画像リンクを1つずつ置き換えるのは非常に面倒です。ただし、次の簡単なコードが役立ちます:

$(&#39;img&#39;).on(&#39;error&#39;, function () {
  if(!$(this).hasClass(&#39;broken-image&#39;)) {
    $(this).prop(&#39;src&#39;, &#39;img/broken.png&#39;).addClass(&#39;broken-image&#39;);
  }
});
ログイン後にコピー

リンク切れがない場合でも、このコードを追加しても費用はかかりません。

Hover Toggle クラス

ユーザーがクリック可能な要素の上にマウスを置いたときに、その要素の色を変更したいとします。その後、ユーザーが要素にマウスを置いたときにクラスを要素に追加し、それ以外の場合は要素を削除できます。

$(&#39;.btn&#39;).hover(function () {
  $(this).addClass(&#39;hover&#39;);
}, function () {
  $(this).removeClass(&#39;hover&#39;);
});
ログイン後にコピー

必要な CSS を追加するだけです。より簡単な方法は、toggleClass メソッドを使用することです:

$(&#39;.btn&#39;).hover(function () {
  $(this).toggleClass(&#39;hover&#39;);
});
ログイン後にコピー

注: この場合、おそらく CSS ソリューションの方が高速ですが、このメソッドを理解する必要があります。

入力フィールドを無効にする

ユーザーが特定のアクションを実行するまで (たとえば、「規約を読みました」チェックボックスをオンにするなど)、フォームの送信ボタンまたはテキスト入力の 1 つを無効にしたい場合があります。必要に応じて、無効な属性を入力に追加して有効にします:

$(&#39;input[type="submit"]&#39;).prop(&#39;disabled&#39;, true);
ログイン後にコピー

次に、input prop メソッドを実行するだけですが、disabled の値を false に設定します:

$(&#39;input[type="submit"]&#39;).prop(&#39;disabled&#39;, false);
ログイン後にコピー

リンクの読み込みを停止します

特定の Web ページにリンクしたり、ページをリロードしたくない場合は、リンクに他のスクリプトをトリガーするなど、他のことを実行させたい場合があります。これには、デフォルトのアクションをブロックするという大騒ぎが必要です:

$(&#39;a.no-link&#39;).click(function (e) {
  e.preventDefault();
});
ログイン後にコピー

フェードイン/スライド切り替え

スライドとフェードはどちらも、jQuery を使用してアニメーション化するときによく使用するものです。ユーザーが要素をクリックした後にその要素を表示したいだけの場合は、fadeIn メソッドと slideDown メソッドを使用するのが最適です。ただし、要素を最初のクリックで表示し、2 回目のクリックで非表示にしたい場合は、次のコードを試すことができます:

// Fade
$(&#39;.btn&#39;).click(function () {
  $(&#39;.element&#39;).fadeToggle(&#39;slow&#39;);
});
// Toggle
$(&#39;.btn&#39;).click(function () {
  $(&#39;.element&#39;).slideToggle(&#39;slow&#39;);
});
ログイン後にコピー

简单的手风琴

这是一个可快速生成手风琴的简单方法:

// Close all panels
$(&#39;#accordion&#39;).find(&#39;.content&#39;).hide();
// Accordion
$(&#39;#accordion&#39;).find(&#39;.accordion-header&#39;).click(function () {
  var next = $(this).next();
  next.slideToggle(&#39;fast&#39;);
  $(&#39;.content&#39;).not(next).slideUp(&#39;fast&#39;);
  return false;
});
ログイン後にコピー

通过添加这个脚本,你真正需要做的仅仅是在页面上添加必要的HTML元素,这样它就可以运行工作了。

让两个div高度相同

有时候,你需要让两个div无论包含什么内容都拥有相同的高度:

$(&#39;.div&#39;).css(&#39;min-height&#39;, $(&#39;.main-div&#39;).height());
ログイン後にコピー

设置 min-height,这意味着它可以比主div大但绝对不能比主div小。不过,还有一种更灵活的方法是遍历一组元素,然后将高度设置为最高的那个元素的高度:

var $columns = $(&#39;.column&#39;);
var height = 0;
$columns.each(function () {
  if ($(this).height() > height) {
    height = $(this).height();
  }
});
$columns.height(height);
ログイン後にコピー

如果你希望所有列的高度相同:

var $rows = $(&#39;.same-height-columns&#39;);
$rows.each(function () {
  $(this).find(&#39;.column&#39;).height($(this).height());
});
ログイン後にコピー

在新标签页/窗口打开外部链接

在一个新的浏览器tab或窗口中打开外部链接,并确保同一个来源的链接能在同一个tab或者窗口中打开:

$(&#39;a[href^="http"]&#39;).attr(&#39;target&#39;, &#39;_blank&#39;);
$(&#39;a[href^="//"]&#39;).attr(&#39;target&#39;, &#39;_blank&#39;);
$(&#39;a[href^="&#39; + window.location.origin + &#39;"]&#39;).attr(&#39;target&#39;, &#39;_self&#39;);
ログイン後にコピー

注意:window.location.origin 在IE10中无效。修复的时候要小心这个问题。

在改变Visibility时触发

当用户不再关注某个tab,或重新聚焦原来的那个tab上时,触发JavaScript:

$(document).on(&#39;visibilitychange&#39;, function (e) {
  if (e.target.visibilityState === "visible") {
    console.log(&#39;Tab is now in view!&#39;);
  } else if (e.target.visibilityState === "hidden") {
    console.log(&#39;Tab is now hidden!&#39;);
  }
});
ログイン後にコピー

AJAX调用错误处理

当Ajax调用返回404或500错误时,就执行错误处理程序。如果没有定义处理程序,其他的jQuery代码或会就此罢工。定义一个全局的Ajax错误处理程序:

$(document).ajaxError(function (e, xhr, settings, error) {
  console.log(error);
});
ログイン後にコピー

链式插件调用

jQuery允许“链式”插件的方法调用,以减轻反复查询DOM并创建多个jQuery对象的过程。比方说,下面的代码片段代表了你的插件方法调用:

$(&#39;#elem&#39;).show();
$(&#39;#elem&#39;).html(&#39;bla&#39;);
$(&#39;#elem&#39;).otherStuff();
ログイン後にコピー

通过使用链式,可以大大改善:

$(&#39;#elem&#39;)
  .show()
  .html(&#39;bla&#39;)
  .otherStuff();
ログイン後にコピー

还有一种方法是在(前缀$)变量中高速缓存元素:

var $elem = $(&#39;#elem&#39;);
$elem.hide();
$elem.html(&#39;bla&#39;);
$elem.otherStuff();
ログイン後にコピー

链式和高速缓存的方法都是jQuery中可以让代码变得更短和更快的代最佳做法。

英文原文:jQuery Tips Everyone Should Know

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

jQueryのリファレンスメソッドを詳しく解説:クイックスタートガイド jQueryのリファレンスメソッドを詳しく解説:クイックスタートガイド Feb 27, 2024 pm 06:45 PM

jQuery 参照方法の詳細説明: クイック スタート ガイド jQuery は、Web サイト開発で広く使用されている人気のある JavaScript ライブラリであり、JavaScript プログラミングを簡素化し、開発者に豊富な機能を提供します。この記事では、jQuery の参照方法を詳しく紹介し、読者がすぐに使い始めるのに役立つ具体的なコード例を示します。 jQuery の導入 まず、HTML ファイルに jQuery ライブラリを導入する必要があります。 CDN リンクを通じて導入することも、ダウンロードすることもできます

jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? Feb 28, 2024 pm 03:12 PM

jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? jQuery で PUT リクエストを送信する方法は、他のタイプのリクエストを送信する方法と似ていますが、いくつかの詳細とパラメータ設定に注意する必要があります。 PUT リクエストは通常​​、データベース内のデータの更新やサーバー上のファイルの更新など、リソースを更新するために使用されます。以下は、jQuery の PUT リクエスト メソッドを使用した具体的なコード例です。まず、jQuery ライブラリ ファイルが含まれていることを確認してから、$.ajax({u

徹底した分析: jQuery の長所と短所 徹底した分析: jQuery の長所と短所 Feb 27, 2024 pm 05:18 PM

jQuery は、フロントエンド開発で広く使用されている高速、小型、機能豊富な JavaScript ライブラリです。 2006 年のリリース以来、jQuery は多くの開発者にとって最適なツールの 1 つとなっていますが、実際のアプリケーションでは、いくつかの利点と欠点もあります。この記事では、jQuery の長所と短所を詳しく分析し、具体的なコード例で説明します。利点: 1. 簡潔な構文 jQuery の構文設計は簡潔かつ明確であるため、コードの読みやすさと記述効率が大幅に向上します。例えば、

jQueryで要素の高さ属性を削除するにはどうすればよいですか? jQueryで要素の高さ属性を削除するにはどうすればよいですか? Feb 28, 2024 am 08:39 AM

jQueryで要素の高さ属性を削除するにはどうすればよいですか?フロントエンド開発では、要素の高さ属性を操作する必要が生じることがよくあります。要素の高さを動的に変更する必要がある場合や、要素の高さ属性を削除する必要がある場合があります。この記事では、jQuery を使用して要素の高さ属性を削除する方法と、具体的なコード例を紹介します。 jQuery を使用して高さ属性を操作する前に、まず CSS の高さ属性を理解する必要があります。 height 属性は要素の高さを設定するために使用されます

jQuery のヒント: ページ上のすべての a タグのテキストをすばやく変更する jQuery のヒント: ページ上のすべての a タグのテキストをすばやく変更する Feb 28, 2024 pm 09:06 PM

タイトル: jQuery ヒント: ページ上のすべての a タグのテキストをすばやく変更する Web 開発では、ページ上の要素を変更したり操作したりする必要がよくあります。 jQuery を使用する場合、ページ内のすべての a タグのテキスト コンテンツを一度に変更する必要がある場合があります。これにより、時間と労力を節約できます。以下では、jQuery を使用してページ上のすべての a タグのテキストをすばやく変更する方法と、具体的なコード例を紹介します。まず、jQuery ライブラリ ファイルを導入し、次のコードがページに導入されていることを確認する必要があります: &lt

jQuery を使用してすべての a タグのテキスト コンテンツを変更する jQuery を使用してすべての a タグのテキスト コンテンツを変更する Feb 28, 2024 pm 05:42 PM

タイトル: jQuery を使用して、すべての a タグのテキスト コンテンツを変更します。 jQuery は、DOM 操作を処理するために広く使用されている人気のある JavaScript ライブラリです。 Web 開発では、ページ上のリンク タグ (タグ) のテキスト コンテンツを変更する必要が生じることがよくあります。この記事では、この目標を達成するために jQuery を使用する方法を説明し、具体的なコード例を示します。まず、jQuery ライブラリをページに導入する必要があります。 HTML ファイルに次のコードを追加します。

jQuery 要素に特定の属性があるかどうかを確認するにはどうすればよいですか? jQuery 要素に特定の属性があるかどうかを確認するにはどうすればよいですか? Feb 29, 2024 am 09:03 AM

jQuery 要素に特定の属性があるかどうかを確認するにはどうすればよいですか? jQuery を使用して DOM 要素を操作する場合、要素に特定の属性があるかどうかを判断する必要がある状況がよく発生します。この場合、jQuery が提供するメソッドを使用してこの関数を簡単に実装できます。以下では、jQuery 要素が特定の属性を持つかどうかを判断するために一般的に使用される 2 つの方法を紹介し、具体的なコード例を添付します。方法 1: attr() メソッドと typeof 演算子 // を使用して、要素に特定の属性があるかどうかを判断します

jQuery における eq の役割と応用シナリオを理解する jQuery における eq の役割と応用シナリオを理解する Feb 28, 2024 pm 01:15 PM

jQuery は、Web ページでの DOM 操作やイベント処理を処理するために広く使用されている人気のある JavaScript ライブラリです。 jQueryではeq()メソッドを利用して指定したインデックス位置の要素を選択しますが、具体的な使い方と応用シーンは以下の通りです。 jQuery では、 eq() メソッドは、指定されたインデックス位置にある要素を選択します。インデックス位置は 0 からカウントされます。つまり、最初の要素のインデックスは 0、2 番目の要素のインデックスは 1 などとなります。 eq() メソッドの構文は次のとおりです。 $("s

See all articles