了解Backone js使用查询参数进行路由

时间:2013-05-22 12:45:44

标签: javascript backbone.js

这对某些人来说似乎微不足道,但我有一个应用程序执行搜索并使用包含搜索词的哈希值更新浏览器历史记录。

routes: {
"": "search",
"search/:query": "searchSetup"
},

根据我对主题标签的理解,有效的主题标签不应包含空格。每个人如何处理用户搜索的内容,例如视频游戏。 似乎当我搜索上面的术语时,导航事件被触发两次 我的正则表达目前很糟糕。

    RT.App.searchRouter = Backbone.Router.extend({
    initialize: function() {
        RT.App.vent.on("change:hash", function(searchTerm) {
            console.log("chnaging hash")
            this.navigate('search/'+searchTerm);
        }, this);
    },
    routes: {
        "": "search",
        "search/:query": "searchSetup"
    },
    createView: function () {
        //has view already been instatiated?
        if(!$("#forms-demo").length) {
            new RT.App.views.AdvancedSearchView({
                el: '#ui-search',
                model: new RT.App.models.AdvancedSearch()
            });

        }   

    },
    search: function() {
        //clear any previous search if any
        this.createView();
    },
    searchSetup: function(query) {
        this.createView();
        var $searchinputEl = $("#search-term"),     

        //check if storage entry exists and if it matches the query entered
            storedSearchTerm = amplify.store('search');
        if((!_.isUndefined(storedSearchTerm) && !_.isUndefined(query)) && (storedSearchTerm.term === unescape(query))) {

            //retrieve storage and perform search based on preferences
            RT.App.searchCategoryOptions.attributes = storedSearchTerm.sections;

            //each filter view options should now set the correct options
            RT.App.vent.trigger("change:options");

            //add search query to search input
            $searchinputEl.val(storedSearchTerm.term);

            //trigger search

            $(".trigger-search").trigger("click");
        }
    }
});
$(function(){

    // Instantiate the router
    var searchRouter = new RT.App.searchRouter();
    if(Backbone.History.started) {
        Backbone.history.stop();
    }
    Backbone.history.start();
});

1 个答案:

答案 0 :(得分:0)

你可以处理空格。只需确保首先对搜索字词进行编码。

this.navigate('search/'+ encodeURIComponent(searchTerm));