侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

详解Python odoo中嵌入html简单的分页功能

Python  /  管理员 发布于 7年前   376

在odoo中,通过iframe嵌入 html,页面数据则通过controllers获取,使用jinja2模板传值渲染

html页面分页内容,这里写了判断逻辑

<!-- 分页 --><ul id="ty_paging">  <li class="home" id="home"><a href="https:car/budget/report/1" rel="external nofollow" ></a>首页</li>  {% if current_page == 1 %}  <li class="prev" id="prev"><</li>  {% else %}  <li class="prev" id="prev"><a href="https:car/budget/report/{{current_page - 1}}" rel="external nofollow" ><</a></li>  {% endif %}  {% if current_page == total_page %}  <li class="next" id="next">></li>  {% else %}  <li class="next" id="next"><a href="https:car/budget/report/{{current_page + 1}}" rel="external nofollow" >></a></li>  {% endif %}  <li class="max">共{{total_page}}页</li>  <li class="max">第{{current_page}}页</li>  <input type="number" min="1" value="1" class="inputPage" id="inputPage"/>  <li class="jump" id="jump"><a id="add" href="" rel="external nofollow" onclick="subNmbr()">跳转</a></li></ul>

在,odoo的controllers中的逻辑

class CarBudgetReport(http.Controller):  @http.route('/car/budget/report/<int:page>', auth='public')  def index(self, page=1, **kw):    data1 = request.env['lims.car.scheme'].get_first_budget()    total_page = int(len(data1) / 10) + 1    if page > total_page:      data = []    else:      data = data1[(page - 1) * 10: page * 10]    return env.get_template(HTML_FIEL_NAME).render({'data': data, 'current_page': page, 'total_page': total_page})

 CSS文件:

/* 分页功能的通用样式 */#ty_paging { overflow: hidden; display: block; width: 100%; margin-top: 20px; text-align: center; user-select: none; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; font-size: 14px; color: #000000; background-color: #FFFFFF;}#ty_paging li { display: inline-block; height: 32px; width: 32px; line-height: 32px; margin: 0px 5px; padding: 0px; border: 1px solid #ddd; border-radius: 2px; cursor: pointer; vertical-align: top; text-align: center;}#ty_paging .home,#ty_paging .jump { width: 56px; height: 32px;}#ty_paging .max { width: 60px; border: none;}#ty_paging .inputPage { height: 32px; width: 56px; border: 1px solid #ddd; border-radius: 2px; text-align: center; color: #000000;}

 在后台xml中需要将路由设置默认为1

<?xml version="1.0" encoding="UTF-8"?><templates id="template" xml:space="preserve">    <t t-name="BudgettIframe">      <iframe src="https:/article/car/budget/report/1" marginheight="0" marginwidth="0" width="100%" height="100%" />    </t></templates>

html 分页js代码

<script>  // 悬浮样式  $('#home, #jump').mouseover(function () {    // if ($(this).val() == ty_currentPage) return;    $(this).css({      'border-color': '#2db71a',      'color': '#000000',      // 'background-color': '#337ab7',    });  });  $('#home, #prev, #next, #jump').mouseout(function () {    // if ($(this).val() == ty_currentPage) return;    $(this).css({      'border-color': "#ddd",      'color': '#666',      // 'background-color': '#ffffff',    });  });  $('#up, #down').mouseover(function () {    // if ($(this).val() == ty_currentPage) return;    $(this).css({      'border-color': '#337ab7',      'color': '#ffffff',      'background-color': '#2db71a',    });  });  $('#up, #down').mouseout(function () {    // if ($(this).val() == ty_currentPage) return;    $(this).css({      'border-color': "#000000",      'color': '#000000',      'background-color': '#ffffff',    });  });  // 点击跳转页面需要用到方法  function subNmbr() {    // 先获取到页面上input输入框中的值    var subNmbr = document.getElementById('inputPage').value;    // console.log(subNmbr);    // 在获取li的id,在点击时做一个动作    document.getElementById("jump").onclick = function () {      //根据a标签的id获取链接,设置href属性      var aObj = document.getElementById("add");      // 把要跳转的页面连接传入href      aObj.href = "/car/budget/report/" + subNmbr;      //根据id获取超链接,设置文字内容      aObj.innerText = "跳转";    };  }</script>

之后便可以进行数据的简单分页

总结

以上所述是小编给大家介绍的Python odoo中嵌入html简单的分页功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!


  • 上一条:
    python TF-IDF算法实现文本关键词提取
    下一条:
    Python 3.8中实现functools.cached_property功能
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客