2016-08-18 106 views
1

我有我掙扎MPDF6與液浮格寬度MPDF問題

我使用笨,它顯示了一次問卷調查結果的Web應用程序創建來解決問題。

我已經在html中生成了簡單的堆積條形圖,並使用jquery將條形圖動畫化爲最終大小。工作好,沒有問題。

我想能夠在MPDF中複製結果,因此使用相同的div理論並相應地調整它們,但是這次我使用php將寬度設置爲內聯樣式,並且在大多數情況下,我有這個工作很好,但是,如果值= 1,那麼由於某種原因,mpdf變得時髦,請參閱下面的示例圖片;

Example of MPDF issue

這裏是我的PHP標記爲MPDF報告

<div class='survey'> 
      <?php $nw = 390; $w = 400; $tot=0; $totpos=0; $score=0; $cat=0; foreach ($categories as $c) : ?> 
      <p class='left question'><?php echo $c->category_name; ?></p> 
      <p class='left perc'><?php echo number_format($summaryAnswers[$cat][6],1); ?>%</p> 
      <p class='left perc'><?php echo number_format($summaryAnswers[$cat][7],2); ?></p> 
      <div style='width: <?php echo $w; ?>px;' class='left chart'> 
       <?php if ($summaryAnswers[$cat][0] > 0) : ?> 
        <div class='left barchart sagree' style='width: <?php $width = $nw * $summaryAnswers[$cat][0]/$summaryAnswers[$cat][5]; echo $width; ?>px;' tot='<?php echo $summaryAnswers[$cat][5]; ?>' val='<?php echo $summaryAnswers[$cat][0]; ?>' ><span class='label'><?php echo $summaryAnswers[$cat][0]; ?></span></div> 
       <?php endif; ?> 

       <?php if ($summaryAnswers[$cat][1] > 0) : ?> 
        <div class='left barchart agree' style='width: <?php $width = $nw * $summaryAnswers[$cat][1]/$summaryAnswers[$cat][5]; echo $width; ?>px;' tot='<?php echo $summaryAnswers[$cat][5]; ?>' val='<?php echo $summaryAnswers[$cat][1]; ?>' ><span class='label'><?php echo $summaryAnswers[$cat][1]; ?></span></div> 
       <?php endif; ?> 

       <?php if ($summaryAnswers[$cat][2] > 0) : ?> 
        <div class='left barchart neither' style='width: <?php $width = $nw * $summaryAnswers[$cat][2]/$summaryAnswers[$cat][5]; echo $width; ?>px;' tot='<?php echo $summaryAnswers[$cat][5]; ?>' val='<?php echo $summaryAnswers[$cat][2]; ?>' ><span class='label'><?php echo $summaryAnswers[$cat][2]; ?></span></div> 
       <?php endif; ?> 

       <?php if ($summaryAnswers[$cat][3] > 0) : ?> 
        <div class='left barchart disagree' style='width: <?php $width = $nw * $summaryAnswers[$cat][3]/$summaryAnswers[$cat][5]; echo $width; ?>px;' tot='<?php echo $summaryAnswers[$cat][5]; ?>' val='<?php echo $summaryAnswers[$cat][3]; ?>' ><span class='label'><?php echo $summaryAnswers[$cat][3]; ?></span></div> 
       <?php endif; ?> 

       <?php if ($summaryAnswers[$cat][4] > 0) : ?> 
        <div class='left barchart sdisagree' style='width: <?php $width = $nw * $summaryAnswers[$cat][4]/$summaryAnswers[$cat][5]; echo $width; ?>px;' tot='<?php echo $summaryAnswers[$cat][5]; ?>' val='<?php echo $summaryAnswers[$cat][4]; ?>' ><span class='label'><?php echo $summaryAnswers[$cat][4]; ?></span></div> 
       <?php endif; ?> 
      </div> 

我曾經嘗試都像素寬度和寬度%這兩個選項給我同樣的結果的一個例子...

這裏是腳本生成的html,你可以看到每個寬度的值看起來正確

<div class='survey'> 
          <p class='left question'>Organisation and Culture</p> 
      <p class='left perc'>66.7%</p> 
      <p class='left perc'>2.92</p> 
      <div style='width: 400px;' class='left chart'> 
             <div class='left barchart sagree' style='width: 97.5px;' tot='24' val='6' ><span class='label'>6</span></div> 

             <div class='left barchart agree' style='width: 162.5px;' tot='24' val='10' ><span class='label'>10</span></div> 

             <div class='left barchart neither' style='width: 32.5px;' tot='24' val='2' ><span class='label'>2</span></div> 

             <div class='left barchart disagree' style='width: 81.25px;' tot='24' val='5' ><span class='label'>5</span></div> 

             <div class='left barchart sdisagree' style='width: 16.25px;' tot='24' val='1' ><span class='label'>1</span></div> 
           </div> 


      <br class='clear' />  

的CSS ..

.survey { font-size: 10pt; } 
.survey .question { width: 47%; padding: 5px 0; } 
.survey .perc  { width: 5%; margin: 0; padding: 5px 0; } 
.survey .no   { width: 2%; margin: 0; padding: 5px 0; } 
.survey .chart  { width: 40%; }  
.survey .barchart { padding: 5px 0; } 
.barchart .label { margin: 0 0 0 5px; } 
div.sagree { background: #2DCC00; } 
div.agree { background: #F2E930; } 
div.neither { background: #888; } 
div.disagree{ background: #FFA519; } 
div.sdisagree { background: #FF1919; } 
.right { float: right; } 
.left { float: left; } 
.clear { clear: both; } 

人爲什麼發生這種情況有什麼想法?

歡呼

+0

能不能請你添加你的CSS這些類?檢查這種情況會更容易一些。 –

+0

css補充,謝謝 – Andie

+0

可能你可以在這裏收集一些有用的信息[浮動塊](https://mpdf.github.io/what-else-can-i-do/floating-blocks.html) –

回答

0

我發現這爲我工作,通過大量的試驗和錯誤的解決方案...

我創建了一個div容器,並使用內聯CSS設置div的寬度%然後每個容器內浮動的div,設定寬度爲%太有點像這樣:

<div style='width: 80%'> 
    <div style='float: left; width: 20%'>Content</div> 
    <div style='float: left; width: 30%'>Content</div> 
    <div style='float: left; width: 40%'>Content</div> 
    <div style='float: left; width: 10%'>Content</div> 
    <div style='float: left; width: 5%'>Content</div> 
    <div style='float: left; width: 15%'>Content</div> 
    <div style='float: left; width: 40%'>Content</div> 
    <div style='float: left; width: 40%'>Content</div> 
</div> 
0

我只是偶然上相同的問題(把較小的寬度,以div和MPDF把它們變成100%)。

我的解決方案是將div轉換爲表,並給每個td給出寬度(百分比)。按預期工作。

注意:顯然,如果內容太寬,可能會迫使td展開,但即便如此,我們也可以使用mPDF來適應/調整內容大小!

例子:

<table style="width: 100%"> 
    <tr> 
    <td style="width:20%">20</td> 
    <td style="width:40%">40</td> 
    <td style="width:10%">10</td> 
    <td style="width:5%">5</td> 
    <td style="width:25%">25</td> 
    </tr> 
</table>