Matraz - Plantillas

Es posible devolver la salida de una función vinculada a una determinada URL en forma de HTML. Por ejemplo, en el siguiente script,hello() la función renderizará ‘Hello World’ con <h1> etiqueta adjunta.

from flask import Flask
app = Flask(__name__)

@app.route('/')
def index():
   return '<html><body><h1>Hello World</h1></body></html>'

if __name__ == '__main__':
   app.run(debug = True)

Sin embargo, generar contenido HTML a partir del código Python es engorroso, especialmente cuando es necesario colocar datos variables y elementos del lenguaje Python como condicionales o bucles. Esto requeriría un escape frecuente de HTML.

Aquí es donde uno puede aprovechar Jinja2motor de plantillas, en el que se basa Flask. En lugar de devolver HTML de código rígido desde la función, elrender_template() función.

from flask import Flask
app = Flask(__name__)

@app.route('/')
def index():
   return render_template(‘hello.html’)

if __name__ == '__main__':
   app.run(debug = True)

Flask intentará encontrar el archivo HTML en la carpeta de plantillas, en la misma carpeta en la que está presente este script.

  • Carpeta de la aplicación
    • Hello.py
    • templates
      • hello.html

El termino ‘web templating system’se refiere al diseño de un script HTML en el que los datos variables se pueden insertar de forma dinámica. Un sistema de plantillas web consta de un motor de plantillas, algún tipo de fuente de datos y un procesador de plantillas.

Usos del matraz jinja2motor de plantillas. Una plantilla web contiene marcadores de posición intercalados de sintaxis HTML para variables y expresiones (en este caso, expresiones de Python) que son valores reemplazados cuando se representa la plantilla.

El siguiente código se guarda como hello.html en la carpeta de plantillas.

<!doctype html>
<html>
   <body>
   
      <h1>Hello {{ name }}!</h1>
      
   </body>
</html>

A continuación, ejecute el siguiente script desde el shell de Python.

from flask import Flask, render_template
app = Flask(__name__)

@app.route('/hello/<user>')
def hello_name(user):
   return render_template('hello.html', name = user)

if __name__ == '__main__':
   app.run(debug = True)

Cuando el servidor de desarrollo comience a ejecutarse, abra el navegador e ingrese la URL como: http://localhost:5000/hello/mvl

los variable parte de la URL se inserta en {{ name }} titular de lugar.

los jinja2 El motor de plantillas utiliza los siguientes delimitadores para escapar de HTML.

  • {% ...%} para declaraciones
  • {{...}} para que las expresiones se impriman en la salida de la plantilla
  • {# ... #} para comentarios no incluidos en la salida de la plantilla
  • # ... ## para declaraciones de línea

En el siguiente ejemplo, se demuestra el uso de una declaración condicional en la plantilla. La regla de URL a lahello()La función acepta el parámetro entero. Se pasa alhello.htmlmodelo. En su interior, se compara el valor del número recibido (puntos) (mayor o menor que 50) y, en consecuencia, HTML se procesa condicionalmente.

El script de Python es el siguiente:

from flask import Flask, render_template
app = Flask(__name__)

@app.route('/hello/<int:score>')
def hello_name(score):
   return render_template('hello.html', marks = score)

if __name__ == '__main__':
   app.run(debug = True)

Secuencia de comandos de plantilla HTML de hello.html es como sigue -

<!doctype html>
<html>
   <body>
      {% if marks>50 %}
         <h1> Your result is pass!</h1>
      {% else %}
         <h1>Your result is fail</h1>
      {% endif %}
   </body>
</html>

Tenga en cuenta que las declaraciones condicionales if-else y endif están encerrados en delimitadores {%..%}.

Ejecute el script de Python y visite la URL http://localhost/hello/60 y entonces http://localhost/hello/30 para ver la salida de HTML cambiando condicionalmente.

Las construcciones de bucle de Python también se pueden emplear dentro de la plantilla. En el siguiente guión, elresult() la función envía un objeto de diccionario a la plantilla results.html cuando URL http://localhost:5000/result se abre en el navegador.

La plantilla parte de result.html emplea un for loop para representar pares de clave y valor del objeto de diccionario result{} como celdas de una tabla HTML.

Ejecute el siguiente código desde el shell de Python.

from flask import Flask, render_template
app = Flask(__name__)

@app.route('/result')
def result():
   dict = {'phy':50,'che':60,'maths':70}
   return render_template('result.html', result = dict)

if __name__ == '__main__':
   app.run(debug = True)

Guarde el siguiente script HTML como result.html en la carpeta de plantillas.

<!doctype html>
<html>
   <body>
      <table border = 1>
         {% for key, value in result.items() %}
            <tr>
               <th> {{ key }} </th>
               <td> {{ value }} </td>
            </tr>
         {% endfor %}
      </table>
   </body>
</html>

Aquí, nuevamente las declaraciones de Python correspondientes a la For bucle están encerrados en {% ..%} mientras que las expresiones key and value se ponen dentro {{ }}.

Una vez que el desarrollo comience a ejecutarse, abra http://localhost:5000/result en el navegador para obtener el siguiente resultado.