(1)
在我的JSF页面中想表达这样的语句:
<h:outputText id="scripthere" escape="false" value="<b>This is a text</b>" />
但是页面报错误:The value of attribute "value" associated with an element type "h:outputText" must not contain the '<' character.
查了下,这个比较好解决,办法如下:
<b><h:outputText id="scripthere" escape="false" value="This is a text" /></b>
(2)但是我要达到这样的效果就难了。
<h:outputText id="scripthere" escape="false" value="<script>alert('提示信息');</script>" />
我也用了上面的那个办法,但是还是报那个错误。至今还没有找到办法....
找到了办法:
<script>
<h:outputText id="scripthere" value="alert('提示信息')"/>
</script>
这样每行每行写就不会全部飘红了。(注意这里的id,其实在后面已经验证了这里不要id)
其实我最终的目的不是这样写的,
最终目的写法:
<script>
<h:outputText id="scripthere" value="#{publishTemplate.script}"/>;
</script>
这样写也没有达到我要的效果,因为页面重新加载一次就使得我private String script;这个为空(这里为空的原因在后面也说了是因为按钮的原因我这里用的是ajax4jsf的,在后面也改成普通的按钮,以便点击后来刷新整个页面)
public String getScript() {
System.out.println("getscript="+script);
return script;
}
public void setScript(String script) {
System.out.println("setscript="+script);
this.script = script;
}
我在判断没有目录的时候会设置它的值:
else{
System.out.println("must be publish template at first !");
this.setScript("alert('提示信息');");
}
但是当页面重新加载一次我就得不到它的值了。所以可能这种方法行不通啦 !!!
最后实在没办法了,就把那个script属性设置成static,这时候就弹出对话框来了,因为很难看它当页面还没有加载完的时候就弹出对话框把整个屏幕都全笼罩了,所以修改template.xhtml里面的那段代码:
<script>
window.onload = new Function("<h:outputText value="#{publishTemplate.script}"/>");
</script>
这样修改就好看些了。
但是当用已经存在的目录来操作时,因为它是static所以达不到效果,所以最后放弃这种方式。
哈哈,上面的情况总得不到值是因为我的按钮的问题,我原来用的是:
<a:commandButton value="Publish" action="#{publishTemplate.publishOneDirectory()}" rendered="#{templateBean.select}" />
xmlns:a="http://richfaces.org/a4j"
这里是ajax4jsf的按钮,a 是ajax的功能 它提交执行后 不再重绘整个页面
,重绘整个页面时它会去bean里取的。所有改成h:commandButton了。这样在后台就可以得到值,但是在前台还是没有得到。待解决中...
最终的解决办法找到啦!!!
完整的代码如下:
(1)类:
private String script;
public String getScript() {
return script;
}
public void setScript(String script) {
this.script = script;
}
public void publishOneDirectory(){
if(localFilePath != null && flag == true){
//这里的代码省略了
}else{
this.setScript("alert('must be publish template at first !');");
}
}
(2)页面中:这outputText里面的id已经去掉啦,不去掉会报错。
<script>
window.onload = new Function(" <h:outputText value="#{publishTemplate.script}"/> ");
</script>
<h:commandButton value="Publish" action="#{publishTemplate.publishOneDirectory()}" rendered="#{templateBean.select}" />
分享到:
相关推荐
标题“h:outputText 使用css 换行1”描述了一个通过CSS实现文本换行的解决方案,主要针对JSF中的`<h:outputText>`标签。 `<h:outputText>`是JavaServer Faces (JSF)框架中用于显示静态或动态文本的组件。它通常用于...
jsf和jpa 期末大作业 ... <h:outputText value="删除"></h:outputText> <f:param name="p_id" value="#{person.id}"/> </h:outputLink> </h:column> </h:dataTable> </h:form> </f:view>
"></h:outputText>如果需要显示后台bean的属性值,可以这样:<h:outputText value="#{backBean.welcomeMessage}"></h:outputText>这里的`welcomeMessage`是后台bean的一个属性。 6. 标签<h:messages>用于显示验证...
- `h:outputText` 用于显示文本,可以绑定到Bean的属性。 ```html <h:outputText value="#{bean.name}"/> ``` 对应的HTML是: ```html terry ``` - `h:outputLabel` 用于创建标签,与输入组件配合使用,...
`<h:outputText>`主要用于显示静态文本,因此如果需要更新的内容不仅仅是静态文本,则可能需要使用其他组件如`<h:outputLabel>`或`<h:outputText>`结合其他JSF组件来实现动态内容的更新。 **总结** 通过以上介绍,...
<h:outputText value="#{bean.outputDate}"> <f:convertDateTime pattern="yyyy 年 MM 月 dd 日"/> </h:outputText> ``` converter converter标签用于调用指定的JSF Converter实现,对JSF组件的输入输出值进行...
对于可编辑的列,可以使用`<h:inputText>`替换`<h:outputText>`。 5. **编辑模式**:为了实现单行编辑,通常需要一个触发编辑状态的机制,如点击行或单元格。这可以通过添加一个`<h:commandLink>`或`<h:...
- **`<h:outputLink>`**:用于创建超链接,可通过`value`属性指定链接地址,通过嵌套的`<h:outputText>`组件来设置链接文本。还可以通过`<f:param>`标签添加URL参数。 示例代码: ```xml <h:outputLink value=...
在JavaScript Server Faces (JSF) 中,控件是构建用户界面的关键组成部分,它们允许开发者创建交互式的Web应用程序。本文将深入探讨JSF中的一些常见控件及其使用方法,旨在帮助开发者更好地理解和应用这些控件。 1....
以上代码展示了如何使用MyFaces标签库中的`<h:outputText>`, `<h:inputText>`, `<h:message>`和`<h:commandButton>`等标签创建一个简单的登录表单。`#{bean.userName}`和`#{bean.password}`通过表达式绑定到后端Bean...
<h:outputText value="This panel is called using Component Control Component"></h:outputText> <h:outputText value="Closure link (X) works also through Component Control"></h:outputText> </rich...
通过使用Express Language 3(Java EE 7的一部分),多个属性也可以通过EL表达式直接定义。 <h:outputText value="Something" > <f:passThroughAttributes value="{"one":1, "two":2, "three":3}" /> </h:...
<h:outputText value="This panel is called using Component Control Component"></h:outputText> <h:outputText value="Closure link (X) works also through Component Control"></h:outputText> ...
<h:outputText value="Content for Tab 2"/> </p:tab> </p:tabView> ``` 这个例子展示了如何使用 `<p:tabView>` 创建两个标签页,并为每个标签页添加内容。 #### 五、更多组件介绍 除了上述介绍的一些基础组件...
在JSF中,处理表格通常使用`<h:dataTable>`标签,它可以轻松地展示数据集。例如: ```xml <h:dataTable value="#{bean.data}" var="item"> <h:column> <f:facet name="header">标题</f:facet> #{item.column...
3. `<h:outputFormat>`:格式化输出文本,支持参数化,可以与`<f:param>`配合使用。 4. `<h:outputText>`:简单地显示绑定的值。 **输入类标签**: 1. `<h:inputText>`:生成单行文本输入框,`type`属性默认为`...
例如,`<h:outputFormat>`可以结合`<f:param>`使用,将变量插入到文本中。在上述示例中,`<h:outputFormat>`根据`messages.properties`文件中的键生成格式化的文本。 在JSF开发中,理解这些核心概念和组件对于构建...