全站搜索

网站开发之php将html转成pdf

网站开发 438

功能需求:将产品导出成pdf手册,用于产品收藏与宣传

所用框架thinkphp3.2

所用库类Mpdf,下载地址:
https://github.com/mpdf/mpdf

将mpdf库类放入ThinkPHP\Library\Vendor\ 文件夹中

1.控制器方法

 public function pdf($id){

        $FavModel=new \Home\Model\MemberFavModel();

        $list=$FavModel->search_fav($id);/获取数据列表

       

        
//引入类库

        Vendor(‘Mpdf.mpdf’);

        
//设置中文编码

        $mpdf=new \mPDF(‘zh-cn’,’A4′, 0, ‘宋体’, 0, 0);

        $sying=’ ‘;

        $mpdf->SetWatermarkText($sying,0.1);

        $path_root= ? ‘..’. : ‘.’.;

        $strContent = $this->bld_htm($list, $path_root);//创建html内容

        

 

         
//dump($list); 

        
//print_r($strContent);exit;

        $mpdf->showWatermarkText = true;

        $mpdf->SetHTMLHeader(”);

        $mpdf->SetHTMLFooter(” );

        $mpdf->WriteHTML($strContent);

      

        $Path=$path_root.’/Download/’.’Wish List’;

        if(!is_dir($Path)){

         mkdir(iconv(“UTF-8”, “GBK”, $Path),0777,true);

        }    

        
//保存ss.pdf文件

        $mpdf->Output($Path.’/Wish List.pdf’);

        
//直接浏览器输出pdf

        
// $mpdf->Output(‘tmp.pdf’,true);

        $mpdf->Output(‘Wish List.pdf’,’I’);
//I表示在线展示 D则显示下载 f生成后保存到服务器

        
// $mpdf->Output();

        
// exit;

   }

 

  • 创建html

 public function bld_htm($list, $path_root){

        $str=”; 

        $str.='<div style=”width: 100%; “>

        <div style=”width: 90%; margin: auto;”>

          <div style=”text-align: center; color: #000000; font-size: 20px; margin-bottom: 20px; “>

            HuaJewelry

          </div>

          <div style=”border-bottom: #999999 solid 1px; color: #fe0001; font-weight: bold; font-size: 18px; padding-bottom: 15px;”>

           Wish List

          </div>

          <ul style=”width:100%;  margin-top: 45px; padding: 0;”>’;

      

        foreach($list as $k=>$v){

            

            $class=’float: left; width: 31%; list-style: none; box-sizing: border-box; margin-right:1%; margin-bottom: 2%; text-align: center; border: #e2e2e2 solid 1px’;

            $str.='<li style=”‘.$class.'”>

            <a href=”” style=”display: block; width: 100%;”>

              <div style=”width:100%; “>

                <img src=”‘.$path_root.$v[‘picture’][0].'” style=”max-width: 100%;” />

              </div>

              <div style=”font-size: 15px; line-height: 1.7; color: #000000; padding: 15px;”>

                  ‘.$v[‘goods_no’].'<br>

                  $’.$v[‘price’].’

              </div>

            </a>

          </li>’;   

         

        }

 

        $str.=”</ul></div></div>”;

        return $str; 

   }

注意这个样式要写在行内才能有效果,不要用超出隐藏会丢失整个数据,而不是隐藏超出的部分,不知道是否是图片的关系,我用超出隐藏就会少几个产品。

前端效果:这里是将个人收藏的商品导出成为excel或者pdf,pdf可以下载预览,预览需要浏览器支持,基本上的pc浏览器都是自带插件的,手机需要安装应用或者浏览器有带插件才可以查看。

这里是直接用链接的形式带上参数跳转到方法pdf(带参数id)

如图:导出后的效果,因为这里是I 在线展示,如果需要可以设置成D下载文件。

 

 $mpdf->Output(‘Wish List.pdf’,’I’);
//I表示在线展示 D则显示下载

 

 

 

 

上一篇: 下一篇:

相关推荐

  • 网站前端制作之css3的渐变效果

    437

    渐变设计在背景的使用,可以体现出良好的视觉吸引力,帮助用户理解设计所表达的内容。在文本字体的中使用可以营造出一个吸引人的焦点,快速吸引注意力。渐变使用在图片上的时候就可以使图片更加出彩,从而导致整个网站在视觉上也加分不少。渐变的使用不仅可以引导浏...

    查看全文
  • 苏州专业的关键词搜索引擎优化公司有哪些

    829

      网站的经营和推广离不开SEO引擎搜索优,那么选择优化公司是非常重要的途径,在苏州地区有很多关关键词,搜索引擎优化公司,人们可以通过知名度,专业度以及网络排名等因素来进行选择,同样还要选择专业度比较强并且性价比比较高的公司。      那...

    查看全文
  • 让网站导航保持友好的九个技巧

    338

    下面是一些导航设计的案例。   导航未能到达站点上的正确页面对访问者来说是一件痛苦的事情。因为这会浪费用户的时间、消磨用户的耐心。 作为一个网站设计师,要尽量避免这样的事情发生。为此,深圳策轩网络总结了九种方法可以让访问者更容易地浏览网站页...

    查看全文
  • PHP网站做简体繁体英文切换功能-多语言版本

    366

    一般网站如果要做多语言版本的话,中文简体和繁体的互相转换,因为中文每个单词都是独立的我们可以用一个js的插件来进行转换,中英文互相转换,一般都是通过单独后台编辑文字,因为机器翻译的实在让人不得其解,相信大家都看过机器翻译的字幕,是真的不知所云,那有...

    查看全文
展开更多