- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的问题是:如何根据登录用户允许不同的 GWT 视觉主题?我想决定在客户登录时使用哪个主题(即在加载 GWT 应用程序之前,所以我很确定这应该是可能的)。我试图使用基于自定义属性的类替换,但失败了,因为只有最后继承的模块的图像集变得可见,即使我可以选择正确的 css 文件......我到处搜索但找不到答案!
最佳答案
感谢 Thomas 的建议,但此解决方案的问题在于您假设 CSS 样式表可供我添加到 ClientBundle(我试过了,但除非您将 css 文件和随附的图片复制到您的项目,你不能那样做)。主题来自外部 GWT 模块。为了模块化,我想保持这种方式(每次我们需要一个新主题时,将一大堆资源导入我的项目会很痛苦)。
我想到的解决方法是在运行时自己编写注入(inject)代码(只需在 HTML 头部注入(inject)一个链接标记)。为了完整起见,这里是执行此操作的代码:
protected void doInjection(String cssFilePath) {
// <link type="text/css" rel="stylesheet" href="sol.css">
Element headEl = Document.get().getElementsByTagName("head").getItem(0);
HeadElement head = HeadElement.as(headEl);
LinkElement link = Document.get().createLinkElement();
link.setType("text/css");
link.setRel("stylesheet");
link.setHref(GWT.getModuleBaseURL() + cssFilePath);
head.appendChild(link);
}
然后你用这样的东西调用这个方法:
doInjection("gwt/standard/standard.css");
然后,从项目的 GWT 模块文件中继承所有 Resources 模块。例如:
<inherits name='com.google.gwt.user.theme.standard.StandardResources'/>
<inherits name='com.google.gwt.user.theme.dark.DarkResources'/>
继承模块的 *Resources 版本避免自动注入(inject)样式表。
为了决定使用哪个主题,我在模块文件中创建了一个自定义的 GWT 属性,根据这个属性的值,我用一个不同的 Java 类 (如果应该使用不同的主题,则默认类的子类)。这有额外的好处,我可以在每个主题中包含我自己的 ResourceBundle 资源,因为与主题一起使用的替换 Java 类除了注入(inject)正确的 css 文件外,还可以为我的 GWT 代码提供替代资源。
编辑
我想添加一个重要说明:上述解决方案效果很好。但是,如果您的应用程序使用不同的 Locales 或其他 GWT 属性,这种方法可能会导致编译排列的数量激增!只有 6 种不同的主题和 3 种不同的语言环境,在您通常拥有的标准 6 种不同浏览器版本之上,GWT 编译器将创建 6 x 3 x 6 = 108 种不同的编译!!这太疯狂了!!
我最终决定采用的更好的解决方案是在用户登录后在 HttpSession 中设置一个属性,然后根据该属性的值加载适当的 css 文件(onModuleLoad 中的第一件事() 我的入口类)。与上述解决方案的唯一区别在于您如何选择主题。
关于gwt - 允许不同用户使用不同的 GWT 视觉主题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7960685/
我想知道 GWT、GWT-RPC、EXT-GWT 和 Smart GWT 之间的区别。目前,我设法借了有关 GWT 的书籍,据我所知,它只是一个旨在促进快速高效的 Ajax(异步 JavaScript
不,这不是问如何让 Guava 在 GWT 中工作,因为我已经让它工作了。 我的问题是,当我执行继承时 我希望在命名空间 com.google.common.collect 中找到一个文件 Coll
Ext GWT 和 GWT-Ext 之间有区别吗?因为我在浏览 Ext GWT 时看到了这个页面 http://gwt-ext.com/demo/ .有什么帮助吗? 最佳答案 ExtGWT 由开发 E
调查gwt-dispatch之后和 Google Wave I/O presentation (Best practices) ( video here ),我想知道为什么官方 GWT 版本 (2.0
我在我的应用程序中使用带有 ext 的 GWT 2.0.3。该项目不再处于积极开发状态并且已被 Smart GWT 取代。我正在为此应用程序使用 HMVC 模式。现在使用现有的 GWT 2.0.3 和
当我尝试在 Windows Vista 上为 ie 8 使用 GWT 开发模式插件时,我不断看到安装插件的提示。 运行插件后我仍然总是看到这个页面。有谁知道如何解决这样的问题? 最佳答案 看这个:Ca
我正在尝试对 GWT RPC 序列化策略进行一些背景阅读,发现 GWT 在编译后将 *.gwt.rpc 文件中的可序列化类型列入白名单。 以下是我的应用程序中生成的一个此类 .gwt.rpc 文件的摘
如果 Enum 实现了 java.io.Serializable,我无法将它序列化为 GWT。它会成功编译 GWT,但在运行时,我会感到害怕: Type 'com....security..Admin
是否有可以与 GWT 一起使用的进度条小部件,还是必须自己制作?我尝试在 google-web-toolkit-incubator、gwtupload 和 upload4gwt 中使用进度条,但没有任
由于 Javadoc 没有说明使用 com.google.gwt.core.shared.GWT 的原因,它似乎包含 com.google.gwt.core.client.GWT 的功能子集,前者存在
我必须在 gwt 中创建一个图像按钮,它使用三个图像(左侧图像、中心拉伸(stretch)图像和右侧图像)。左侧图像和右侧图像具有圆角。中心图像想要拉伸(stretch)取决于按钮标题大小.创建的 I
我正在尝试在 GWT 的垂直面板中设置 align 属性,如下所示: vpanel = new VerticalPanel(); vPanel.setHorizontalAlignment(HasHo
我想在 GWT 中添加可编辑的组合框,请告诉我解决方案? 最佳答案 试试 Advanced GWT Components , 具体来说 org.gwt.advanced.client.ui.widge
我在使用 GWT Designer 配置 GXT 时遇到问题。我拥有 Eclipse、GWT 插件和 GXT 的所有新版本,但无法将 GXT 配置为与 GWT Designer 一起使用。我设置了我的
我们有一个当前使用 Capistrano 部署的应用程序。该应用程序使用 php 作为后端,使用 GWT 作为前端。 我已经设法通过 Ant 文件编译 GWT,但想用自定义 Capistrano 任务
这应该很简单,但不知何故我找不到在 GWT 中创建简单超链接的方法。基本上,我想在用户点击某些东西时加载另一个页面。 Hyperlink似乎仅指向内部 GWT 应用程序状态。我想我可以把链接放在 HT
在 GWT 界面中哪个更好,使用带有 javacode 的普通 MVP,还是 UiBinder?从性能、编辑、简单性方面。 最佳答案 这就是Google says : Besides being a
GWT 2.5.0 开发模式 我在下面对文件上传做了一个简单的测试, startupUrl: http://127.0.0.1:8888/UploadTest.html?gwt.codesvr=127
我需要创建一个SuggestBox,在按下时将显示所有选项 Enter键。 我已经写了以下实现,看来是 工作正常。 我希望有人审查我的实现情况,并让我知道 在任何特定情况下都会引起问题。 另外,要传递
在哪里可以找到有关 GWT 和 GWT-Ext 延迟加载的更多信息? 最佳答案 快速谷歌搜索显示 nice blog entry由 GWT 团队提供。 关于 GWT-Ext,我无话可说,但无论采用何种
我是一名优秀的程序员,十分优秀!