我正在将 Extjs 升级到 5.0.1 (从5.0.0开始)以及 Sencha Cmd 到 5.0.1.231
没有编译时错误,但在运行时没有加载应用程序并给出以下错误
Uncaught TypeError: Cannot read property 'baseUrl' of undefined
其他一些用户遇到了同样的问题..
http://www.sencha.com/forum/showthread.php?289872-After-update-to-5.0.1&p=1059537
这是一个错误还是我们做了一些不同的事情?
由于
答案 0 :(得分:3)
它看起来像一个bug,但我认为Sencha正在推动使用microloader,而不仅仅是包含app.js文件和css文件。所以我的简短回答是两者! :)
现在是长篇:
我正在玩设置一个ExtJS应用程序,该应用程序远离webroot,同时在开发和生产模式(环境)中都可用。
设置Sencha CMD应用的 app.json ,以便 microloader.js 加载所需的js和css文件,这证明是一个挑战。< / p>
我的文件夹设置如下: (注意,我的构建文件夹位于Sencha CMD应用程序文件夹之外 - MyApp - 只是为了拥有相同的路径深度)
index.cfm
/far/away/from/web/root
....
/build
/resources
app.js
app.json
microloader.js
...
/MyApp
/.sencha
/ext
app.json
app.js
bootstrap.js
....
<强> MyApp的/ app.json 强>
{
/**
* The application's namespace.
*/
"name": "MyApp",
/**
* The relative path to the appliaction's markup file (html, jsp, asp, etc.)
*
* Below setting seems relevant for proper loading MyApp/bootstrap.js
*/
"indexHtmlPath": "../../../../../index.cfm",
......
"output": {
"base": "${workspace.build.dir}",
"page": {
/**
* Below is relative path from the build folder to the application markup file
*/
"path": "../../../../../index.cfm",
"enable": false
},
"microloader": {
"path": "microloader.js",
"embed": false,
"enable": true
},
"manifest": {
"path": "app.json",
"embed": false,
"enable": "${app.output.microloader.enable}"
}
},
/**
* Uniquely generated id for this application, used as prefix for localStorage keys.
* Normally you should never change this value.
*/
"id": "f6cd3e2b-6a0c-4359-a452-e07adda808ae"
}
最初,为了使用生产版本,直接加载 /far/away/from/web/root/build/app.js 文件,它会抛出同样的错误:
Uncaught TypeError: Cannot read property 'baseUrl' of undefined
现在,按照上面的配置 app.json ,我可以选择 index.cfm 是否加载:
for production - /far/away/from/web/root/build/microloader.js
for development - /far/away/from/web/root/MyApp/bootstrap.js
我希望这有助于某人。
干杯, Pencho