首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JavascriptMVC是否支持可加书签的URL?

JavascriptMVC是否支持可加书签的URL?
EN

Stack Overflow用户
提问于 2011-01-05 19:18:39
回答 2查看 584关注 0票数 0

我正在考虑移植我当前的应用程序,以使用JavascriptMVC + RESTfull web服务。但是,我不确定是否可以使用JavascriptMVC创建可加书签的URL。

例如: webapp是一个托管课程的应用程序,它的URL如下

/courses/RDBMS/lecture/1

可以用JavascriptMVC创建这样的URL吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-08 13:30:52

您可以考虑使用jQuery.address ( http://www.asual.com/jquery/address/ )来管理您的URL。

jQuery.address允许您设置可爬行的URL,如"http://example.com/#!/user/5“,并侦听地址更改并采取相应的操作。

在我自己的代码中,我从steal配置文件中设置了一个基于地址的路由器,如下所示。

代码语言:javascript
复制
steal.plugins(
          'jquery/controller',
          'jquery/controller/subscribe',
          'jquery/view/ejs',
          'jquery/controller/view',
          'jquery/model',
          'jquery/dom/fixture',
          'jquery/dom/form_params',
          'steal/less')                   
    .css('css/vendor/reset-fonts-grids')
    .resources('vendor/jquery.address-1.3.1.min.js')
    .models('user')
    .controllers('user')
    .views()
    .then(function() {
        steal.less('css/style');

        // Set up a router
        $.address.baseURL('/basePath');

        // $.address.crawlable(true);
        $.address.change(function(event) {
            var path = event.path;
            switch(true) {
            // Matches http://example.com/#!/ or http://example.com/
            case /^\/$/.test(path):
                $('#page').empty();
                break;
            // Matches http://example.com/#!/user/42/profile
            case /^\/user\/[0-9]+\/profile/.test(path):
                var userId = path.split("/")[2];
                // Instantiate and load a controller
                new User.Controllers.User($('body'),userId);
                break;
            case /^\/search/.test(path):
                $.log('search');
                break;
            default:
                $.log(event.path);
            }
        });
    });

然后,您可以通过以下方式从HTML-land调用新页面

代码语言:javascript
复制
<a href="/" onclick="$.address.value('/'); return false;">root url</a>

或从JS land通过

代码语言:javascript
复制
$.address.value('/user/10/profile');
票数 2
EN

Stack Overflow用户

发布于 2012-05-19 05:28:57

您可以使用JavascriptMVC路由器,它与jQuery.address相同,但集成了JavascriptMVC:http://javascriptmvc.com/docs.html#!jQuery.route

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4603462

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档