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'); });
JavaScript
$('.btn').hover(function () { $(this).toggleClass('hover'); });
入力フィールドを無効にする
JavaScript
$('input[type="submit"]').prop('disabled', true);
JavaScript
$('input[type="submit"]').prop('disabled', false);
JavaScript
$('a.no-link').click(function (e) { e.preventDefault(); });
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; });
2 つの Div を同じ高さにします
JavaScript
$('.div').css('min-height', $('.main-div').height());
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,群内程序员都是来自,百度、阿里、京东、小米、去哪儿、饿了吗、蓝港等高级程序员 ,拥有丰富的经验。加入我们,直线沟通技术大牛,最佳的学习环境,了解业内的一手的资讯。如果你想结实大牛,那 就加入进来,让大牛带你超神!