- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习 Vaadin 7,我正在阅读 Vaadin 7 CookBook
。其实我已经在第4章了,请问有人遇到过这样的问题吗:
我在浏览器控制台中收到以下错误:
SEVERE: Server sent Vaadin 6 style updates for ChromaHashPasswordFieldConnector (3) but this is not a Vaadin 6 Paintable
当我渲染此 UI 时:
public class ChromaHashUI extends UI {
@WebServlet(value = "/*", asyncSupported = true)
@VaadinServletConfiguration(productionMode = false, ui = ChromaHashUI.class, widgetset = "com.example.chromahash.widget.Chapter_4___custom_widgets___creating_a_chroma_hash_password_fieldWidgetset")
public static class Servlet extends VaadinServlet {
}
@Override
protected void init(VaadinRequest request) {
VerticalLayout layout = new VerticalLayout();
layout.setMargin(true);
layout.setSpacing(true);
setContent(layout);
layout.addComponents(new ChromaHashPasswordField(), new ChromaHashPasswordField());
}
}
这两个 ChromaHashPasswordField
组件是基于自定义 GWT 的小部件,代码如下:
ChromaHashPasswordField 服务器端组件:
public class ChromaHashPasswordField extends com.vaadin.ui.PasswordField {
public ChromaHashPasswordField() {
}
@Override
public ChromaHashPasswordFieldState getState() {
return (ChromaHashPasswordFieldState) super.getState();
}
@Override
public String getValue() {
return super.getValue();
}
@Override
public void setValue(String value) {
getState().text = value;
}
}
ChromaHashPasswordFieldWidget 客户端组件:
public class ChromaHashPasswordFieldWidget extends Composite {
public static final String CLASSNAME = "chromahashpasswordfield";
private PasswordTextBox textBox = new PasswordTextBox();
private HTML chromaHashStripes = new HTML();
private HorizontalPanel panel = new HorizontalPanel();
private int numberStripes = 3;
public ChromaHashPasswordFieldWidget() {
initWidget(panel);
setStyleName(CLASSNAME);
panel.add(textBox);
panel.add(chromaHashStripes);
}
private String[] getChromaHash(String text, int numberStripes) {
String salt = "du467e4aSdfe";
text += salt;
String[] colors = new String[numberStripes];
int hash;
int part = text.length() / numberStripes;
for (int i = 0; i < numberStripes; i++) {
hash = text.substring(part * i,
(part * i) + part).hashCode();
colors[i] = "#" + intToRGB(hash);
}
return colors;
}
public String intToRGB(int i) {
String RGB = Integer.toHexString(((i >> 16) & 0xFF))
+ Integer.toHexString(((i >> 8) & 0xFF))
+ Integer.toHexString((i & 0xFF));
while (RGB.length() < 6) {
RGB += "0";
}
return RGB;
}
public void updateChromaHashStripes() {
String[] chromaHash = getChromaHash(getText(), numberStripes);
int height = 18;
int width = 6;
String htmlStripes = "<div style=\"margin: 3px;\">";
for (int i = 0; i < numberStripes; i++) {
htmlStripes += "<div style=\"background-color: "+ chromaHash[i] + ";"
+ " float: left; height: "+ height + "px;"
+ " width: "+ width +"px;\">"
+"</div>";
}
htmlStripes += "</div>";
chromaHashStripes.setPixelSize(height * 2, width * numberStripes);
chromaHashStripes.setHTML(htmlStripes);
}
public String getText() {
return textBox.getText();
}
public void setText(String text) {
textBox.setText(text);
}
public HandlerRegistration addKeyUpHandler(KeyUpHandler handler) {
return textBox.addKeyUpHandler(handler);
}
}
ChromaHashPasswordFieldState 组件的共享状态:
public class ChromaHashPasswordFieldState extends com.vaadin.shared.ui.textfield.AbstractTextFieldState {
// initializer block, overrides AbstractTextFieldState's ones
{
primaryStyleName = null;
}
}
以及 ChromaHashPasswordFieldConnector 连接器:
@Connect(ChromaHashPasswordField.class)
public class ChromaHashPasswordFieldConnector extends AbstractComponentConnector {
/**
*
*/
private static final long serialVersionUID = 1L;
public ChromaHashPasswordFieldConnector() {
getWidget().addKeyUpHandler(new KeyUpHandler() {
@Override
public void onKeyUp(KeyUpEvent event) {
getWidget().updateChromaHashStripes();
}
});
}
@Override
protected Widget createWidget() {
return GWT.create(ChromaHashPasswordFieldWidget.class);
}
@Override
public ChromaHashPasswordFieldWidget getWidget() {
return (ChromaHashPasswordFieldWidget) super.getWidget();
}
@Override
public ChromaHashPasswordFieldState getState() {
return (ChromaHashPasswordFieldState) super.getState();
}
@Override
public void onStateChanged(StateChangeEvent stateChangeEvent) {
super.onStateChanged(stateChangeEvent);
final String text = getState().text;
getWidget().setText(text);
getWidget().updateChromaHashStripes();
}
}
当我编译并运行该项目时,一切都按预期工作,正如您从以下屏幕截图中看到的:
但是控制台中出现了我上面提到的错误。这与不同的 Vaadin 版本有关吗?我可以修复此错误还是与 Vaadin/GWT 相关?
感谢您的关注!
最佳答案
您在服务器端扩展了 PasswordField
类,该类扩展了 AbstractTextField
并且 AbstractTextField
实现了 com.vaadin.ui。 LegacyComponent
接口(interface)。 LegacyComponent
可以更轻松地将 Vaadin 组件从 Vaadin 6 转换为 Vaadin 7,并且大多数核心组件都以这种方式转换。
当服务器端类实现 LegacyComponent
接口(interface)时,该类的连接器必须实现 com.vaadin.client.Paintable
接口(interface)。您看到错误消息是因为您的连接器未实现该接口(interface)。在 Paintable.updateFromUIDL
中,您应该处理来自 LegacyComponent.paintContent
的更改。
关于java - 这个错误 "SEVERE: Server sent Vaadin 6 style updates for Connector...but this is not a Vaadin 6 Paintable"在 Vaadin 7 中意味着什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28509630/
我可以同步我的 Gmail 收件箱,但发送的文件夹不起作用。 这是我的 .mbsyncrc IMAPStore martinstabenfeldt-remote Account martins
我正在尝试从 nodeJS 发送电子邮件(使用 nodemailer 库),目前我在整个邮寄过程中遇到了一些超时问题。那不是我需要帮助的问题。我确实需要帮助的问题是,当它到达日志记录部分时,成功将为空
我在 WordPress 模板中使用 Contact Form 7 插件。我创建了表单和相关的 CSS,所以一切正常。当我单击发送按钮并成功发送电子邮件时,我需要执行以下操作。表单应该消失并显示“已发
我正在从辅助角色向服务总线队列发送消息。我注意到一些消息会随机丢失。 当我调试时,我在 Send 方法之后设置了一个断点,并登录到我的 Azure 面板以检查消息队列是否增加。我发现奇怪的是,有时消息
我是网站安全的新手,目前正在尝试深入了解同源策略。虽然在 stackoverflow 和其他地方有关于 SOP 概念的非常好的帖子,但我找不到关于 chrome 和其他浏览器是否允许跨域 XHR po
我正在从官方文档中学习 Solidity,并在我创建简单硬币的练习中进行堆栈: pragma solidity ^0.4.20; // should actually be 0.4.21 con
我们有一个需求,其中服务器需要将数据推送到各个客户端。所以我们继续使用 SSE(服务器发送事件)。我浏览了文档,但仍然不清楚这个概念。我有以下疑问: 场景 1。假设有 10 个客户。所以所有 10 个
我对 javascript/jquery 缺乏经验。我正在阅读 http://api.jquery.com/mouseover/ 的文档其中指出: The mouseover event is sen
所以我理解服务器发送事件的概念( EventSource ): 客户端通过 EventSource 连接到端点 客户端只监听从端点发送的消息 我感到困惑的是它在服务器上的工作方式。我看过不同的例子,但
我看过 here和 there尝试弄清楚服务器发送的事件是在传输级别。我还不确定。 两个消息来源都声称它们“只是 http”。然而,至少有两种方式可以解释这样的陈述。 当我第一次阅读那些文章时,我假设
我正在尝试使用 PHPMailer 在我的网站上创建联系表单。我在设置时遇到一些问题。我正在尝试使用 G-mail 作为我的 smtp 主机。我想知道是否有人可以帮助解决这个问题? 这是我的邮件代码:
我有一个大约 150 封电子邮件的文件夹,全部保存为 HTML 文件(Firefox 扩展),并且我需要捕获始终在“已发送”行中找到的年份;如下图所示。 我尝试使用 RegEx 但失败了;它根本不会打
我正在 Swift 中基于 NSObject 开发自定义类。它是一个状态菜单图标/菜单助手。当我收到在自定义类中单击图标的事件时,我想以 NSButton 允许创建 IBAction 来响应用户单击按
我尝试使用 MPI 对矩阵求和来执行此操作,我不知道为什么,但我无法使用 MPI_Send 发送任何类型的数据,但无论我在尝试什么我会收到一条错误消息吗: Sending 3 rows to task
我正在开发一个简单的收件箱/下午系统,我不明白为什么,但我可以显示已发送消息的显示,我可以显示已发送项目的列表,从收件箱查看下午消息,但不能确定我做错了什么,任何提示表示赞赏.. 这是我的代码:
我正在尝试在内容脚本和扩展程序之间传递消息 这是我在内容脚本中的内容 chrome.runtime.sendMessage({type: "getUrls"}, function(response)
我正在尝试将一段分成几个词。我手边有可爱的 nltk.tokenize.word_tokenize(sent),但是 help(word_tokenize) 说,“这个分词器被设计为一次处理一个句子。
我在从设备读取 SMS 消息时遇到问题。获取 URI content://sms/inbox 的内容提供者时,一切都很好。我可以阅读 person 列以在 people 表中找到外键并最终到达联系人及
我知道这个网站上有类似的问题,我已经尝试了一些建议的解决方案,其中一些对之前提出这个问题的人有效。但是,我仍然收到发送两次而不是一次的相同数据。 这是代码: final ProgressDialog
当做programmatic file upload时使用jQuery-File-Upload plugin启用分块后,我无法发送多个文件。 我调用电话的方式如下: fileUploadWidget.
我是一名优秀的程序员,十分优秀!