我将帐户注册到oracle.com网站,我看到一些非常有趣的东西:
在表格中查看电话号码的输入字段。我如何将其重现为JSF输入表单?这是由CSS制作的吗?
代码更新
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html">
<h:head>
<script type="text/javascript">
<!-- input field shadow -->
var placeholder = "test field"
$("input").on({
focus: function() {
if (this.value == placeholder) {
$(this).val("").removeClass("shadow");
}
},
blur: function() {
if (this.value == "") {
$(this).val(placeholder).addClass("shadow");
}
}
}).trigger("blur");
</script>
</h:head>
<h:body>
<h1>JSF 2 textbox example with shadow</h1>
<h:form>
<h:inputText value="#{userBean.userName}" />
<h:commandButton value="Submit" action="user" />
</h:form>
</h:body>
</html>
我测试了这段代码,但它没有用。也许我需要将JavaScript代码作为函数调用到<h:inputText>
标记中?
答案 0 :(得分:5)
这是自HTML5以来的新功能。它是placeholder
属性,在HTML5时代之前也被称为“水印”。
<input type="text" name="phone" placeholder="e.g. +994 (12) 491 2345" />
这当然仅适用于支持HTML5的浏览器。使用JSF时,这仅适用于支持新HTML5 placeholder
属性的JSF组件。标准JSF <h:inputText>
本身不支持此功能。您需要寻找支持此功能的第三方组件库。其中包括PrimeFaces及其<p:watermark>
组件:
<h:inputText id="phone" value="#{register.user.phone}" />
<p:watermark for="phone" value="e.g. +994 (12) 491 2345" />
这将检查是否支持HTML5,然后使用placeholder
,否则它将引入一些JS / jQuery魔法来模拟相同的。这一切都不是由CSS完成的。
如果由于某些原因使用PrimeFaces不是一个选项,你需要自己重新发明它自定义组件和/或自定义JS / jQuery的味道,就像<p:watermark>
正在做的那样覆盖。
答案 1 :(得分:2)
我认为他们正在使用jquery的水印来做到这一点。附件是该页面的萤火虫视图,显示
答案 2 :(得分:2)
如果您无法使用PrimeFaces,@BalusC stated,您可以使用这样的JavaScript / jQuery代码:
var placeholder = "e.g. +358 (11) 123-45-67"
$("input").on({
focus: function() {
if (this.value == placeholder) {
$(this).val("").removeClass("shadow");
}
},
blur: function() {
if (this.value == "") {
$(this).val(placeholder).addClass("shadow");
}
}
}).trigger("blur");
CSS类shadow
的字体为color: #bbb
。