gpt4 book ai didi

java - 需要将样式标签放在 XPages 的头部,输出到 Excel

转载 作者:行者123 更新时间:2023-12-01 20:09:19 29 4
gpt4 key购买 nike

我有一个 XPage,它允许选择查询文档。其中的全文查询从数据库中搜索文档,进行一些计算并将其显示为屏幕上的 View 。屏幕上还有一个按钮,用于设置 requestScope.showExcel=true 并执行完全重新加载,以便将数据直接下载到 Excel 中(使用 .setHeader("Content-disposition", "inline; myfile.xls")。它只不过是一个带有 tr 和 td 标签的简单表格。到目前为止一切顺利。

可以为每列设置列属性(高度、宽度、颜色),这些属性存储在查询文档(这是一个单独的文档,不是搜索结果的一部分)内。这些属性被放入使用 xp:text 控件集创建的 style-tag 元素中,以创建 html 输出。

一切正常,除了一件事:Excel 和 OpenOffice 或 LibreOffice Calc 不喜欢正文中的样式部分。当我保存输出并将样式移至头部时,文件在 Excel 中加载正常。

所以我出去把我们计算的样式放在头部。我找到了 styleSheet 资源及其计算的内容参数。它确实生成了我放入的一些 CSS,但不是全部。事实证明,内容是在加载时计算的,而不是动态计算的。上面提到的按钮会完全刷新页面,这让我假设样式也会更新。

唉,没有。样式表内容似乎是固定的。

我的问题:

  • 有没有一种方法可以将内联CSS动态地放在head部分的样式部分中,以便在页面重新加载时重新计算(全面更新)?

    <
  • 是否有一些控件可以让我向头部添加任意内容?

  • 或者Java中有没有一种方法可以动态调整head部分?

感谢您的帮助!

最佳答案

只需为 header 资源创建您自己的渲染器即可:

package ch.hasselba.xpages.renderkit;

import com.ibm.commons.util.StringUtil;
import com.ibm.xsp.complex.Parameter;
import com.ibm.xsp.render.ResourceRenderer;
import com.ibm.xsp.resource.GenericHeadResource;
import com.ibm.xsp.resource.Resource;
import com.ibm.xsp.util.JSUtil;
import java.io.IOException;
import java.util.List;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.context.ResponseWriter;

public class GenericHeadResourceRenderer extends ResourceRenderer {
public void encodeResource(FacesContext fc, UIComponent uiComponent,
Resource res) throws IOException {
GenericHeadResource headRes = (GenericHeadResource) res;
ResponseWriter rw = fc.getResponseWriter();

String tagName = headRes.getTagName();
if (StringUtil.isNotEmpty(tagName)) {

rw.startElement(tagName, uiComponent);

List<Parameter> params = headRes.getAttributes();
if (params != null) {
for (Parameter param : params) {
String name = param.getName();
if (StringUtil.isNotEmpty(name)) {
String value = param.getValue();
if (value == null) {
value = "";
}
if( "content".equals( name ) ){
rw.write( value );
}else{
rw.writeAttribute(name, value, name);
}
}
}
}
rw.endElement(tagName);
JSUtil.writeln(rw);
}
}
}

要激活渲染器,您必须覆盖 faces-config.xml 中的现有渲染器:

<?xml version="1.0" encoding="UTF-8"?>
<faces-config version="1.2" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-facesconfig_1_2.xsd">

<render-kit>
<renderer>
<component-family>com.ibm.xsp.resource.Resource</component-family>
<renderer-type>com.ibm.xsp.resource.GenericHead</renderer-type>
<renderer-class>ch.hasselba.xpages.renderkit.GenericHeadResourceRenderer</renderer-class>
</renderer>
</render-kit>

</faces-config>

然后,在名为“content”的参数中添加所需的动态内容:

<?xml version="1.0" encoding="UTF-8"?>
<xp:view xmlns:xp="http://www.ibm.com/xsp/core">

<xp:this.resources>
<xp:headTag tagName="style">
<xp:this.attributes>
<xp:parameter name="type" value="text/css" />
<xp:parameter name="content"
value="#{javascript:java.lang.System.currentTimeMillis()}" />
</xp:this.attributes>
</xp:headTag>
</xp:this.resources>

</xp:view>

关于java - 需要将样式标签放在 XPages 的头部,输出到 Excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46920547/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com