CSS 和 wicked_pdf 不工作

CSS and wicked_pdf not working

我不确定我错过了什么,但我的 css 似乎没有与 wicked_pdf 一起工作。我的文件中链接了一张图片,可以使用,但缺少样式。

Gemfile

gem 'wicked_pdf'
gem 'wkhtmltopdf-binary'

控制器

format.pdf do
  render pdf: "day_report", 
  template: 'day/day_report',
  page_size: 'A4'
end

application.html.erb

<head>
 <title>Page Title</title>
 <%= wicked_pdf_stylesheet_link_tag "styles" %>
 <%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track': 'reload' %>
 <%= javascript_include_tag 'application', 'data-turbolinks-track': 'reload' %>
</head>

day_report.pdf.erb

<%= wicked_pdf_image_tag( 'logo.jpg', height: '100', width: '100') %>

<div class="page-header">
    Day Report
</div>

styles.css

.page-header {
  padding: 40px 0;
  background-color: red;
  text-color: #fff;
}

能否请您将 styles.css 重命名为 styles.css.scss 并将此文件添加到预编译列表 Rails.application.config.assets.precompile += %w(styles.css) 并尝试。

如下所示为 pdf 创建不同的布局。例如 pdf.html.erb

<!DOCTYPE html>
<html>
<head>
  <title>Page title</title>
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <%= stylesheet_link_tag 'application', media: 'all', 'data-turbolinks-track': 
  'reload' %>
  <%= wicked_pdf_stylesheet_link_tag "styles" %>
  <%= javascript_include_tag 'application', 'data-turbolinks-track': 'reload'%>
</head>
<body>
  <%= yield %>
</body>
</html>

将控制器动作更改为:

format.pdf do
  layout:'pdf.html',
  render pdf: "day_report", 
  template: 'day/day_report',
  page_size: 'A4',
  encoding:"UTF-8"
end

将styles.css改为styles.scss并添加assets.rb.

Rails.application.config.assets.precompile += %w(styles.scss)

希望这会有所帮助。

干杯