ローカル開発環境 (windows) で、Css スタイルを含む pdf が正常に生成されました。しかし、CSSスタイルを適用せずに生成されたLinuxサーバー環境のpdfをホストしています.Belowは私のwkhtmltopdf(WickedPdf)構成です
WickedPdf.config = {
#:wkhtmltopdf => "#{RAILS_ROOT}/pdfbin/wkhtmltopdf-amd64",
:exe_path => "/home/software/.gems/bin/wkhtmltopdf",
:layout => "layouts/pdf.html.erb",
:margin => { :top=> 40,
:bottom => 20,
:left=> 30,
:right => 30},
:header => {:html => { :template=> 'layouts/pdf_header.html.erb'}},
:footer => {:html => { :template=> 'layouts/pdf_footer.html.erb'}}
#:exe_path => '/usr/bin/wkhtmltopdf'
}
追加情報:
これは私の dir 構造です。私は app\views\layouts をホストしている Linux レール上にいます。レイアウト内には pdf.html.erb 、 pdf_footer.html.erb 、pdf_header.html.erb があります。上記のものは、ローカルの Windows 開発環境で完全に動作します。 、しかし、スタイルなしで生成された本番PDFでは、CSSスタイルを使用してPDFを作成するのを手伝ってください
アプリ/ビュー/レイアウト/pdf.html.erb
<!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html dir="<%= (rtl?) ? 'rtl' : 'ltr' %>">
<head>
<% @direction = (rtl?) ? 'rtl/' : '' %>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<%= stylesheet_link_tag([@direction+'application', @direction+'_styles/ui.all'])%>
<%= stylesheet_link_tag(*get_stylesheets) %>
<%= stylesheet_link_tag @direction+"_layouts/pdf" %>
<link rel="stylesheet" type="text/css" href="<%="#{RAILS_ROOT}/public/stylesheets/#{@direction}_layouts/pdf.css" %>" media="all" />
<link rel="stylesheet" type="text/css" href="<%="#{RAILS_ROOT}/public/stylesheets/#{get_stylesheets}.css"%>" media="all" />
<link rel="stylesheet" type="text/css" href="<%= "#{RAILS_ROOT}/public/stylesheets/#{@direction}_styles/ui.all.css"%>" media="all" />
</head>
<body>
<%= yield %>
</body>
</html>
pdf.html.erb には pdf をレンダリングするためのすべてのスタイル情報が含まれています。ホスティング環境では、これらのスタイルは wkhtmltopdf によって取得されません。みんな私を助けてください