2012-02-10 9 views
2

私はTwitterのBootstrapトップバーを使用しています。href =#SomeDivNameをクリックするとページがスクロールします

私は

href=#SomeDivName

このページのナビゲーションキーを押したときと同様のhrefいくつかのナビゲーションをクリックしてください:ビットダウン

http://twitter.github.com/bootstrap/examples/fluid.html#contact

ページがスクロールします。

クリックした後に関連するセクションが表示されるようにしたいが、私は のページをスクロールしたくない。

答えて

6
$('a[href="#SomeDiveName"]').on('click', false); 

あなたは#SomeDiveNameに設定href属性を持つアンカータグをクリックしたとき、これはfalseを返します。要素のデフォルトの振る舞いを妨げます。この場合、href属性が参照する要素にスクロールします。

$('.stop-this-link').on('click', false); 

これですべての要素のデフォルトの動作を防ぐことができます:あなたはこれらのリンクのセットを持っている場合は

その後、私はあなたが一度にすべてを選択することができますので、それらを識別するためにクラスを追加することをお勧めしたいです要素がクリックされるたびにstop-this-linkクラス。クラスで選択するのは、属性よりもはるかに高速です。属性で検索する場合は、DOM内のすべての要素をチェックする必要があります。

jQueryイベントハンドラでfalseを返すことは、event.preventDefault()event.stopPropagation()を呼び出すのと同じことに注意してください。これらの関数についての詳細情報については

はこちらを参照してください。

+0

'.on'に' false'を渡すことができますか? '.on( 'click'、function(){return false;});'? –

+2

私は誰を覚えていないのですが、SOの誰かがそれを約1週間前に見せてくれました。 'function(){return false '}'何をしますか? 'false'を返します。まあ 'false'は' false'を返します:)。あなたがしたいのは、デフォルトの動作やイベントのバブリングを防ぐことだけが目的ならば、コードを簡単にする方法です。 – Jasper

+0

しかし、 'function(){return false '}'は 'function'です。' false'は 'boolean'です。私はjQueryがそれを理解するのに十分スマートだと思う。 –

1

あなたが他のものをバインドする場合は、しかし、あなたは、いくつかのすごみを得る可能性があります後で。

$('.stop-this-link').on('click', function(e){ e.preventDefault() }); 

基本的に同じことをしますが、重要なことは、少し冗長であることのコストで、DOMアップイベントの伝播を停止しない:私はこれを使用する傾向があります。

4

の代わり<a href="#target">使用<a data-target="#target">を使用し、href属性

+0

これは私の最後には機能しませんでした。必要な機能を得るために必要な変更があるかどうかを知りたいですか? – adi

+0

ありがとうございます。それは私のコードで動作します。 –