8-tornado中模板的使用(通过字符串返回、通过模板Template返回、通过模板render返回)、模板案例

1 Template

1.1 通过字符串返回

import tornado
class IndexHandler(web.RequestHandler):
    def get(self):
        arg = 'Template'
        self.finish(f'<h1>Hello {
     arg}!!</h1>')

1.2 通过模板Template返回

tornado.template

一个简单的模板系统,将模板编译为Python代码。
基本用法如下

class IndexHandler1(web.RequestHandler):
    def get(self):
        arg = 'Template1'
        t = template.Template(f'<h1>Hello {
     arg}!!</h1>')
        self.finish(t.generate())

class IndexHandler2(web.RequestHandler):
    def get(self):
        arg1 = 'Template2'
        t = template.Template('<h1>Hello {
   {arg}}!!</h1>')
        self.finish(t.generate(arg = arg1))

class IndexHandler3(web.RequestHandler):
    def get(self):
        arg1 = 'Template3_file'
        loader = template.Loader('./templates/')
        self.finish(loader.load('index.html').generate(arg = arg1))
<!-- templates/index.html -->
<h1>Hello {
  {arg}}!!</h1>

1.3 通过模板render返回

class IndexHandler4(web.RequestHandler):
    def get(self):
        arg1 = 'render_Template3_file'
        self.render('index.html',arg=arg1)     

2 模板案例

