2013-01-04 9 views
10
function UsersVM(start_page){ 
    var self = this; 
    console.log('start form ' + start_page); 
    self.go_to = function(page) { 
    location.hash = '#Users/' + pageNumber;  
    } 
} 

Sammy(function() { 
    this.get('/app/?#Users/:page', function() { 
     var vm = new UsersVM(this.params.page); 
     ko.applyBinding(vm);    
    }); 
}).run(); 

をトリガすることなく、私は次のコードを使用して、ページのハッシュを変更したいと思います。バックボーンでこう答えてください。変更ハッシュサミーイベントに

app.navigate("help/troubleshooting", {trigger: false}); 

サミーでも可能ですか? ありがとう!

+0

私はまた、それを行う方法を理解しようとしています、あなたは解決策を見つけました@Andrew Luzkovky? – punkbit

答えて

0

次のコードを使用します。私はサミーでこれを行うには、ネイティブな方法を知っているが、ここで私のために働いているソリューションですません

var new_location = '#foo'; 
app.trigger('redirect', {to: new_location}); 
app.last_location = ['get', new_location]; 
app.setLocation(new_location); 
5

を:

var sam = $.sammy(function() { 
    var sammy = this; //get a persistent reference to this 

    sammy.quiet = false; //set quiet to false by default 

    //I set quiet to true before running a route 
    sammy.quietRoute = function (location) { 
     sammy.quiet = true; 
     sammy.setLocation(location); 
    } 

    //I'm called after every route to reset quiet to false 
    sammy.after(function() { 
     sammy.quiet = false; 
    }); 

    //I'm a 'normal' route that does not have the capability to be 'quiet' 
    this.get('#normalRoute', function() { 
     //routing code 
    }); 

    //I am a route that can be 'quieted' so that when the url or 
    //hash changes my routing code doesn't run 
    this.get('#quietableRoute', function() { 
     if (!sammy.quiet) { 
      //routing code 
     } else { 
      return; 
     } 
    }); 

}); 

その後コード内のquietRoute関数を呼び出してください: