2014-04-20 72 views
0

我被困在真正好奇的错误。 我有一个挂图页面,我试图导入一个javascript文件。之前,我导入了extjs-version3.js文件(它工作完美),然后我想导入extjs-version4.js文件。所以,我从文件系统中删除了version3文件,将version4文件添加到文件系统,并更改了我的tapestry页面的java代码以导入version4文件。但我总是得到错误,“version3文件不存在”!挂毯5:试图加载JavaScript文件

在调试时,我改变了页面的Java代码,以便它现在不导入任何文件。

所以,现在我有一个页面,不导入任何JavaScript文件,我仍然得到错误,“version3文件不存在”。

以下是确切的详细信息。

MyPage.java其中导入了javascript文件。

@Import(
     library = { 
      //"context:js/lib/extjs3/adapter/ext/ext-base-debug.js", 
      //"context:js/lib/extjs3/ext-all-debug-w-comments-v4.js", 
      /*"context:js/lib/ext_compat_layer/ext3-compat.js", 
      "context:js/lib/ext_compat_layer/ext3-core-compat.js",*/ 
      //"context:js/page/ActivitiesTab.js", 
      //"context:js/lib/extjs3/ux/gridSearch/Ext.ux.grid.Search.js", 
      //"context:js/lib/extjs3/ux/gridSearch/Ext.ux.IconMenu.js", 
      //"context:js/lib/extjs3/ux/gridSearch/Ext.ux.Toast.js" 
     }, 
     stylesheet = { 
      /*"context:js/lib/extjs3/resources/css/ext-all.css", 
      "context:js/lib/extjs3/resources/css/xtheme-gray.css", 
      "context:js/lib/extjs3/resources/css/theme-gray/core.css",*/ 
      //"context:js/lib/extjs3/resources/css/icons.css", 
      //"context:js/lib/extjs3/resources/css/gridsearch.css" 
     } 
    ) 

错误的堆栈跟踪我接受。