*前端

   <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8"/>
    <title>购物车</title>
    <link rel="stylesheet" type="text/css" href="{
    { static_url('css/style.css') }}" />
    <script src="{
    { static_url('js/html5.js') }}"></script>
    <script src="{
    { static_url('js/jquery.js') }}"></script>
    <script>
    $(document).ready(function(){
     
      $("nav .indexAsideNav").hide();
      $("nav .category").mouseover(function(){
     
    	  $(".asideNav").slideDown();
    	  });
      $("nav .asideNav").mouseleave(function(){
     
    	  $(".asideNav").slideUp();
    	  });
    });
    </script>
    </head>
    <body>
    <!--header-->
    <header>
      <!--topNavBg-->
      <div class="topNavBg">
       <div class="wrap">
       <!--topLeftNav-->
        <ul class="topLtNav">
         <li><a href="login.html" class="obviousText">亲,请登录</a></li>
         <li><a href="register.html">注册</a></li>
         <li><a href="#">移动端</a></li>
        </ul>
       <!--topRightNav-->
        <ul class="topRtNav">
         <li><a href="user.html">个人中心</a></li>
         <li><a href="cart.html" class="cartIcon">购物车<i>0</i></a></li>
         <li><a href="favorite.html" class="favorIcon">收藏夹</a></li>
         <li><a href="user.html">商家中心</a></li>
         <li><a href="article_read.html" class="srvIcon">客户服务</a></li>
         <li><a href="union_login.html">联盟管理</a></li>
        </ul>
       </div>
      </div>
      <!--logoArea-->
      <div class="wrap logoSearch">
       <!--logo-->
       <div class="logo">
        <h1><img src="{
    { static_url('img/logo.png')}}"/></h1>
       </div>
       <!--search-->
       <div class="search">
        <ul class="switchNav">
         <li class="active" id="chanpin">产品</li>
         <li id="shangjia">商家</li>
         <li id="zixun">搭配</li>
         <li id="wenku">文库</li>
        </ul>
        <div class="searchBox">
         <form>
          <div class="inputWrap">
          <input type="text" placeholder="输入产品关键词或货号"/>
          </div>
          <div class="btnWrap">
          <input type="submit" value="搜索"/>
          </div>
         </form>
         <a href="#" class="advancedSearch">高级搜索</a>
        </div>
       </div>
      </div>
      <!--nav-->
      <nav>
    <ul class="wrap navList">
    <li class="category">
    <a>全部产品分类</a>
    <dl class="asideNav indexAsideNav">
    <dt><a href="channel.html">女装</a></dt>
    <dd>
    <a href="#">夏装新</a>
    <a href="#">连衣裙</a>
    <a href="#">T恤</a>
    <a href="#">衬衫</a>
    <a href="#">裤子</a>
    <a href="#">牛仔裤</a>
    <a href="#">背带裤</a>
    <a href="#">短外套</a>
    <a href="#">时尚外套</a>
    <a href="#">风衣</a>
    <a href="#">毛衣</a>
    <a href="#">背心</a>
    <a href="#">吊带</a>
    <a href="#">民族服装</a>
    </dd>
    <dt><a href="channel.html">男装</a></dt>
    <dd>
    <a href="#">衬衫</a>
    <a href="#">背心</a>
    <a href="#">西装</a>
    <a href="#">POLO衫</a>
    <a href="#">马夹</a>
    <a href="#">皮衣</a>
    <a href="#">毛衣</a>
    <a href="#">针织衫</a>
    <a href="#">牛仔裤</a>
    <a href="#">外套</a>
    <a href="#">夹克</a>
    <a href="#">卫衣</a>
    <a href="#">风衣</a>
    <a href="#">民族风</a>
    <a href="#">原创设计</a>
    <a href="#">大码</a>
    <a href="#">情侣装</a>
    <a href="#">开衫</a>
    <a href="#">运动裤</a>
    <a href="#">工装裤</a>
    </dd>
    </dl>
    </li>
    <li>
    <a href="index.html" class="active">首页</a>
    </li>
    <li>
    <a href="#">时尚搭配</a>
    </li>
    <li>
    <a href="channel.html">原创设计</a>
    </li>
    <li>
    <a href="channel.html">时尚代购</a>
    </li>
    <li>
    <a href="channel.html">民族风</a>
    </li>
    <li>
    <a href="information.html">时尚搭配</a>
    </li>
    <li>
    <a href="library.html">搭配知识</a>
    </li>
    <li>
    <a href="#">促销专区</a>
    </li>
    <li>
    <a href="#">其他</a>
    </li>
    </ul>
    </nav>
    
     </header>
     <script>
     $(document).ready(function(){
     
       //测试效果,程序对接如需变动重新编辑
       $(".switchNav li").click(function(){
     
         $(this).addClass("active").siblings().removeClass("active");
         });
       $("#chanpin").click(function(){
     
         $(".inputWrap input[type='text']").attr("placeholder","输入产品关键词或货号");
         });
       $("#shangjia").click(function(){
     
         $(".inputWrap input[type='text']").attr("placeholder","输入商家店铺名");
         });
       $("#zixun").click(function(){
     
         $(".inputWrap input[type='text']").attr("placeholder","输入关键词查找文章内容");
         });
       $("#wenku").click(function(){
     
         $(".inputWrap input[type='text']").attr("placeholder","输入关键词查找文库内容");
         });
       });
       
     </script>
     
    <section class="wrap" style="margin-top:20px;overflow:hidden;">
     <table class="order_table">
      <tr>
       <th><input type="checkbox"/></th>
       <th>产品</th>
       <th>名称</th>
       <th>属性</th>
       <th>单价</th>
       <th>数量</th>
       <th>小计</th>
       <th>操作</th>
      </tr>
      {% set total = 0 %}
      {% for order in  orders %}
      <tr>
       <td class="center"><input type="checkbox"/></td>
       <td class="center"><a href="product.html"><img src="{
    {order['img']}}" style="width:50px;height:50px;"/></a></td>
       <td><a href="product.html">{
  {order['name']}}</a></td>
       <td>
        <p>{
  {order['type']}}</p>
      
       </td>
       {% if order['price'] < 100 %}
       <td class="center"><span class="rmb_icon">优惠力度很大</span></td>
       {% else %}
       <td class="center"><span class="rmb_icon">{
  {order['price']}}</span></td>
       {% end %}
       <td class="center">
        <span>{
  { order['num'] }}</span>
       </td>
       <!-- <td class="center"><strong class="rmb_icon">{
   { order['price']*order['num'] }}</strong></td> -->
       <td class="center"><strong class="rmb_icon">{
  { count_price(order['price'],order['num']) }}</strong></td>
       <td class="center">{% raw order['opts'] %}</td>  <!-- html 解析-->
       {
  { total = total + count_price(order['price'],order['num']) }}
      </tr>
      {% end %}
     </table>
     <div class="order_btm_btn">
      <a href="index.html" class="link_btn_01 buy_btn"/>继续购买</a>
      <a href="order_confirm.html" class="link_btn_02 add_btn"/>共计金额<strong class="rmb_icon">{
  { total }}</strong>立即结算</a>
     </div>
    </section>
    <!--footer-->
    <footer>
     <!--help-->
     <ul class="wrap help">
      <li>
       <dl>
        <dt>消费者保障</dt>
        <dd><a href="article_read.html">保障范围</a></dd>
        <dd><a href="article_read.html">退换货流程</a></dd>
        <dd><a href="article_read.html">服务中心</a></dd>
        <dd><a href="article_read.html">更多服务特色</a></dd>
       </dl>
      </li>
      <li>
       <dl>
        <dt>新手上路</dt>
        <dd><a href="article_read.html">保障范围</a></dd>
        <dd><a href="article_read.html">退换货流程</a></dd>
        <dd><a href="article_read.html">服务中心</a></dd>
        <dd><a href="article_read.html">更多服务特色</a></dd>
       </dl>
      </li>
      <li>
       <dl>
        <dt>付款方式</dt>
        <dd><a href="article_read.html">保障范围</a></dd>
        <dd><a href="article_read.html">退换货流程</a></dd>
        <dd><a href="article_read.html">服务中心</a></dd>
        <dd><a href="article_read.html">更多服务特色</a></dd>
       </dl>
      </li>
      <li>
       <dl>
        <dt>服务保障</dt>
        <dd><a href="article_read.html">保障范围</a></dd>
        <dd><a href="article_read.html">退换货流程</a></dd>
        <dd><a href="article_read.html">服务中心</a></dd>
        <dd><a href="article_read.html">更多服务特色</a></dd>
       </dl>
      </li>
     </ul>
     <dl class="wrap otherLink">
      <dt>友情链接</dt>
      <dd><a href="#" target="_blank">新码笔记</a></dd>
      <dd><a href="#" target="_blank">DethGhost</a></dd>
      <dd><a href="#">当当</a></dd>
      <dd><a href="#">优酷</a></dd>
      <dd><a href="#">土豆</a></dd>
      <dd><a href="#">新浪</a></dd>
      <dd><a href="#">钉钉</a></dd>
      <dd><a href="#">支付宝</a></dd>
     </dl>
     <div class="wrap btmInfor">
      <p>© 2060 版权所有 网络文化经营许可证:浙网文[2060]***-027号 增值电信业务经营许可证:浙B2-200***24-1 信息网络传播视听节目许可证:1109***4号</p>
      <address>联系地址:北京尚学堂科技有限公司</address>
     </div>
    </footer>
    </body>
    </html>

