diff options
| author | Di Peng | 2011-07-14 17:50:06 -0700 |
|---|---|---|
| committer | Igor Minar | 2011-07-17 22:19:08 -0700 |
| commit | 7a3fdda9650a06792d9278a8cef06d544d49300f (patch) | |
| tree | 6a4cb98b13c9f0cdcef78ae5e50041b21a9ddd53 /test/jqLiteSpec.js | |
| parent | b4f18fc295fe9cdbabf9e6e8d7587e5d76ff6878 (diff) | |
| download | angular.js-7a3fdda9650a06792d9278a8cef06d544d49300f.tar.bz2 | |
feat(jqlite): added show(),hide() and eq() methods to jqlite
- add those three methods to jqlite
Diffstat (limited to 'test/jqLiteSpec.js')
| -rw-r--r-- | test/jqLiteSpec.js | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/test/jqLiteSpec.js b/test/jqLiteSpec.js index c920a250..8dd66d36 100644 --- a/test/jqLiteSpec.js +++ b/test/jqLiteSpec.js @@ -507,4 +507,70 @@ describe('jqLite', function(){ expect(innerDiv.html()).toEqual('text'); }); }); + + + describe('hide', function() { + var element; + + afterEach(function() { + if (element) dealoc(element); + }); + + it('should hide the element', function() { + element = jqLite('<div></div>'); + expect(isCssVisible(element)).toBe(true); + element.hide(); + expect(isCssVisible(element)).toBe(false); + }); + }); + + + describe('show', function() { + var element; + + afterEach(function() { + if (element) dealoc(element); + element.remove(); + }); + + + it('should show the element ', function() { + element = jqLite('<div></div>'); + element[0].style.display = 'none'; + expect(isCssVisible(element)).toBe(false); + element.show(); + expect(isCssVisible(element)).toBe(true); + }); + + + it('should show previously hidden element and preserve the display value', function() { + element = jqLite('<div style="display:inline">xx</div>'); + jqLite(document.body).append(element); + element.hide(); + expect(isCssVisible(element)).toBe(false); + element.show(); + expect(element[0].style.display).toBe('inline'); + expect(isCssVisible(element)).toBe(true); + + element[0].style.display = 'block'; + element.hide(); + expect(isCssVisible(element)).toBe(false); + element.show(); + expect(isCssVisible(element)).toBe(true); + + // this totally doesn't make sense, it should be 'block', but jquery (1.4.2+1.6.2) behaves + // this way. + expect(element[0].style.display).toBe('inline'); + }); + }); + + + describe('eq', function() { + it('should select the nth element ', function() { + var element = jqLite('<div><span>aa</span></div><div><span>bb</span></div>'); + expect(element.find('span').eq(0).html()).toBe('aa'); + expect(element.find('span').eq(-1).html()).toBe('bb'); + expect(element.find('span').eq(20).length).toBe(0);; + }); + }); }); |
