ホームページ >ウェブフロントエンド >jsチュートリアル >jquery スキルに注意し、jquery スキルを向上させる (フロントエンド開発のために学習する必要があります)_jquery

jquery スキルに注意し、jquery スキルを向上させる (フロントエンド開発のために学習する必要があります)_jquery

WBOY
WBOYオリジナル
2016-05-16 15:34:001482ブラウズ

jQuery スキルの向上に役立つ簡単なヒントのコレクション。

Matt Smith によって始められた小さなプロジェクトで、現在 14 個のヒントがあります。 Bole Online は引き続きアップデートをフォローアップしていきます。

トップに戻るボタン
画像をプリロード
画像がロードされているかどうかを確認します
破損した写真を自動的に修復します
ホバーでクラススイッチ
入力フィールドを無効にする
リンクの読み込みを停止
フェード/スライドスイッチ
シンプルな折りたたみ効果
2 つの Div を同じ高さに設定します
外部リンクを新しいウィンドウで開きます
テキスト要素
を見つけます 表示トリガーと非表示トリガーを切り替えます

トップに戻るボタン

jQuery で animate メソッドとscrollTop メソッドを使用すると、プラグインを必要とせずに、単純なトップに戻るアニメーションを作成できます。

JavaScript

// Back to top
$('a.top').click(function (e) {
 e.preventDefault();
 $(document.body).animate({scrollTop: 0}, 800);
});

JavaScript

<!-- Create an anchor tag -->
<a class="top" href="#">Back to top</a>

scrollTop の値を、スクロールバーを停止させたい位置に変更します。次に、800 ミリ秒以内に先頭に戻るように設定します。

画像をプリロード

ページで、最初は表示されない画像が多数使用されている場合 (ホバーにバインドされているなど)、それらをプリロードすると便利です:

JavaScript

$.preloadImages = function () {
 for (var i = 0; i < arguments.length; i++) {
  $('<img>').attr('src', arguments[i]);
 }
};
$.preloadImages('img/hover-on.png', 'img/hover-off.png');

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

スクリプトで後続の操作を実行する前に、画像が完全にロードされているかどうかを確認する必要がある場合があります:

JavaScript

$('img').load(function () {
 console.log('image load successful');
});

img タグを ID またはクラスに置き換えることで、特定の画像がロードされているかどうかを確認することもできます。

破損した写真を自動的に修復します

Webサイト上の画像リンクが切れていることに気付いた場合、いちいち張り替えるのは面倒です。この単純なコードは非常に役立ちます:

JavaScript

$('img').on('error', function () {
 $(this).prop('src', 'img/broken.png');
});

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

ホバー時のクラス切り替え

ユーザーがページ上のクリック可能な要素の上にマウスを置いた場合、この要素の視覚的表現を変更したいとします。次のコードを使用すると、ユーザーが要素にホバーしたときにクラスを追加し、ユーザーがマウスを離れたときにクラスを削除できます。

JavaScript

$('.btn').hover(function () {
 $(this).addClass('hover');
}, function () {
 $(this).removeClass('hover');
});
必要な CSS を追加するだけです。もっと簡単な方法が必要な場合は、toggleClass メソッドを使用することもできます:


JavaScript

$('.btn').hover(function () {
 $(this).toggleClass('hover');
});


注: この例では CSS の方が高速な解決策である可能性がありますが、それでも知っておく価値はあります。

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


ユーザーが特定のアクション (「規約を読みました」チェックボックスを確認するなど) を実行するまで、フォームの送信ボタンやテキスト入力ボックスを使用できないようにしたい場合があります。必要な効果を実現するには、入力に無効な属性を追加します:


JavaScript

$('input[type="submit"]').prop('disabled', true);

disabled の値を false に変更したい場合は、入力に対して prop メソッドを再度実行するだけです。


JavaScript

$('input[type="submit"]').prop('disabled', false);

リンクの読み込みを停止


