Deprecated: Assigning the return value of new by reference is deprecated in /home/users/1/fool.jp-ichi/web/blog/wp-content/plugins/modPukiWiki/plugin/notice.inc.php on line 14
Deprecated: Function split() is deprecated in /home/users/1/fool.jp-ichi/web/blog/wp-content/plugins/modPukiWiki/lib/func.php on line 75
Deprecated: Function split() is deprecated in /home/users/1/fool.jp-ichi/web/blog/wp-content/plugins/modPukiWiki/lib/func.php on line 75
Deprecated: Function ereg() is deprecated in /home/users/1/fool.jp-ichi/web/blog/wp-content/plugins/modPukiWiki/plugin/ref.inc.php on line 207
Deprecated: Assigning the return value of new by reference is deprecated in /home/users/1/fool.jp-ichi/web/blog/wp-content/plugins/modPukiWiki/plugin/region.inc.php on line 14
- 08/12/05 修正
- return $(this) → return this に。
古いのだとメソッドチェーンしたときにたぶんまずいことになる。
スクロールについてきてぬるぬる動くやつをちょと変更。
- がちゃがちゃとスクロールしまくるとたまに妙な位置で止まるので(もっかいスクロールすれば治るけど)、定期的に今の位置を確認しておかしな場所に居れば本来居るべき場所に動くようにした。
- ということでオプションに『check』を追加。0にしたら定期チェック無しに。
- Safariで挙動がおかしな場合があるのでposition:fixedでお茶濁し。
必要なもの
サンプル
オプション
- wait(デフォルト値:100)
- スクロールしてから動き出すまで(ms)
- minDuration(デフォルト値:100)
- アニメーションの最小時間(ms)
- check(デフォルト値:1000)
- 定期チェックの間隔(ms)
0にするとチェック無しに。
ソース
…
$.fn.floating = function(options){ options = $.extend({ wait: 100, minDuration: 100, check: 1000 }, options); return this.each(function(){ var $this = $(this); //safariはfixedでお茶濁し if($.browser.safari){ $this.css("position", "fixed"); return true;//continue } var boxTop = function(){return $this.offset().top}; var startTop = boxTop(); var timer, checkTimer; var scrollTop, nowTop, targetTop, duration; var d = document, w = window; var getPosTop = function(){ scrollTop = d.body.scrollTop || d.documentElement.scrollTop; nowTop = boxTop(); targetTop = scrollTop + startTop; duration = Math.max(options.minDuration, Math.abs(targetTop - nowTop)); }; var scrollAnimation = function(){ $this .animate({ top: targetTop + "px" }, duration, function(){ timer = 0; }); }; $(w) .scroll(function(){ if(timer) return; timer = w.setTimeout(function(){ getPosTop(); scrollAnimation(); }, options.wait); }); //定期的にチェック checkが0ならスルー if(options.check) checkTimer = w.setInterval(function(){ if(timer) return; getPosTop(); if(nowTop == targetTop) return; scrollAnimation(); }, options.check); }); }; |
Prev / Next in same category
Comment Form
Trackbacks (1)
秋冬ビジネススーツ ローライズスラックスのスーツ
[js] floating.jsちょと変更 | おれせか
[2014/11/03 (月) 18:49]
Comments (11)
safariんとこはreturn trueだな。
明日なおす。
なおした
全力でミスってたので修正。
return $(this)じゃなくてreturn thisだわ。
俺もきめぇwww
しっかり読まなくてもアジェンダの応用例見るだけでも何ができるのかはすぐわかるよ。
流行を見抜くことができるのも実は巡回するで。
異なる風格は過ぎて数年また流行り始めて。
休む騒動の飛躍、各種が高くて大きい上の贅沢なブランドにも次から次へとこ。
l直書きでネスト作るこ
このシャネル腕時計のブランドの自分、
シャネル激安http://www.cctoh.com/
93―01チップを基礎にする93―02は自動的に鎖の機械のチップに行って駆動します。
シャネル財布
シャネルピアス
シャネル眼鏡
シャネルバッグ
シャネル腕時計
シャネル靴
このチップは48時間の動力を持って貯蓄して、
シャネル激安腕時計の使用更におだやかで心地良くて、
飛行する陀はずみ車は8粒のねじの調節の後の改良システムでと腕時計、
シャネル完璧な精密で正確な度を確保しました。
一方、優れたスーパーコピー素材で作りますから、質感が素晴らしいです
ということでオプションに『check』を追加。0にしたら定期チェック無しに。
Safariで挙動がおかしな場合があるのでposition:fixedでお茶濁し。
流行を見抜くことができるのも実は巡回するで。