gpt4 book ai didi

ember.js - 如何显式重定向到自动生成的 `error`路由?

转载 作者:行者123 更新时间:2023-12-02 06:08:48 25 4
gpt4 key购买 nike

看来我可以显式访问/重定向到自动创建的loading路由,但不能访问error路由。有什么理由吗?还是解决它的方法?

所谓“自动创建”,是指我已经创建了加载和错误模板,但尚未明确创建路由或在路由器中定义它们。 Ember docs解释这将创建一个加载路径,而implies (but does not explicitly state)解释错误路径也应如此。

我看到的错误看起来好像路由不存在:

DEBUG: -------------------------------
vendor.js:28585DEBUG: Ember : 1.8.1
vendor.js:28585DEBUG: Ember Data : 1.0.0-beta.12
vendor.js:28585DEBUG: Handlebars : 1.3.0
vendor.js:28585DEBUG: jQuery : 1.11.2
vendor.js:28585DEBUG: -------------------------------
vendor.js:28585Error: Assertion Failed: The URL '/error' did not match any routes in your application
at new Error (unknown source)
at Error.EmberError (http://0.0.0.0:4200/assets/vendor.js:27463:23)
at Object.assert (http://0.0.0.0:4200/assets/vendor.js:17077:15)
at http://0.0.0.0:4200/assets/vendor.js:39714:17
at tryCatch (http://0.0.0.0:4200/assets/vendor.js:60519:16)
at invokeCallback (http://0.0.0.0:4200/assets/vendor.js:60531:17)
at http://0.0.0.0:4200/assets/vendor.js:62430:13
at http://0.0.0.0:4200/assets/vendor.js:42647:9
at http://0.0.0.0:4200/assets/vendor.js:13891:18
at Object.flush (http://0.0.0.0:4200/assets/vendor.js:13961:15)
vendor.js:17077Uncaught Error: Assertion Failed: Error: Assertion Failed: The URL '/error' did not match any routes in your application

但它被列为可用路线:
Ember.keys(Onboarding.Router.router.recognizer.names)
["loading", "error", ..., "index", "application"]

尽管如此,将其显式添加到路由器:
Router.map(function() {
...
this.route("error");
});

确实解决了问题。

我在做傻事吗?还是这是预期的行为?

编辑:

JSBin来说明不同之处: http://emberjs.jsbin.com/yicijayiri/2/edit?html,js,output

最佳答案

我遇到了同样的问题,并在http://discuss.emberjs.com/t/error-route-must-now-be-explicitly-included-in-router-intended-behavior/6943找到了有用的提示

经过测试,这使我了解到在您的示例中,您可以通过添加预期参数来链接到错误页面(无需显式定义错误路径)。由于您没有使用该参数,因此它无关紧要。在链接至中添加第二个参数适用于您的示例:{{link-to "error page" "error" "A string"}}
以下是一些可能有用的其他信息。如果您希望过渡到错误路线,则在传递第二个参数时,其工作原理类似。

this.transitionTo('error', 'Error'); // OR
this.intermediateTransitionTo('error', 'Error');

现在,如果要在错误消息中使用参数,则可以使用如下所示的错误模板:
<script type="text/x-handlebars" id="error">
<h1>{{name}}</h1>
<p>{{message}}</p>
</script>

使用此模板,当您使用transitionTo或中间体TransitionTo时,您需要传递一个错误对象作为参数: this.transitionTo('error', new Error('My custom error message.'));
此外,如果您还希望传递唯一的错误名称,则可以执行以下操作:
var errorObj = new Error('My customer error message');
errorObj.name = 'Custom Error';
this.transitionTo('error', errorObj);

关于ember.js - 如何显式重定向到自动生成的 `error`路由?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28889287/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com