mirror of
				https://github.com/twbs/bootstrap.git
				synced 2025-10-25 00:03:39 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| $(function () {
 | |
|   'use strict';
 | |
| 
 | |
|   module('affix plugin')
 | |
| 
 | |
|   test('should be defined on jquery object', function () {
 | |
|     ok($(document.body).affix, 'affix method is defined')
 | |
|   })
 | |
| 
 | |
|   module('affix', {
 | |
|     setup: function () {
 | |
|       // Run all tests in noConflict mode -- it's the only way to ensure that the plugin works in noConflict mode
 | |
|       $.fn.bootstrapAffix = $.fn.affix.noConflict()
 | |
|     },
 | |
|     teardown: function () {
 | |
|       $.fn.affix = $.fn.bootstrapAffix
 | |
|       delete $.fn.bootstrapAffix
 | |
|     }
 | |
|   })
 | |
| 
 | |
|   test('should provide no conflict', function () {
 | |
|     ok(!$.fn.affix, 'affix was set back to undefined (org value)')
 | |
|   })
 | |
| 
 | |
|   test('should return element', function () {
 | |
|     ok($(document.body).bootstrapAffix()[0] == document.body, 'document.body returned')
 | |
|   })
 | |
| 
 | |
|   test('should exit early if element is not visible', function () {
 | |
|     var $affix = $('<div style="display: none"></div>').bootstrapAffix()
 | |
|     $affix.data('bs.affix').checkPosition()
 | |
|     ok(!$affix.hasClass('affix'), 'affix class was not added')
 | |
|   })
 | |
| 
 | |
|   test('should trigger affixed event after affix', function () {
 | |
|     stop()
 | |
| 
 | |
|     var template = $('<div id="affixTarget"><ul><li>Please affix</li><li>And unaffix</li></ul></div><div id="affixAfter" style="height: 20000px; display:block;"></div>')
 | |
|     template.appendTo('body')
 | |
| 
 | |
|     $('#affixTarget').bootstrapAffix({
 | |
|       offset: $('#affixTarget ul').position()
 | |
|     })
 | |
| 
 | |
|     $('#affixTarget')
 | |
|       .on('affix.bs.affix', function () {
 | |
|         ok(true, 'affix event triggered')
 | |
|       }).on('affixed.bs.affix', function () {
 | |
|         ok(true, 'affixed event triggered')
 | |
|         $('#affixTarget').remove()
 | |
|         $('#affixAfter').remove()
 | |
|         start()
 | |
|       })
 | |
| 
 | |
|     setTimeout(function () {
 | |
|       window.scrollTo(0, document.body.scrollHeight)
 | |
|       setTimeout(function () {
 | |
|         window.scroll(0, 0)
 | |
|       }, 0)
 | |
|     }, 0)
 | |
|   })
 | |
| })
 |