使用class属性而不是JSF组件的styleClass实际上有效,为什么?

时间:2015-01-07 08:54:09

标签: class jsf jsf-2 attributes

据我所知,我们需要使用styleClass=,因为JSF组件不支持仅使用class=

我最近注意到一些使用class=的组件仍然正确呈现。作为一个最小的例子,

<?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>
        <title>Simple JSF Facelets page</title>
    </h:head>

    <h:body>
       <h:inputText class="wut" anothertag="hi" value="me"/>
    </h:body>

</html>

这会产生

<?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">
    <head>
        <link type="text/css" rel="stylesheet" href="/individuallifefaz/javax.faces.resource/theme.css.xhtml?ln=primefaces-aristo"/>
        <title>Simple JSF Facelets page</title></head>
    <body>
        <input type="text" name="j_idt5" value="me" class="wut"/>
    </body>

</html>

为什么这样有效?它显然不仅仅是通过任何未知的标签,因为anothertag被剥离了。

1 个答案:

答案 0 :(得分:8)

这实际上是由视图技术Facelets完成的,而不是由JSF组件本身完成的。 Facelets的class属性alias会自动映射到styleClass。这是作为jsfc属性的支持的一部分实现的,如在#34;设计师友好的Facelets&#34;应该可以做到这样的事情:

<input type="text" jsfc="h:inputText" class="foo" />

如果你使用不同的视图技术使用JSF(尽管到目前为止还没有一个是Facelets的一个重要替代品,并且不推荐使用JSP),那么<h:inputText class>无法保证会工作的。

另见: