javascript - 无法通过 url 访问 Ember 子路由并将我重定向到父路由

标签 javascript url ember.js ember-cli ember-router

我想通过 url 访问子路由,例如:https://my-app.com/dashboard/library。当我点击它时,Ember 将我重定向到 https://my-app.com/dashboard 并正确填充这条路线的模型数据,但我想转到 https://my- app.com/dashboard/library,及其新模型数据。 另一方面,我可以通过 url 访问 https://my-app.com/login,顺便说一下,它没有模型数据。

environment.js 我有 locationType: "auto",我的 router.js 是这样的:

Router.map(function() {
  this.route('login');
  this.route('dashboard', function() {
    this.route('child', {path: '/child/:child_id'});
    this.route('library');
  });
});

我的路线:

// Route: dashboard
import Ember from 'ember';
import RouteHistoryMixin from 'ember-route-history/mixins/routes/route-history';

export default Ember.Route.extend(RouteHistoryMixin, {
    model: function() {
        let userId = this.authentication.getPlayerId();
        let actions =  this.store.findAll('action');
        return Ember.RSVP.hash({
            actions: actions,
            tasks: Ember.RSVP.all([actions]).then((actions) => {
                return this.store.findAll('task')
            }),
            rank: this.store.findAll('rank')
        });
    },
    afterModel: function(){
        this.transitionTo('dashboard.index');   // needless
    },
    setupController(controller, model) {
        this._super(...arguments);
        Ember.set(controller, 'tasks', model.tasks);
        Ember.set(controller, 'rank', model.rank);
    }
    // . . .

// Route: dashboard/library
import Route from '@ember/routing/route';
import Ember from 'ember';
import RouteHistoryMixin from 'ember-route-history/mixins/routes/route-history';

export default Route.extend(RouteHistoryMixin, {
    complete: Ember.inject.service(),
    queryParams: {
        taskId: {}
    },
    model(params) {
        if(params.taskId) {
            return Ember.RSVP.hash({
                article: this.store.query('article', { filter: '{"inSyllabus": true}'}),
                task: this.store.query('task', { filter: '{"id": ' + params.taskId + '}'})
            });
        }
        else {
            return Ember.RSVP.hash({
                article: this.store.query('article', { filter: '{"inSyllabus": true}'})
            });
        }
    },
    setupController(controller) {
        this._super(...arguments);
        if (controller.taskId)
            this.store.findRecord('task', controller.taskId).then((task) => {
                controller.set('libraryQueryParam', task.points);
                // Notify Task completion
                let payload = {
                    startDate: new Date(),
                    endDate: new Date(),
                    points: task.points,
                    entries: 1
                };
                // PUT HTTP COMMAND FOR PLAYER
                let playerTask = this.store.createRecord('playTaskTest', payload);
                playerTask.save();
            });
    }
    // . . .

可能是配置标志或路由器配置问题?

我怎样才能通过 url 访问这个子路由或者你们有没有发生过类似的事情?

最佳答案

我认为问题出在仪表板中。在 afterModel 钩子(Hook)上:

afterModel: function(){
    this.transitionTo('dashboard.index');   // needless
}

每次调用dashboard 路由时,这部分重定向到dashboard.index。请记住,dashboard.index 是与 childlibrary 相同的子路由,因此您将永远无法访问它们。

关于javascript - 无法通过 url 访问 Ember 子路由并将我重定向到父路由,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55063873/

相关文章:

javascript - jquery 延迟更改排队函数关闭?

zend-framework - 为什么 Google 会截断我的网址? (使用 Zend 框架)

Android InputStream 遵循重写规则

javascript - 外部拒绝 Ember 中的未决 promise

javascript - 使用范围 slider 过滤数据

javascript - Chart.js折线图设置背景色

javascript - 如何将全局/公共(public)变量添加到 grunt-contrib-uglify 输出

swift - 添加坐标(从 UIViewController)到常量文件

ember.js - 将负 isDirty 与禁用类连接

ember.js - ember 数据适配器中的动态段