CherryPy Tutorial on CherryPy Presentation Layer

the presentation layer ensures that the communication passing through it targets the intended recipients. cherrypy maintains the working of presentation layer by various template engines.

a template engine takes the input of the page with the help of business logic and then processes it to the final page which targets only the intended audience.

kid — the template engine

kid is a simple template engine which includes the name of the template to be processed (which is mandatory) and input of the data to be passed when the template is rendered.

on creation of the template for the first time, kid creates a python module which can be served as a cached version of the template.

the kid.template function returns an instance of the template class which can be used to render the output content.

the template class provides the following set of commands −

s.no command & description
1.

serialize

it returns the output content as a string.

2.

generate

it returns the output content as an iterator.

3.

write

it dumps the output content into a file object.

the parameters used by these commands are as follows −

s.no command & description
1.

encoding

it informs how to encode the output content

2.

fragment

it is a boolean value which tells to xml prolog or doctype

3.

output

this type of serialization is used to render the content

example

let us take an example to understand how kid works −

<!doctype html public "-//w3c//dtd html 4.01//en" "http://www.w3.org/tr/html4/strict.dtd">
<html xmlns:py = "http://purl.org/kid/ns#">
   <head>
      <title>${title}</title>
      <link rel = "stylesheet" href = "style.css" />
   </head>
	
   <body> 
      <p>${message}</p>
   </body>
</html>

the next step after saving the file is to process the template via the kid engine.

import kid

params = {'title': 'hello world!!', 'message': 'cherrypy.'}
t = kid.template('helloworld.kid', **params)
print t.serialize(output='html')

kid's attributes

the following are the attributes of kid −

xml-based templating language

it is an xml-based language. a kid template must be a well-formed xml document with proper naming conventions.

kid implements attributes within the xml elements to update the underlying engine on the action to be followed for reaching the element. to avoid overlapping with other existing attributes within the xml document, kid has introduced its own namespace.

<p py:if = "...">...</p>

variable substitution

kid comes with a variable substitution scheme and a simple approach — ${variable-name}.

the variables can either be used in attributes of elements or as the text content of an element. kid will evaluate the variable each and every time the execution takes place.

if the user needs the output of a literal string as ${something}, it can be escaped using the variable substitution by doubling the dollar sign.

conditional statement

for toggling different cases in the template, the following syntax is used −

<tag py:if = "expression">...</tag>

here, tag is the name of the element, for instance div or span.

the expression is a python expression. if as a boolean it evaluates to true, the element will be included in the output content or else it will not be a part of the output content.

looping mechanism

for looping an element in kid, the following syntax is used −

<tag py:for = "expression">...</tag>

here, tag is the name of the element. the expression is a python expression, for example for value in [...].

example

the following code shows how the looping mechanism works −

<!doctype html public "-//w3c//dtd html 4.01//en" "http://www.w3.org/tr/html4/strict.dtd">
<html>
   <head>
      <title>${title}</title>
      <link rel = "stylesheet" href = "style.css" />
   </head>
	
   <body>
      <table>
         <caption>a few songs</caption>
         <tr>
            <th>artist</th>
            <th>album</th>
            <th>title</th>
         </tr>
			
         <tr py:for = "info in infos">
            <td>${info['artist']}</td>
            <td>${info['album']}</td>
            <td>${info['song']}</td>
         </tr>
      </table>
   </body>
</html>

import kid

params = discography.retrieve_songs()
t = kid.template('songs.kid', **params)
print t.serialize(output='html')

the output for the above code with the looping mechanism is as follows −

looping output