5

我刚刚注意到Ext.app.Controller 上的商店配置http://docs.sencha.com/extjs/6.0/6.0.2-classic/#!/api/Ext.app.Controller-cfg-stores没有查看正确的路径(与视图配置相同)。

例如

Ext.define('MyApp.controller.Menu', {
    extend: 'Ext.app.Controller',
    stores: ['Menu']
...
});

这将寻找

http://localhost/myapp/app/controller/store/Menu.js?_dc=20160607211025

注意控制器文件夹

代替

http://localhost/myapp/app/store/Menu.js?_dc=20160607211025

一开始我认为这是我的一个项目特有的配置问题,但后来在另一个项目上得到了同样的结果。

我正在使用 ExtJs 6.02

我知道我可以使用像 MyApp.store.Menu 这样的完整类名,但是 getter 会非常难看。(这发生在我刚刚升级的巨大代码库上,因此使用完整的类名将是我的最后一个资源)。

有人遇到过这个问题吗?

4

2 回答 2

2

我找到了原因(请耐心等待):

https://docs.sencha.com/extjs/6.0/6.0.2-classic/source/Controller2.html#Ext-app-Controller

看着:

onClassExtended -> Controller.resolveNamespace -> Ext.app.getNamespace

这些是重要的,一旦命名空间被解析,就会调用处理依赖项:

Controller.processDependencies(proto, requires, namespace, 'store', data.stores);

我对此进行了研究,并且 Ext.app.getNamespace 在 ext 5 和 6 中是相同的

那么为什么它在 ExtJs 5 中

Ext.getNamespace("MyApp.controller.SomeController"); // returns MyApp

在 ExtJs 6 上

Ext.getNamespace("MyApp.controller.SomeController"); // returns MyApp.controller

原因由 console.log 找到,Ext.ClassManager.paths现在有一个新条目对应于MyApp.controller

在此处输入图像描述

以前没有 MyApp.controller (ZHT.controller) 的密钥

Ext.getNameSpace 所做的是寻找“最深的前缀”,如您在此处看到的http://docs.sencha.com/extjs/6.0/6.0.2-classic/source/Util.html#Ext-app-Util

[更新] 所以可以做的一件事是像这样覆盖静态方法resolveNamespace:

  statics: {
    resolveNamespace: function(cls, data) {
            var Controller = Ext.app.Controller,
                namespaceRe = cls.prototype.isProfile ? Controller.profileRegex : Controller.controllerRegex,
                className, namespace, match;
            /*
             * Namespace resolution is tricky business: we should know what namespace
             * this Controller descendant belongs to, or model/store/view dependency
             * resolution will be either ambiguous or plainly not possible. To avoid
             * guessing games we try to look for a forward hint ($namespace) that
             * Application class sets when its onClassExtended gets processed; if that
             * fails we try to deduce namespace from class name.
             *
             * Note that for Ext.app.Application, Controller.onClassExtended gets executed
             * *before* Application.onClassExtended so we have to delay namespace handling
             * until after Application.onClassExtended kicks in, hence it is done in this hook.
             */
            className = Ext.getClassName(cls);
            namespace = data.$namespace || data.namespace ||
                Ext.app.getNamespace(className) ||
                ((match = namespaceRe.exec(className)) && match[1]);

            //<debug>
            if (!namespace) {
                Ext.log.warn("Missing namespace for " + className + ", please define it "+
                    "in namespaces property of your Application class.");
            }
            //</debug>


            //This is the only change on this override.
            //http://stackoverflow.com/questions/37731213/extjs-6-stores-config-on-ext-app-controller-not-working/37733261#37733261
            if(namespace && namespace.indexOf(".controller") > -1) {
                namespace = namespace.slice(0, namespace.indexOf(".controller"));
            }

            return namespace;
        }
  }

如果您知道更好的解决方案,请告诉我!

于 2016-06-09T18:08:27.253 回答
0

我遇到过类似的问题,解决这个问题的方法是将我的应用程序需要的所有商店添加storesapp/Application.js.

于 2016-06-09T16:33:38.337 回答