库存盘点打印功能生成PDF速度太慢使用页面缓存
一.业务需求
二.产品设计
三.UI设计
四.程序设计
1.使用behavior配置页面缓存
class WmsCheckController extends Controller { /** * @inheritdoc */ public function behaviors() { return [ 'verbs' => [ 'class' => VerbFilter::className(), 'actions' => [ 'delete' => ['POST'], ], ], [ 'class' => 'yii\filters\PageCache', 'only' => ['view'], 'duration' => 3600, 'variations' => [ \Yii::$app->language, ], 'dependency' => [ 'class' => 'yii\caching\DbDependency', ], ], ]; }
2.在控制器中编写redis缓存对数据进行缓存
public function actionPrint($id) { //设置无布局 $this->layout = false; //获取打印数据 $model = $this->findModel($id); if(!($model->is_del == 0)){ throw new ForbiddenHttpException("该单据无法打印"); } $serializedDataProvider = \Yii::$app->redis->get('wms_check_detail_data_provider'); if (false == $serializedDataProvider){ $wmsCheckDetail = new \backend\models\WmsCheckDetailSearch(); $dataProvider = $wmsCheckDetail->searchByCheckId($id); \Yii::$app->redis->set('wms_check_detail_data_provider', serialize($dataProvider)); \Yii::$app->redis->expire('wms_check_detail_data_provider', 3600); }else{ $dataProvider = unserialize($serializedDataProvider); } //生成页面内容 $content = $this->render('print', [ 'model' => $model, 'dataProvider'=>$dataProvider, ]); //打印对象 // $pdf = new \TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT,true, 'UTF-8', false); $pdf = (new \TCPDF('L', 'mm', array(240, 140), true, 'UTF-8', false)); //设置无打印头 $pdf->setPrintHeader(false); $pdf->setPrintFooter(false); //设置PDF打印纸张的编剧 $pdf->SetMargins(20, 20,20); //设置单元格内边距 $pdf->setCellPaddings(0, 0, 0, 0); //设置自动进入下一页 // $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_TOP); // $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM); // $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_LEFT); $pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_RIGHT); // $pdf->SetAutoPageBreak(TRUE, 0); $pdf->AddPage(); //设置字体 $pdf->SetFont('stsongstdlight', '', 10); $pdf->writeHTML($content, true, false, true, false, ''); $pdf->lastPage(); $pdf->get('库存盘点.pdf'); }
3.进行页面缓存
<?php if ($this->beginCache($model->id, [ 'duration' => 3600, 'enabled' => Yii::$app->request->isGet])): ?> <?php foreach ($dataProvider->getModels() as $detail): ?> <table class="table-bordered" style="font-size: 10px; border-top: 2px solid black;"> <tr> <td colspan="2" class="active" align="center">名称</td> <td colspan="4" class="active" align="center">等级</td> <td colspan="4" class="active" align="center">单号</td> <td colspan="2" class="active" align="center">件数(袋)</td> <td colspan="2" class="active" align="center">实盘</td> <td colspan="2" class="active" align="center">差异</td> <td colspan="2" class="active" align="center">规格</td> <td colspan="2" class="active" align="center">重量(公斤)</td> <td colspan="2" class="active" align="center">实盘</td> <td colspan="2" class="active" align="center">差异</td> </tr> <tr> <td colspan="2" align="center"> <?= $detail->common_producer_herb_info_name ?> </td> <td colspan="4" align="center"> <?= $detail->common_producer_herb_grade_info_name ?> </td> <td colspan="4" align="center"> <?= $detail->wms_herb_in_sheet_number ?> </td> <td colspan="2" align="center"> <?php if(in_array($model->common_producer_herb_type, [\core\models\WmsCheck::HERB_TYPE_MATERIAL, \core\models\WmsCheck::HERB_TYPE_PRODUCT])): ?> <?= $detail->wms_check_detail_system_package_num ?> <?php endif; ?> </td> <td colspan="2" align="center"> <?php if(in_array($model->common_producer_herb_type, [\core\models\WmsCheck::HERB_TYPE_MATERIAL, \core\models\WmsCheck::HERB_TYPE_PRODUCT])): ?> <?php if($model->wms_check_status == \core\models\WmsCheck::STATUS_FINISH): ?><?= $detail->wms_check_detail_check_package_num ?><?php endif; ?> <?php endif; ?> </td> <td colspan="2" align="center"> <?php if($model->wms_check_status == \core\models\WmsCheck::STATUS_FINISH): ?><?= $detail->wms_check_detail_diff_package_num ?><?php endif; ?> </td> <td colspan="2" align="center"> <?php if($model->wms_check_status == \core\models\WmsCheck::STATUS_FINISH): ?><?= $detail->wms_check_detail_spec_name ?><?php endif; ?> </td> <td colspan="2" align="center"> <?= \common\models\Base::weightBcdiv($detail->wms_check_detail_system_weight) ?> </td> <td colspan="2" align="center"> <?php if($model->wms_check_status == \core\models\WmsCheck::STATUS_FINISH): ?><?= \common\models\Base::weightBcdiv($detail->wms_check_detail_check_weight) ?><?php endif; ?> </td> <td colspan="2" align="center"> <?php if($model->wms_check_status == \core\models\WmsCheck::STATUS_FINISH): ?><?= \common\models\Base::weightBcdiv($detail->wms_check_detail_diff_weight) ?><?php endif; ?> </td> </tr> <tr> <td colspan="2" class="active" align="center">说明</td> <td colspan="22" align="left"><?php if($model->wms_check_status == \core\models\WmsCheck::STATUS_FINISH): ?><?= $detail->wms_check_detail_diff_note ?><?php endif; ?></td> </tr> </table> <?php endforeach; ?> <?php $this->endCache(); endif; ?>
库存盘点打印功能生成PDF速度太慢使用页面缓存的更多相关文章
- 快销品 车销批发管理手持终端PDA系统 打印开单 入库 库存 盘点多功能一体
手持POS终端PDA移动开单 PDA通过扫描商品条码移动开单,实现便携式办公,伴随式销售,浩瀚技术研发团队开发的一款最新产品,PDA能通过WIFI无线局域网.GPRS互联网直接与主机连接,让公司业务人 ...
- 个人永久性免费-Excel催化剂功能第50波-批量打印、导出PDF、双面打印功能
在倡导无纸化办公的今天,是否打印是一个碍眼的功能呢,某些时候的确是,但对于数据的留存,在现在鼓吹区块链技术的今天,仍然不失它的核心价值,数据报表.单据打印出来留存,仍然是一种不可或缺的数据存档和防篡改 ...
- wkhtmltopdf+itext实现html生成pdf文件的打印下载(适用于linux及windows)
目中遇到个根据html转Java的功能,在java中我们itext可以快速的实现pdf打印下载的功能,在itext中我们一般有以下三中方式实现 配置pdf模板,通过Adobe Acrobat 来设置域 ...
- netcore3.1 + vue (前后端分离)生成PDF(多pdf合并)返回前端打印
1.使用Adobe Acrobat XI Pro编辑pdf模板 2.公共类代码 3.service层调用 4.Controller层 5.前端(Vue) 因为print.js不支持宋体,所以打算用后台 ...
- 在js内生成PDF文件并下载的功能实现(不调用后端),以及生成pdf时换行的格式不被渲染,word-break:break-all
在js内生成PDF文件并下载的功能实现(不调用后端),以及生成pdf时换行的格式不被渲染,word-break:break-all 前天来了个新需求, 有一个授权书的文件要点击下载, 需要在前端生成, ...
- php实现pdf导出和打印功能。
所用插件:TCODF //导出pdf public function export_pdf($order_sn){ require_once(FCPATH .'../sha ...
- java实现自动静默打印功能
最近接到一个需求,要求实现自动打印功能,一般网页打印pdf需要借助浏览器的pdf组件,而且还要弹出打印窗口,再点击打印才能实现. 那么如何实现自动打印了,从点击自己网页上3次缩减到点击一次了? 一 ...
- 使用 WebView2 封装一个生成 PDF 的 WPF 控件
使用 WebView2 封装一个生成 PDF 的 WPF 控件 最近在迁移项目到 .net6,发现项目中用的 PDF 库不支持 .net6,于是想着换一个库.结果找了一大圈,发现不是版本不支持,就是收 ...
- 手把手教你使用 Java 在线生成 pdf 文档
一.介绍 在实际的业务开发的时候,研发人员往往会碰到很多这样的一些场景,需要提供相关的电子凭证信息给用户,例如网银/支付宝/微信购物支付的电子发票.订单的库存打印单.各种电子签署合同等等,以方便用户查 ...
随机推荐
- 【转】编写微信聊天机器人4《聊天精灵WeChatGenius》:实时获取到微信聊天消息,hook数据库插入操作。
接上篇,使用Xposed来hook微信,找到微信进程:https://blog.csdn.net/weixin_42127613/article/details/81839537 既然已经找到了微信进 ...
- sql优化的几种方法
在sql查询中为了提高查询效率,我们常常会采取一些措施对查询语句进行sql优化,下面总结的一些方法,有需要的可以参考参考. 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 ord ...
- svn解决冲突问题
1.在linux的branchs下创建了一个新的分支branch_2后,commit.提示: 2.这是把/my_branch/index.html删除后svn update也不能解决问题 3.到myb ...
- .NET Core中复制源文件夹下的所有内容到新文件夹
.NET Core中没有原生的复制文件夹方法,我们可以自己写个: 新建一个.NET Core控制台项目,示例代码如下: using System; using System.IO; namespace ...
- EF Core中,通过实体类向SQL Server数据库表中插入数据后,实体对象是如何得到数据库表中的默认值的
我们使用EF Core的实体类向SQL Server数据库表中插入数据后,如果数据库表中有自增列或默认值列,那么EF Core的实体对象也会返回插入到数据库表中的默认值. 下面我们通过例子来展示,EF ...
- 两个select之间的元素互相移动并保持顺序
<html> <head> <meta http-equiv="Content-Type" content="text/html; char ...
- Java发送Email邮件及SpringBoot集成
一:普通方式发送 1.导包 <!--Java MAil 发送邮件API--> <dependency> <groupId>javax.mail</groupI ...
- 从 0 到 1 实现 react - 9.onChange 事件以及受控组件
该系列文章在实现 cpreact 的同时理顺 React 框架的核心内容 项目地址 从一个疑问点开始 接上一章 HOC 探索 抛出的问题 ---- react 中的 onChange 事件和原生 DO ...
- Php7 开发笔记
Ubuntu环境安装 http://www.jianshu.com/p/1d312d9f1be1 sudo apt-get install python-software-properties sof ...
- 阿里云作为yum源操作
阿里云提供的yum镜像地址为:https://opsx.alibaba.com/mirror 找到自己的使用系统,点击帮助,可以查看更换说明 替换centOS的yum源,如下图 具体操作: CentO ...