13

我们有一个共享项目的解决方案,该项目被其他两个项目引用。

在共享项目中,我们有resx文件,但我们注意到Designer.cs在 resx 中添加或修改术语时,代码隐藏文件没有更新。显然,共享项目不支持为嵌入式资源生成自定义工具 (ResXFileCodeGenerator)。

我一直在寻找很长一段时间来克服这个限制。我尝试使用所有资源文件创建一个类库,但后来我偶然发现了无法在共享项目中添加对该类库的引用的问题。

有谁知道我该如何解决这个问题?在类库中拥有资源文件,并且能够在我们共享的项目视图中使用它们?

--

除了上面的问题,resx当我们自己在Designer.cs文件中添加代码时,我们可以让文件在项目上工作,但看起来仍然存在一些问题。

例如,在视图中,我们可以通过命名空间和术语名称获取翻译,但在 IDE 中它们显示为红色(不可解析)。但是,如果我们运行应用程序,它会正常工作。

更新:resx在运行应用程序时,我能够在我的视图中显示一个单独项目中的文件的翻译。但是,在视图所在的共享项目中,我对resx文件的引用仍显示为红色。这可能是因为共享项目没有对翻译项目的引用。一旦构建,具有参考的“真实”项目可以找到resx翻译,因此在运行应用程序时没有问题。

有什么方法可以告诉 Visual Studio 我的共享项目使用resx来自单独的类库的文件,以便它找到术语并且不会在我的引用下划线?让智能感知工作会很好。


根据评论中的要求,请参阅我的视图/Html 代码片段:

@using System.Configuration
@{
    ViewBag.Title = "ManageCategories";
}
<div class="main container-fluid">
<div id="spis-categories" ng-controller="categoriesController as categoriesVm" ng-cloak ng-init="categoriesVm.siteName='@ConfigurationManager.AppSettings["siteName"]';categoriesVm.pageSize = @inConnexion.Common.Constants.Constants.PageSize">
<div class="modal cust-modal-ontop" tabindex="-1" role="dialog" id="confirmDeleteDialog" data-backdrop="static" data-keyboard="false">
    <div class="modal-dialog cust-modal-dialog">
        <div class="modal-content cust-modal-content">
            <div class="modal-header">
                <h4 class="modal-title">@CategoryResources.SPIS_Categories_Maintenance.Button_Delete</h4>
            </div>
            <div class="modal-body">
                <p>@CategoryResources.SPIS_Categories_Maintenance.Confirm_Delete</p>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-default" ng-click="categoriesVm.doDeleteSelected();"><span class="glyphicon glyphicon-ok" aria-hidden="true"></span>&nbsp;@CategoryResources.SPIS_Categories_Maintenance.Label_Yes</button>
                <button type="button" class="btn btn-default" ng-click="categoriesVm.cancelDeleteSelected();"><span class="glyphicon glyphicon-remove" aria-hidden="true"></span>&nbsp;@CategoryResources.SPIS_Categories_Maintenance.Label_No</button>
            </div>
        </div>
    </div>
</div>

然后查看此屏幕截图,其中无法识别引用:

未找到参考资料

另请注意,也无法识别 ViewBag。但是在运行时,一切都按预期工作......

4

3 回答 3

2

可能只是设计视图中的命名空间问题。在文件中包含资源的命名空间Views/web.config。视图将使用其中包含的命名空间来解析类型。

视图/web.config

<pages pageBaseType="System.Web.Mvc.WebViewPage">
  <namespaces>
    <add namespace="System.Web.Mvc" />
    <add namespace="System.Web.Mvc.Ajax" />
    <add namespace="System.Web.Mvc.Html" />
    <add namespace="System.Web.Optimization"/>
    <add namespace="System.Web.Routing" />
    <add namespace="System.Net.Http" />
    <add namespace="{Resources name space here}" />
    <!-- You could also include System.Configuration to avoid having to use using -->
    <add namespace="System.Configuration" />
  </namespaces>
</pages>
于 2017-09-12T12:55:14.197 回答
2

这对我使用 Visual Studio 2015 有效,请尝试以下操作:

  1. 不要将您的共享资源命名为“Resources.resx”或“Resource.resx”,因为这会导致冲突。使用类似“Strings.resx”或“Translation.resx”的东西。

  2. 在设计器中打开 resx 文件时,确保访问修饰符是公开的:

资源访问修饰符

  1. 在您的项目中添加引用并在您的 Views/web.config 中引用命名空间,如@Nkosi 的回答中所述。
于 2017-09-12T13:03:59.423 回答
0

我能够制作一个共享资源 .resx 文件,该文件对其他每个项目和共享项目都是可见的。在弄清楚这一点之后,我遇到了这个提供详细信息的问题: Share Resource Files Across Projects。正如查理在第二个答案中指出的那样,重要的一点是,在获取共享资源的每个项目的 .csproj 文件中,必须调整链接的 .resx 文件的逻辑名称,以便设计器文件可以在部件。我创建了一个测试文件集来说明这一点 - 这里列出的代码太多,但如果有人感兴趣,它在 github 上。我不知道是否可以发布到存储库的链接,所以我会忽略它。

于 2018-09-13T05:26:04.700 回答