ANGULAR-UI-ROUTER:从URL解析状态

Ale*_*uch 9 javascript angularjs angular-ui angular-ui-router

我正在创建一个具有动态状态的应用程序,有时我需要从URL解析状态名称.

例如:我有/dashboard/user/12268,我需要得到这个州'dashboard.user'.

有没有办法用这些工具来做到这一点ui-router?我现在无法知道如何做到这一点......

我正在使用requireJS进行动态模块加载的应用程序.第一次没有问题,因为用户被发送到登录状态.登录后,我使用require只加载用户有权访问的状态.但是当用户重新加载页面时,我再次加载模块,并需要将URL解析为状态,并且存在问题.我已经开始尝试使用urlMatcherFactory但无法解决它们.

在URL解析后加载状态.

流程是(刷新页面后http://localhost:8090/index.html#/dashboard/user/12268):

  • 引导应用程序(没有状态)
  • 此时,ui-router已经装好了
  • 获取用户有权访问的状态,并注册它们(这些状态配置阶段注册)
  • 找出我是否有一个匹配给定网址的状态重定向到那里.这就是我被困住的地方.

为了在应用程序引导之后加载状态,我使用了Ben Nadel解决方案的变体,其中包括状态和常量.

data-main在RequireJS中有这个初始化代码:

require.config({
    // REQUIREJS CONFIGURATION
});

require(['app'], function (app) {
    app.bootstrap(document);

    var ng = angular.injector(['ng']);
    var $window = ng.get('$window')
    var $q = ng.get('$q');

    var appStorage = $window.localStorage;
    var loadedManifests;

    try {
        loadedManifests = JSON.parse(appStorage.getItem('loadedManifests'));
    } catch(e) {
        loadedManifests = [];
    }

    if (!angular.isArray(loadedManifests) || loadedManifests.length === 0) {
        $q.all([
                app.loadManifest('login/manifest'), //loadMainfest function loads the states for login
                app.loadManifest('logout/manifest') //load states for logout
            ])
            .then(function () {
                app.injector.get('$rootScope').$evalAsync(function () {
                    app.injector.get('$state').go('login');
                });
            });
    } else {
        var promisesArray = [];

        for(var i = 0; loadedManifests[i]; i++) {
            promisesArray.push(app.loadManifest(loadedManifests[i])); //load all manifests registered on localstorage
        }

        $q.all(promisesArray).then(function(){
            //TODO: Stuck. Get URL from querystring and resolve to valid state, or redirect to /login
        });
    }
});
Run Code Online (Sandbox Code Playgroud)

loadManifest函数在我的应用程序(服务,工厂,控制器,路由器......)上注册所有后引导元素.

谢谢你的帮助,
Alx

Chr*_*s T 17

https://github.com/angular-ui/ui-router/issues/1651

您可以使用.decorator挂钩来公开内部状态实现$stateProvider.你可以装饰国家建设者的任何财产; 我随意选择了"父母".


app.config(function($stateProvider) { 
  $stateProvider.decorator('parent', function (internalStateObj, parentFn) {
     // This fn is called by StateBuilder each time a state is registered

     // The first arg is the internal state. Capture it and add an accessor to public state object.
     internalStateObj.self.$$state = function() { return internalStateObj; };

     // pass through to default .parent() function
     return parentFn(internalStateObj); 
  });
});
Run Code Online (Sandbox Code Playgroud)

现在,您可以使用.$$state(),例如,访问内部状态对象

var publicState = $state.get("foo");
var privateInternalState = publicState.$$state();
Run Code Online (Sandbox Code Playgroud)

其次,遍历$ state.get()中的每个状态,并针对您的URL片段测试它们.

angular.forEach($state.get(), function(state) { 
  var privatePortion = state.$$state();
  var match = privatePortion.url.exec(url, queryParams);
  if (match) console.log("Matched state: " + state.name + " and parameters: " + match);
});
Run Code Online (Sandbox Code Playgroud)

  • 在搜索部分,添加`if(!state.$$ state)return;`会很好,因为我有一个_global_抽象状态,它没有该属性并导致错误. (4认同)

小智 -2

当前状态可以从 $state 服务获取。就像$state.current 检查这个api http://angular-ui.github.io/ui-router/site/#/api/ui.router.state.$state

  • 在这种情况下,“$state.current”是一个空状态,因为状态是在配置阶段之后注册的 (2认同)