Location.hash возвращает пустую строку
В настоящее время я использую jQuery, Twitter Bootstrap и CanJS для своего веб-приложения. Я пытаюсь реализовать маршрутизацию с CanJS. Я использую вкладку Bootstrap, и когда я щелкаю по вкладке, она должна была принести #tabSearch, #tabUser или #tabPermissions, но хеш возвращается с пустой строкой. Что я делаю неправильно?
Я использую это, чтобы изменить вкладки:
TabControl = can.Control.extend({}, {
init: function (element, options) {
element.find('a[href="' + options.defaultTab + '"]').tab('show');
this.userSearch = null;
this.userForm = null;
}
, 'a[data-toggle="tab"] show': function (e) {
this.options.tabChangeCallback(e);
}
});
UserTab = new TabControl('#tabctrlUser', {
defaultTab: '#tabSearch',
tabChangeCallback: function (e) {
if (e.context.hash == '#tabSearch') {
if (!this.userSearch) {
this.userSearch = new FormUserQuery('#tabSearch', {});
}
} else if (e.context.hash == '#tabUser') {
if (!this.userForm) {
this.userForm = new FormUser('#tabUser', {});
}
this.userForm.renderView(currentUser);
} else if (e.context.hash == '#tabPermissions') {
new FormPermissions('#tabPermissions', {});
}
}
});
Вот часть HTML:
<ul id="tabctrlUser" class="nav nav-tabs">
<li><a href="#tabSearch" data-toggle="tab">Pesquisar</a></li>
<li><a href="#tabUser" data-toggle="tab">Cadastrar/Alterar</a></li>
<li><a href="#tabPermissions" data-toggle="tab">Acessos</a></li>
</ul>
<div class="tab-content">
<div class="tab-pane" id="tabSearch"></div>
<div class="tab-pane" id="tabUser"></div>
<div class="tab-pane" id="tabPermissions"></div>
</div>
2 ответа
Вам нужно использовать can.route или can.Control.Route, способ, которым вы делаете это, сложен, взгляните на этот вопрос. Также есть 2 хорошие статьи о маршрутизации.
посмотрите на эту суть
http://jsfiddle.net/Z9Cv5/2/light/
var HistoryTabs = can.Control({
init: function( el ) {
// hide all tabs
var tab = this.tab;
this.element.children( 'li' ).each(function() {
tab( $( this ) ).hide();
});
// activate the first tab
var active = can.route.attr(this.options.attr);
this.activate(active);
},
"{can.route} {attr}" : function(route, ev, newVal, oldVal){
this.activate(newVal, oldVal)
},
// helper function finds the tab for a given li
tab: function( li ) {
return $( li.find( 'a' ).attr( 'href' ) );
},
// helper function finds li for a given id
button : function(id){
// if nothing is active, activate the first
return id ? this.element.find("a[href=#"+id+"]").parent() :
this.element.children( 'li:first' );
},
// activates
activate: function( active, oldActive ){
// deactivate the old active
var oldButton = this.button(oldActive).removeClass('active');
this.tab(oldButton).hide();
// activate new
var newButton = this.button(active).addClass('active');
this.tab(newButton).show();
},
"li click" : function(el, ev){
// prevent the default setting
ev.preventDefault();
// update the route data
can.route.attr(this.options.attr, this.tab(el)[0].id)
}
});
// configure routes
can.route(":component",{
component: "model",
person: "mihael"
});
can.route(":component/:person",{
component: "model",
person: "mihael"
});
// adds the controller to the element
new HistoryTabs( '#components',{attr: 'component'});
new HistoryTabs( '#people',{attr: 'person'});
Я не знаком с CanJS, но это может быть чем-то, что событие щелчка якоря происходит до навигации, а location.hash устанавливается после. Например, если (в качестве теста) вы определяете свою ссылку как
<a href="#tabSearch" onclick="tabChangeCallback()">Pesquisar</a>
А в простом ваниле JS попробуй
function tabChangeCallback() {
alert(location.hash)
}
Это будет отображаться пустым.
Но если вы попробуете что-то вроде
function tabChangeCallback() {
setTimeout(function() {
alert(location.hash)
}, 100)
}
Это будет отображать хэш. Так что в вашем случае либо установите код для выполнения по таймауту после основного события, либо (и я думаю, что это лучший вариант) вместо хеша, который вы должны прочитать href
атрибут элемента привязки, вызвавшего событие.
Обновление Простой пример JS ниже показывает, как получить значение хеша без тайм-аута:
function tabChangeCallback(e) {
var elem = e ? e.target : event.srcElement
alert(elem.getAttribute("href"))
}