- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在创建一项调查供用户填写,其中一项要求是实现一个进度条,该进度条会在用户回答问题时填充。
我无法完全理解的错误是列表框。如果我选择一个值,计数器就会上升,但如果我选择另一个值,计数器会再次增加,而它应该保持相同的值。
下面的基本示例:
完成百分比:0%(默认下拉列表,“选择值”作为默认值)
完成百分比:2%
完成百分比:4%(应该是 2%,因为问题已经得到解答)
这是更改处理程序的代码:
final ValueChangeHandler<Boolean> booleanChangeHandler = new ValueChangeHandler<Boolean>()
{
@Override
public void onValueChange(final ValueChangeEvent<Boolean> event)
{
Boolean value = event.getValue();
changeAnsweredQuestionTotal(String.valueOf(value));
}
};
这会改变进度条。我还用它来检查文本框是否已填写。
public void changeAnsweredQuestionTotal(String value)
{
//Window.alert(value);
boolean isEmpty = (value == null) || value.equalsIgnoreCase("Null") ? true : value.isEmpty();
Integer answered;
Integer totalQuestions;
String text = this.getQuestionsAnswered().getText().substring(0, 2);
text= text.replaceAll("\\s+", "");
answered = text.isEmpty() ? 0 : Integer.valueOf(text);
answered = (answered < 0) ? 0 : answered;
totalQuestions = this.getTotalQuestions().getValue().isEmpty() ? 0 : Integer.valueOf(this.getTotalQuestions().getValue());
String result;
if (isEmpty)
{
answered = answered - 1;
answered = (answered < 0) ? 0 : answered;
result = answered + " questions answered. ";
}
else
{
if (!value.equalsIgnoreCase("null"))
{
answered = answered > totalQuestions ? totalQuestions : answered + 1;
}
result = answered + " questions answered. ";
}
Integer percent = (answered*100)/totalQuestions;
percent = (percent > 100) ? 100 : percent;
}
任何帮助将不胜感激。
最佳答案
首先,我认为您的方法“changeAnsweredQuestionTotal”过于复杂,如果您决定将来使用它,则需要重构。
下面我将描述如何解决它。我确信还有其他方法。
这个想法是为答案设置一个计数器(在本例中为 Map<String,Integer>
)。键是控件名称(例如 Question1 或 Question2 ...),值可以是 0 或 1,具体取决于是否回答。
您应该有一个自定义 ValueChangeHandler
对于每个列表小部件。该处理程序将知道“源”(将用作计数器中的键),并且知道根据值更新计数器。
最后,您再创建一个处理程序、一个实例,并分配给所有列表小部件以更新进度栏。
这是自定义处理程序的代码:
public class QuestionChangeHandler<T> implements ValueChangeHandler<T>{
private String source;
private Map<String, Integer> counter;
public QuestionChangeHandler(String source, Map<String, Integer> counter) {
super();
this.source = source;
this.counter = counter;
}
@Override
public void onValueChange(ValueChangeEvent<T> event) {
T value = event.getValue();
if (value == null) {
counter.put(source, Integer.valueOf(0));
} else {
counter.put(source, Integer.valueOf(1));
}
}
/**
* @return the source
*/
public String getSource() {
return source;
}
}
这是一个带有两个列表的小型工作应用程序:
public class AnswersApp implements EntryPoint {
private VerticalPanel mainPanel = new VerticalPanel();
private Label answersLabel = new Label("Answers");
private Label answerNumber = new Label("0");
private ValueListBox<Boolean> question1 = new ValueListBox<Boolean>(new BooleanRenderer(), new BooleanKeyProvider());
private ValueListBox<Boolean> question2 = new ValueListBox<Boolean>(new BooleanRenderer(), new BooleanKeyProvider());
private ValueChangeHandler<Boolean> updateHandler;
private HashMap<String, Integer> counter = new HashMap<String, Integer>();
public void onModuleLoad() {
initUpdateHandler();
List<Boolean> values = new ArrayList<Boolean>();
values.add(Boolean.TRUE);
values.add(Boolean.FALSE);
question1.setAcceptableValues(values);
question2.setAcceptableValues(values);
question1.addValueChangeHandler(new QuestionChangeHandler<Boolean>("q1", counter));
question2.addValueChangeHandler(new QuestionChangeHandler<Boolean>("q2", counter));
question1.addValueChangeHandler(updateHandler);
question2.addValueChangeHandler(updateHandler);
mainPanel.add(question1);
mainPanel.add(question2);
mainPanel.add(answersLabel);
mainPanel.add(answerNumber);
RootPanel.get().add(mainPanel);
}
private void initUpdateHandler() {
updateHandler = new ValueChangeHandler<Boolean>() {
@Override
public void onValueChange(ValueChangeEvent<Boolean> event) {
recalculateAnswers();
}
};
}
private void recalculateAnswers() {
Set<String> keys = counter.keySet();
int answers = 0;
for (String key : keys) {
Integer value = counter.get(key);
if (value != null && value.intValue() == 1) {
answers++;
}
}
answerNumber.setText(Integer.toString(answers));
}
}
这里的结果是答案的数量,我相信您可以从那里继续。
关于java - 检查 GWT 中是否回答了 ValueListBoxes,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10000564/
我想知道 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,我无话可说,但无论采用何种
我是一名优秀的程序员,十分优秀!