Orbeon Forms中的字段只读行为存在问题。我们通常在绑定定义中写条件来告诉字段应该只读取,所以当条件满足时,表单上的字段(HTML浏览器)将不可编辑。
但是,在该字段的HTML页面源中,我们看到该字段保持属性disabled =“disabled”但不是readonly =“readonly”。由于属性disabled =“disabled”,输入字段中的数据将以灰色显示( IE浏览器,窗口默认外观),并且看起来模糊/暗淡,因此无法正确查看。 此外,我们无法通过禁用字段的css属性更改输入数据的颜色,但我们可以对具有属性readonly =“readonly”的字段进行更改。
所以问题是当我们在Orbeon代码中的绑定定义中说readonly =“true”时,是否有可能为HTML浏览器上的字段获取readonly =“readonly”而不是disabled =“disabled”的属性
示例Orbeon代码和HTML页面源快照在
下面<xhtml:html xmlns:xforms="http://www.w3.org/2002/xforms"
xmlns:f="http://orbeon.org/oxf/xml/formatting"
xmlns:xhtml="http://www.w3.org/1999/xhtml"
xmlns:xxforms="http://orbeon.org/oxf/xml/xforms"
xmlns:ev="http://www.w3.org/2001/xml-events"
xmlns:xsd="http://www.w3.org/2001/XMLSchema"
>
<xhtml:head>
<xforms:model xmlns:xforms="http://www.w3.org/2002/xforms"
xmlns:xs="http://www.w3.org/2001/XMLSchema" id="main-model">
<xforms:instance id="form-instance">
<form>
<field-1></field-1>
<field-2></field-2>
<field-3></field-3>
</form>
</xforms:instance>
<xforms:instance id="form-attributes">
<attributes>
<summary>false</summary>
</attributes>
</xforms:instance>
<xforms:bind id="summary" nodeset="instance('form-attributes')/summary" />
<xxforms:variable name="summary" select="instance('form-attributes')/summary" />
<xforms:bind nodeset="instance('form-instance')" readonly="$summary='true'" />
<xforms:bind id="field-1" nodeset="instance('form-instance')/field-1" />
<xforms:bind id="field-2" nodeset="instance('form-instance')/field-2" />
<xforms:bind id="field-3" nodeset="instance('form-instance')/field-3" />
</xforms:model>
</xhtml:head>
<xhtml:body>
<table>
<tr>
<td>
<xforms:trigger appearance="minimal" id="readonly-view">
<xforms:label>Readonly View</xforms:label>
<xforms:action ev:event="DOMActivate">
<xforms:setvalue bind="summary" value="'true'" />
</xforms:action>
</xforms:trigger>
</td>
<td>
<xforms:trigger appearance="minimal" id="editable-view">
<xforms:label>Editable View</xforms:label>
<xforms:action ev:event="DOMActivate">
<xforms:setvalue bind="summary" value="'false'" />
</xforms:action>
</xforms:trigger>
</td>
</tr>
<tr>
<td>
Field 1:
</td>
<td>
<xforms:input bind="field-1" id="field-1-id" xxforms:maxlength="10" />
</td>
</tr>
<tr>
<td>
Field 2:
</td>
<td>
<xforms:input bind="field-2" id="field-2-id" xxforms:maxlength="10" />
</td>
</tr>
<tr>
<td>
Field 3:
</td>
<td>
<xforms:input bind="field-3" id="field-3-id" xxforms:maxlength="10" />
</td>
</tr>
</table>
</xhtml:body>
</xhtml:html>
快照HTML页面源代码:
答案 0 :(得分:0)
此时,正如您所注意到的,Orbeon Forms在只读表单字段上生成disabled="disabled"
,而不是readonly="readonly"
,如果不更改Orbeon表单,则无法更改。
问题的一个可能解决方案是使用static appearance for read-only controls,它只显示字段的值,方式与xf:output
的方式类似,而不是只读表单字段。这通常非常有用,可以非常轻松地创建审核页面,您可以在提交用户之前向用户显示所有输入的值。