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

作者:上帝的中腿 时间:2021-05-21 12:24:06 

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

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


<!-- 分页 -->
<ul id="ty_paging">
 <li class="home" id="home"><a href="/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="/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="/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="javascript:void(0)" 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="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 odoo中嵌入html简单的分页功能,网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

来源:https://www.cnblogs.com/ws17345067708/archive/2019/05/29/10941807.html

标签:Python,odoo,html,分页
0
投稿

猜你喜欢

  • 以PHP代码为实例详解RabbitMQ消息队列中间件的6种模式

    2023-06-08 12:15:53
  • oracle 重置序列从指定数字开始的方法详解

    2023-07-05 02:40:04
  • asp简单的仿图片验证码

    2008-03-12 11:54:00
  • Python爬虫天气预报实例详解(小白入门)

    2023-03-23 16:05:48
  • 一个小时内学习 SQLite 数据库

    2012-05-22 18:51:30
  • 关于pycharm python3.7成功安装dlib库的问题

    2022-03-04 04:22:45
  • Python多继承以及MRO顺序的使用

    2022-04-01 19:35:50
  • 解析mysql数据库还原错误:(mysql Error Code: 1005 errno 121)

    2024-01-15 00:13:13
  • python实现简单登陆流程的方法

    2021-01-30 00:48:24
  • Java数据库操作库DButils类的使用方法与实例详解

    2024-01-20 13:32:45
  • asp实现通过session来统计在线人数的方法

    2007-08-13 12:56:00
  • MYSQL使用.frm恢复数据表结构的实现方法

    2024-01-24 21:52:27
  • 深入理解python多进程编程

    2023-03-20 09:07:20
  • 解决mysql ERROR 1017:Can't find file: '/xxx.frm' 错误

    2024-01-13 18:57:43
  • asp利用xmlhttp抓取特定网页内容例子

    2008-10-10 12:58:00
  • SQL Server中的T-SQL的基本对象

    2024-01-17 21:10:35
  • [译]艺术和设计的差异 (1)

    2009-09-25 12:38:00
  • tensorflow中next_batch的具体使用

    2023-04-21 05:34:02
  • python调用ffmpeg命令行工具便捷操作视频示例实现过程

    2023-12-19 07:48:22
  • Python操作word文档插入图片和表格的实例演示

    2023-09-20 08:21:09
  • asp之家 网络编程 m.aspxhome.com