aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKlaus Hartl <klaus.hartl@googlemail.com>2009-02-19 20:19:13 +0000
committerKlaus Hartl <klaus.hartl@googlemail.com>2009-02-19 20:19:13 +0000
commit1ca5ae160ca1243ba6232abba8f52e09dd7172f6 (patch)
tree89093ddcc2f707875362bdedf12e99b4bebe3b9e
parente5268f9c32d9f934e942aacbce8acfaf73d8c477 (diff)
downloadjquery-ui-1ca5ae160ca1243ba6232abba8f52e09dd7172f6.tar.gz
jquery-ui-1ca5ae160ca1243ba6232abba8f52e09dd7172f6.zip
Tabs: normalization of href attribute required in IE, fixes #4134
-rw-r--r--tests/unit/tabs/tabs_methods.js4
-rw-r--r--ui/ui.tabs.js20
2 files changed, 17 insertions, 7 deletions
diff --git a/tests/unit/tabs/tabs_methods.js b/tests/unit/tabs/tabs_methods.js
index 61ddee642..dbfa9ee33 100644
--- a/tests/unit/tabs/tabs_methods.js
+++ b/tests/unit/tabs/tabs_methods.js
@@ -43,7 +43,7 @@ test('disable', function() {
});
test('add', function() {
- expect(3);
+ expect(4);
el = $('#tabs1').tabs();
el.tabs('add', "#new", 'New');
@@ -55,6 +55,8 @@ test('add', function() {
ok(other.is('.ui-state-hover'), 'should not remove mouseover handler from existing tab');
other.simulate('mouseout');
+ equals($('a', added).attr('href'), '#new', 'should not expand href to full url of current page');
+
ok(false, "missing test - untested code is broken code.");
});
diff --git a/ui/ui.tabs.js b/ui/ui.tabs.js
index 57ff72f94..f9d4cc512 100644
--- a/ui/ui.tabs.js
+++ b/ui/ui.tabs.js
@@ -81,13 +81,20 @@ $.widget("ui.tabs", {
this.$tabs.each(function(i, a) {
var href = $(a).attr('href');
- // For dynamically created HTML that contains a hash as href IE expands
- // such href to the full page url with hash and then misinterprets tab as ajax...
- if (href.split('#')[0] == location.toString().split('#')[0]) href = a.hash;
-
+ // For dynamically created HTML that contains a hash as href IE < 8 expands
+ // such href to the full page url with hash and then misinterprets tab as ajax.
+ // Same consideration applies for an added tab with a fragment identifier
+ // since a[href=#fragment-identifier] does unexpectedly not match.
+ // Thus normalize href attribute...
+ if (href.split('#')[0] == location.toString().split('#')[0]) {
+ href = a.hash;
+ a.href = href;
+ }
+
// inline tab
- if (fragmentId.test(href))
+ if (fragmentId.test(href)) {
self.$panels = self.$panels.add(self._sanitizeSelector(href));
+ }
// remote tab
else if (href != '#') { // prevent loading the page itself if href is just "#"
@@ -109,8 +116,9 @@ $.widget("ui.tabs", {
}
// invalid tab href
- else
+ else {
o.disabled.push(i);
+ }
});
// initialization from scratch