リンクでページにジャンプしたり、ページをリロードしたりしたくないが、他のスクリプトをトリガーするなど、別のことを実行できるようにしたい場合があります。次のコードは、デフォルトの動作を無効にするちょっとしたトリックです:


JavaScript

$('a.no-link').click(function (e) {
 e.preventDefault();
});
フェード/スライドスイッチ


フェードイン、フェードアウト、スライドは、jQuery を使用して作成することが多いアニメーション効果です。ユーザーが何かをクリックしたときに要素を表示したいだけかもしれません。fadeIn と slideDown の使用はどちらも優れています。ただし、要素を最初のクリックで表示し、2 回目のクリックで非表示にしたい場合は、次のコードを使用するとうまく機能します:

JavaScript

// Fade
$('.btn').click(function () {
 $('.element').fadeToggle('slow');
});
// Toggle
$('.btn').click(function () {
 $('.element').slideToggle('slow');
});
シンプルなアコーディオンエフェクト


アコーディオン効果を素早く簡単に実現する方法は次のとおりです:

JavaScript

// Close all panels
$('#accordion').find('.content').hide();
 
// Accordion
$('#accordion').find('.accordion-header').click(function () {
 var next = $(this).next();
 next.slideToggle('fast');
 $('.content').not(next).slideUp('fast');
 return false;
});

このスクリプトを追加したら、必要な HTML 内でスクリプトが適切に動作するかどうかを確認するだけです。

2 つの Div を同じ高さにします


含まれるコンテンツに関係なく、2 つの div を同じ高さにしたい場合があります。


JavaScript

$('.div').css('min-height', $('.main-div').height());

この例では min-height を設定します。つまり、メイン div よりも大きくすることはできますが、小さくすることはできません。ただし、より柔軟な方法は、要素のセットの設定を繰り返し、高さを要素内の最高値に設定することです:

JavaScript

var $columns = $('.column');
var height = 0;
$columns.each(function () {
 if ($(this).height() > height) {
  height = $(this).height();
 }
});
$columns.height(height);
すべての列を同じ高さにしたい場合:


JavaScript

var $rows = $('.same-height-columns');
$rows.each(function () {
 $(this).find('.column').height($(this).height());
});

在新标签/窗口打开站外链接
在一个新标签或者新窗口中打开外置链接,并确保站内链接会在相同的标签或窗口中打开:

JavaScript

$('a[href^="http"]').attr('target', '_blank');
$('a[href^="//"]').attr('target', '_blank');
$('a[href^="' + window.location.origin + '"]').attr('target', '_self');

注意:window.location.origin 在 IE 10 中不可用,该 issue 的修复方法。

通过文本找到元素

通过使用 jQuery 中的 contains() 选择器,你可以找到某个元素中的文本。如果文本不存在,该元素将会隐藏:

JavaScript

var search = $('#search').val();

$('div:not(:contains("' + search + '"))').hide();

视觉改变触发
当用户焦点在另外一个标签上,或重新回到标签时,触发 JavaScript:

JavaScript

$(document).on('visibilitychange', function (e) {
 if (e.target.visibilityState === "visible") {
  console.log('Tab is now in view!');
 } else if (e.target.visibilityState === "hidden") {
  console.log('Tab is now hidden!');
 }
});

Ajax 调用的错误处理

当某次 Ajax 调用返回 404 或 500 错误,就会执行错误处理。但如果没有定义该处理,其他 jQuery 代码或许会停止工作。可以通过下面这段代码定义一个全局 Ajax 错误处理:

JavaScript

$(document).ajaxError(function (e, xhr, settings, error) {
 console.log(error);
});

全能程序员交流QQ群290551701,群内程序员都是来自,百度、阿里、京东、小米、去哪儿、饿了吗、蓝港等高级程序员 ,拥有丰富的经验。加入我们,直线沟通技术大牛,最佳的学习环境,了解业内的一手的资讯。如果你想结实大牛,那 就加入进来,让大牛带你超神!

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