An unexpected application exception has occurred. 

    org.apache.tapestry5.ioc.internal.OperationException 
    Unable to locate asset 'context:js/lib/extjs3/ext-all-debug-w-comments.js' (the file does not exist). 

    trace 
      Constructing instance of page class net.semandex.salsa.tapestry.pages.ActivitiesTab 

    java.lang.RuntimeException 
    Unable to locate asset 'context:js/lib/extjs3/ext-all-debug-w-comments.js' (the file does not exist). 

    Hide uninteresting stack frames Stack trace 
      org.apache.tapestry5.internal.services.AssetSourceImpl.getLocalizedAssetFromResource(AssetSourceImpl.java:135) 
      org.apache.tapestry5.internal.services.AssetSourceImpl.getAssetInLocale(AssetSourceImpl.java:105) 
      org.apache.tapestry5.internal.services.AssetSourceImpl.getAsset(AssetSourceImpl.java:85) 
      org.apache.tapestry5.internal.transform.ImportWorker$5.map(ImportWorker.java:206) 
      org.apache.tapestry5.internal.transform.ImportWorker$5.map(ImportWorker.java:203) 
      org.apache.tapestry5.func.LazyMappedValue.get(LazyMappedValue.java:31) 
      org.apache.tapestry5.func.LazyFlow.first(LazyFlow.java:52) 
      org.apache.tapestry5.func.AbstractFlow$1.next(AbstractFlow.java:68) 
      org.apache.tapestry5.func.AbstractFlow.toMutableList(AbstractFlow.java:47) 
      org.apache.tapestry5.func.AbstractFlow.toMutableList(AbstractFlow.java:40) 
      org.apache.tapestry5.func.AbstractFlow.toList(AbstractFlow.java:205) 
      org.apache.tapestry5.internal.transform.ImportWorker.convertPathsToAssets(ImportWorker.java:202) 
      org.apache.tapestry5.internal.transform.ImportWorker.access$100(ImportWorker.java:40) 
      org.apache.tapestry5.internal.transform.ImportWorker$4.advise(ImportWorker.java:190) 
      org.apache.tapestry5.internal.services.AbstractComponentMethodInvocation.proceed(AbstractComponentMethodInvocation.java:86) 
      net.semandex.salsa.tapestry.pages.ActivitiesTab.containingPageDidLoad(ActivitiesTab.java) 
      org.apache.tapestry5.internal.structure.ComponentPageElementImpl$4.run(ComponentPageElementImpl.java:120) 
      org.apache.tapestry5.internal.structure.ComponentPageElementImpl.invoke(ComponentPageElementImpl.java:977) 
      org.apache.tapestry5.internal.structure.ComponentPageElementImpl.containingPageDidLoad(ComponentPageElementImpl.java:829) 
      org.apache.tapestry5.internal.structure.PageImpl.loaded(PageImpl.java:171) 
      org.apache.tapestry5.internal.pageload.PageLoaderImpl$3.invoke(PageLoaderImpl.java:190) 
      org.apache.tapestry5.internal.pageload.PageLoaderImpl$3.invoke(PageLoaderImpl.java:174) 
      org.apache.tapestry5.ioc.internal.OperationTrackerImpl.invoke(OperationTrackerImpl.java:65) 
      org.apache.tapestry5.ioc.internal.PerThreadOperationTracker.invoke(PerThreadOperationTracker.java:68) 
      org.apache.tapestry5.ioc.internal.RegistryImpl.invoke(RegistryImpl.java:1063) 
      org.apache.tapestry5.internal.pageload.PageLoaderImpl.loadPage(PageLoaderImpl.java:173) 
      org.apache.tapestry5.internal.services.PageSourceImpl.getPage(PageSourceImpl.java:81) 
      org.apache.tapestry5.internal.services.NonPoolingRequestPageCacheImpl.get(NonPoolingRequestPageCacheImpl.java:74) 
      org.apache.tapestry5.internal.services.PageRenderRequestHandlerImpl.handle(PageRenderRequestHandlerImpl.java:55) 
      org.apache.tapestry5.services.TapestryModule$36.handle(TapestryModule.java:2326) 
      org.apache.tapestry5.internal.services.ComponentRequestHandlerTerminator.handlePageRender(ComponentRequestHandlerTerminator.java:48) 
      org.apache.tapestry5.services.InitializeActivePageName.handlePageRender(InitializeActivePageName.java:47) 
      org.apache.tapestry5.internal.services.PageRenderDispatcher.dispatch(PageRenderDispatcher.java:45) 
      org.apache.tapestry5.services.TapestryModule$RequestHandlerTerminator.service(TapestryModule.java:321) 
      net.semandex.salsa.tapestry.services.AppModule$1.service(AppModule.java:164) 
      org.apache.tapestry5.internal.services.RequestErrorFilter.service(RequestErrorFilter.java:26) 
      org.apache.tapestry5.services.TapestryModule$4.service(TapestryModule.java:984) 
      org.apache.tapestry5.services.TapestryModule$3.service(TapestryModule.java:974) 
      org.apache.tapestry5.internal.services.StaticFilesFilter.service(StaticFilesFilter.java:90) 
      org.apache.tapestry5.internal.services.URLRewriterRequestFilter.service(URLRewriterRequestFilter.java:50) 
      org.apache.tapestry5.internal.services.CheckForUpdatesFilter$2.invoke(CheckForUpdatesFilter.java:90) 
      org.apache.tapestry5.internal.services.CheckForUpdatesFilter$2.invoke(CheckForUpdatesFilter.java:80) 
      org.apache.tapestry5.ioc.internal.util.ConcurrentBarrier.withRead(ConcurrentBarrier.java:85) 
      org.apache.tapestry5.internal.services.CheckForUpdatesFilter.service(CheckForUpdatesFilter.java:103) 
      org.apache.tapestry5.services.TapestryModule$HttpServletRequestHandlerTerminator.service(TapestryModule.java:272) 
      org.apache.tapestry5.internal.gzip.GZipFilter.service(GZipFilter.java:53) 
      org.apache.tapestry5.upload.internal.services.MultipartServletRequestFilter.service(MultipartServletRequestFilter.java:44) 
      org.apache.tapestry5.internal.services.IgnoredPathsFilter.service(IgnoredPathsFilter.java:62) 
      org.apache.tapestry5.services.TapestryModule$2.service(TapestryModule.java:928) 
      org.apache.tapestry5.TapestryFilter.doFilter(TapestryFilter.java:147) 

MyPage.tml文件非常简单,没有什么可疑的,但如果需要,我可以张贴代码。

为什么tapestry试图加载一个未包含在任何页面中的js文件?

更新:

逸岸,无论我在@Import注释写的文件是根据以前的代码始终进口。所有页面都发生这种情况。

回答

0

现在解决。问题出在我的生产环境,而不是在Tapestry。当我更改它们时,Java类文件未被Eclipse更新。正因为如此,JavaScript文件是基于页面的java文件中以前的代码导入的。

Eclipse报告了以下问题。 “该项目不是由于”无法删除/ someName/bin /“而造成的。修复此问题,然后尝试刷新此项目并构建它,因为它可能不一致” 我提到了这个question并解决了我的问题。

简单的刷新,干净/发布并没有解决我的问题。我不得不关闭Eclipse并重新启动PC。这固定了我的环境,现在Eclipse正在更新Java类。

1

这可能是由模板中无法加载资源的某个组件或可能是由MyPage扩展的父模板引起的。

根据堆栈跟踪,页面net.semandex.salsa.tapestry.pages.ActivitiesTab是问题的原因。 MyPage可能将其加载到某处。

+0

实际上,ActivitiesTab是myPage,为了简单起见,我在此将其命名为myPage。加载ActivitiesTab页面本身时出现错误。 –

+0

检查我的更新问题,看来我在导入注释中更改的内容没有在Tapestry中得到更新,而且它总是试图根据旧代码加载文件。 –

+0

@PratikPatel如果您还没有尝试重新启动应用程序,则某些更改不会自动加载。如果这不起作用,请尝试清理整个项目(删除所有构建文件),以确保它不使用任何旧文件。 – Kapep