Порядок, в котором связаны библиотеки, имеет значение, если библиотеки зависят друг от друга. В общем случае, если библиотека A
зависит от библиотеки B
, тогда libA
ДОЛЖЕН появляться перед libB
в флагах компоновщика.
Например:
// B.h
#ifndef B_H
#define B_H
struct B {
B(int);
int x;
};
#endif
// B.cpp
#include "B.h"
B::B(int xx) : x(xx) {}
// A.h
#include "B.h"
struct A {
A(int x);
B b;
};
// A.cpp
#include "A.h"
A::A(int x) : b(x) {}
// main.cpp
#include "A.h"
int main() {
A a(5);
return 0;
};
Создайте библиотеки:
$ g++ -c A.cpp
$ g++ -c B.cpp
$ ar rvs libA.a A.o
ar: creating libA.a
a - A.o
$ ar rvs libB.a B.o
ar: creating libB.a
a - B.o
Скомпилируйте:
$ g++ main.cpp -L. -lB -lA
./libA.a(A.o): In function `A::A(int)':
A.cpp:(.text+0x1c): undefined reference to `B::B(int)'
collect2: error: ld returned 1 exit status
$ g++ main.cpp -L. -lA -lB
$ ./a.out
Чтобы повторить снова, порядок имеет значение!
Вы можете использовать EL в атрибуте id
для компонента JSF, но переменная EL должна быть доступна во время сборки времени, тогда как дерево компонентов JSF должно быть создано. Тем не менее, <ui:repeat>
работает во время отображения времени визуализации, тогда как вывод HTML должен быть создан на основе дерева компонентов JSF. <ui:repeat var>
недоступен во время времени сборки, а #{class2.name}
- null
, что полностью объясняет полученную вами ошибку. То, что оно работает в <h:outputText>
, связано с тем, что оно выполняется во время визуализации рендеринга.
Если вы замените <ui:repeat>
на <c:forEach>
, который выполняется во время времени сборки, тогда он будет работать так, как вы намерены. <c:forEach>
будет генерировать физически несколько <h:form>
компонентов в дереве компонентов JSF, каждый из которых генерирует индивидуально свой собственный вывод HTML (в отличие от <ui:repeat>
, где один и тот же компонент <h:form>
повторно используется несколько раз для генерации HTML output).
<c:forEach var="class2" items="#{bean.list}" varStatus="status">
<h:form id="#{class2.name}">
<h:outputText value="#{class2.name}" />
</h:form>
</c:forEach>
Однако я действительно удивляюсь, зачем вам это нужно. Обычно нет необходимости динамически назначать идентификаторы компонентов. JSF уже обеспечит уникальность идентификатора. В приведенном ниже примере
<ui:repeat var="class2" value="#{bean.list}" varStatus="status">
<h:form id="form">
<h:outputText value="#{class2.name}" />
</h:form>
</ui:repeat>
будет отображаться в нескольких формах с каждым уникальным идентификатором, заполненным индексом итерации <ui:repeat>
. Если вам действительно нужно использовать #{class2.name}
для некоторых целей JavaScript / jQuery (вы нигде не указали конкретное функциональное требование в вопросе, для которого вы думали, что это будет правильное решение, так что это просто догадки), а затем просто оберните его простой HTML-элемент ванили:
<ui:repeat var="class2" value="#{bean.list}" varStatus="status">
<div id="#{class2.name}">
<h:form id="form">
<h:outputText value="#{class2.name}" />
</h:form>
</div>
</ui:repeat>
Или задайте его как класс стилей компонента JSF, который также можно выбрать с помощью селектора CSS:
<ui:repeat var="class2" value="#{bean.list}" varStatus="status">
<h:form id="form" styleClass="#{class2.name}">
<h:outputText value="#{class2.name}" />
</h:form>
</ui:repeat>