Specification: iscontent
iscontent Element
Modify the HTTP header (set the content type) of the generated output stream sent to the browser or email client. The HTTP header is identified by its MIME type.
Syntax
<iscontent
type="${MIME_type}"
charset="${char_set}"
encoding="on"
compact="true"
/>
type
Allowed data type: string or expression.
type
specifies the MIME type of the generated output stream. If no type is specified, the type
is set to text/html
. Generally, storefront pages and email output are set to text/html
.Use an expression for dynamic content types. You can set the encoding explicitly using the charset
attribute, or determine it implicitly from the content type.
<blockquote title="Note" variant="note"> <div><p>It's possible, though rarely helpful, to generate one type of content through the type command and then encode the output with a different content type. Generally, the on and off commands suffice.</p></div> </blockquote>
charset
Allowed data type: string Expressions are not allowed.
charset
defines the character set of the output stream. The default value is the default encoding of the operating system that runs the Salesforce B2C Commerce application server. The default encoding is UTF8 and shouldn't be changed, unless really necessary.
encoding
Naming a content type, for example html
, has the same affect as using the on
value and also selects the type of output. All data processed after the first occurrence of the <iscontent/>
tag is affected by this setting. Encoding converts characters that could cause a syntax conflict. For example, the ampersand symbol is converted to & in HTML encoding. The default encoding value is html
. For more information, see Encoding Expression Results in isprint.
on
turns on encoding for the output stream. This is used in combination with the charset to determine the characters in the output stream.off
turns off encoding for the output stream.html
turns on encoding and specifies html as the type of encoding. This is used in combination with the charset to determine the characters in the output stream.xml
turns on encoding and specifies xml as the type of encoding. This is used in combination with the charset to determine the characters in the output stream.wml
turns on encoding and specifies xml as the type of encoding. This is used in combination with the charset to determine the characters in the output stream.
compact
Allowed data type: boolean. Expressions are not allowed.
HTML code often contains white space that doesn't have any affect on the visual appearance of a page and is primarily used to make the code of a template easier to read. When compact is set to true, unnecessary white space is removed from the output stream. Compact is on by default. See the general examples for an example of how the compact attribute works.
Purpose
In most cases, you don't need to set the type because this is done automatically by the node or pipelet that calls the template. These nodes set the MIME header as follows:
Node/Pipelet | MIME Type Setting |
---|---|
Interaction-continue or interaction-end node | text/html |
SendMail pipelet | text/plain |
dw.net.Mail (as part of a script run by a script node) | text/plain |
If you want to overwrite these defaults, or if you want your template to generate a different type of output, you can explicitly specify another MIME type in the type attribute. See alsoSending Email via Scripts or Hooks
Additionally, the <iscontent/>
tag:
Sets the character encoding of the generated output stream
Allows HTML, XML or WML encoding for the whole template
Removes unnecessary spaces by means of the compact attribute
You can also dynamically select
<iscontent/>
settings. For example, you can use a dynamic expression to set the MIME type.
General Example
This example sets the content type and character set of the output stream:
<iscontent type="plain/text" charset="iso-8859-1" />
The following is a typical formatting of HTML code, with tabs or whitespace to make it more readable:
<table>
<tr>
<td>Some text here</td>
<td>More text here</td>
<td>text</td>
</tr>
</table>
Note Such white spaces increase the size of a file, which potentially increases the time necessary to transmit a page to the client. To optimize the output code of a template don't set compact to
false
. Because compact is set totrue
by default, you can use:
<iscontent compact="true">
or <iscontent/>
This tag ensures that all extra white space is removed during the template conversion process, for example, converting the previous code into:
<table>
<tr>
<td>Some text here</td>
<td>More text here</td>
<td>text</td>
</tr>
</table>
The template compacting feature compresses templates before transmitting them to a client's browser. The process eliminates all unnecessary white spaces and can reduce the load time at client browsers.
Compacting can't be toggled within the template. The feature isn't applied to templates included within a calling template using the <isinclude/>
tag. The statement must be used in each template that is to be compacted.
HTML statements that use formatted content, such as the <pre>
tag, might not appear properly if used in a template with compacting. If a template uses these tags, avoid using the compacting feature or use dynamic content, created with expressions, for the formatted material. For example, to keep the additional spaces in the statement:
<input type="submit" name=" Button " />
You can use:
<input type="submit" name="${' Button '}" />
To ensure that the <pre>
tag works in a compacted template:
<pre> This is formatted text .</pre>
Use an <isprint/>
statement:
<pre><isprint value="${' This is formatted text .'}"> </pre>
Dynamic Content Type Examples
The following examples shows the resulting Content-Type: HTTP header for different values of the type
and charset
attributes:
<iscontent> Usage | Resulting Content-Type | Comment |
---|---|---|
<iscontent type ="text/html" charset="ISO-8859-1" /> | text/html;charset=ISO-8859-1 | |
<iscontent type="text/html" /> | text/html;charset=UTF-8 | The charset used is the default encoding for ISML "UTF-8". |
<iscontent type="plain" /> | plain;charset=UTF-8 | The charset used is also the default encoding for ISML, "UTF-8". |
<isscript>pdict.ContentType = 'text/html';</isscript> <iscontent type="${pdict.ContentType}" charset="ISO-8859-1" /> | text/html;charset=ISO-8859-1 | |
<isscript>pdict.ContentType = 'text/html';</isscript> <iscontent type="${pdict.ContentType}" /> | text/html;charset=UTF-8 | The charset used is the default encoding for ISML, "UTF-8". |
<iscontent charset="UTF-8" /> | text/html;charset=UTF-8 | The type used is the default MIME type for ISML, "text/html". |
<iscontent compact="true" /> | text/html;charset=UTF-8 | The type used is the default MIME type for ISML, "text/html". The charset used is the default encoding for ISML pages, "UTF-8". |
Note If text of the page appears in the ISML template before the
<iscontent/>
tag, either directly or through a script containingout.print()
statements, thetype
andcharset
specified in the tag can't be guaranteed to take effect. For best results, the<iscontent/>
tag should always be first in an ISML template.