后端

from tornado import web,template
from tornado import ioloop

class IndexHandler(web.RequestHandler):
    def count(self,price,num):
        return price*num
    def get(self):
        orders=[
            {
      'id':1,
                'name':'MacPro 2060',
                'type':'32G',
                'price':9999,
                'num':1,
                'img':'static/img/goods.jpg',
                'opts':'<a href="delete?id=3">删除</a>'
            },
            {
   
                'id':2,
                'name':'HuaWei Mate 2060',
                'type':'512G',
                'price':6666,
                'num':1,
                'img':'static/img/goods007.jpg',
                'opts':'<a href="delete?id=3">删除</a>'
            },
            {
      
                'id':3,
                'name':'Sony耳机',
                'type':'立体混音',
                'price':66,
                'num':2,
                'img':'static/img/goods008.jpg',
                'opts':'<a href="delete?id=3">删除</a>'
            },
        ]
        self.render('shop.html',orders=orders,count_price=self.count)


settings={
   
    'static_path':'./static/',
    'static_url_prefix':'/static2/',
    'template_path':'./templates'
}

if __name__ == '__main__':
    app = web.Application([
        ('/',IndexHandler),
        ],debug=True,
        **settings)
    app.listen(8000)
    ioloop.IOLoop.current().start()ok     

最近更新

  1. TCP协议是安全的吗?

    2023-12-07 13:44:05       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-07 13:44:05       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-07 13:44:05       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-07 13:44:05       20 阅读

热门阅读

  1. 在windows上使用多个版本的chrome(谷歌)浏览器

    2023-12-07 13:44:05       48 阅读
  2. 星期一 至 星期日的样本个数统计(Python)

    2023-12-07 13:44:05       32 阅读
  3. 基于灰狼算法求解旅行商问题的MATLAB源码

    2023-12-07 13:44:05       41 阅读
  4. nvm,node,npm,yarn相关安装报错问题记录

    2023-12-07 13:44:05       37 阅读
  5. CSS-2

    2023-12-07 13:44:05       34 阅读
  6. 数据库sql是什么?

    2023-12-07 13:44:05       37 阅读
  7. [Swift]RxSwift常见用法详解

    2023-12-07 13:44:05       40 阅读
  8. 开启gitlab中远程连接pgsql

    2023-12-07 13:44:05       28 阅读
  9. 【原创】Mac mini M1安装home-brew

    2023-12-07 13:44:05       35 阅读
  10. AURIX TC芯片中DSU实现安全启动

    2023-12-07 13:44:05       37 阅读
  11. 网络攻击有什么危害,该如何防御

    2023-12-07 13:44:05       39 阅读