1.安装
npm install print-js --save
//or
yarn add print-js
2.在需要使用的文件引入
import printJS from 'print-js'
Print.js有四种打印类型:'pdf'、'html'、'image'、'json'。
它的基本用法是调用printJS()并传入参数
//pdf打印 传入PDF文档url
printJS('docs/PrintJS.pdf')
//图片打印 传入图片url,第二个参数:'image'
printJS('images/PrintJS.jpg', 'image')
//html打印 第一个参数:元素id,第二个参数:'html'
printJS('myElementId', 'html')
//json打印 当打印Json数据时,传入要打印的数据、类型和数据属性
printJS({printable: myData, type: 'json', properties: ['prop1', 'prop2', 'prop3']})
Print.js接受一个对象作为参数,在这里你可以配置一些选项:
| 字段 | 默认值 | 说明 |
| printable | null | 数据源:pdf or image的url,html类型则填打印区域元素id,json类型则是数据object。 |
| type | 'pdf' | 可选类型:pdf, html, image, json。 |
| header | null | 应用于页面顶部标题文本。 |
| headerStyle | 'font-weight: 300;' | 应用于标题文本的可选标题样式。 |
| maxWidth | 800 | 最大文档宽度(像素)。 |
| css | null | 这允许我们传递一个或多个css文件的url,应该应用到正在打印的html。Value可以是包含单个URL的字符串,也可以是包含多个URL的数组。 |
| style | null | 这允许我们传递一个自定义样式的字符串,该字符串应应用于正在打印的html。 |
1.打印Html
<div id="printJS-HTML" style="display:none;">
<div v-for="index in 5" :key="index">
<table>
<tr>
<td>序号</td>
<td>作者</td>
</tr>
<tr>
<td>1</td>
<td>Ghmin</td>
</tr>
</table>
<!-- 控制打印分页的关键 -->
<div class="paging"></div>
</div>
</div>
<button @click="printHtml">打印 HTML</button>
const printHtml=()=>{
//在页面显示需打印区域来获取dom
document.querySelector('#printJS-HTML').style.display = 'block'
printJS({
printable: 'printJS-HTML',//打印区域id
type: 'html',//打印类型
style: `@page { size: auto; } .paging{page-break-after: always;}`,
})
//获取打印内容后隐藏dom
document.querySelector('#printJS-HTML').style.display = 'none'
}
这里 .paging{page-break-after: always;}样式就是控制分页的关键。
2.打印图片
打印图片的话可以使用上面第一种Html的方式,但更推荐使用Print.js提供的"image"打印类型
printJS({
printable: ['第一张图片Url','第二张图片Url','第三张图片Url'],
type: 'image',
header: null,
imageStyle: `display: block;margin: 0 auto;page-break-after: always;max-width:100%`
})
相对于Html方式这个更简单,传入需要打印的图片url数组即可。
更多内容可访问 Print.js官网:https://printjs.crabbly.com/
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
所以我在关注Railscast,我注意到在html.erb文件中,ruby代码有一个微弱的背景高亮效果,以区别于其他代码HTML文档。我知道Ryan使用TextMate。我正在使用SublimeText3。我怎样才能达到同样的效果?谢谢! 最佳答案 为SublimeText安装ERB包。假设您安装了SublimeText包管理器*,只需点击cmd+shift+P即可获得命令菜单,然后键入installpackage并选择PackageControl:InstallPackage获取包管理器菜单。在该菜单中,键入ERB并在看到包时选择
我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R
我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden
我正在使用Rails构建一个简单的聊天应用程序。当用户输入url时,我希望将其输出为html链接(即“url”)。我想知道在Ruby中是否有任何库或众所周知的方法可以做到这一点。如果没有,我有一些不错的正则表达式示例代码可以使用... 最佳答案 查看auto_linkRails提供的辅助方法。这会将所有URL和电子邮件地址变成可点击的链接(htmlanchor标记)。这是文档中的代码示例。auto_link("Gotohttp://www.rubyonrails.organdsayhellotodavid@loudthinking.
我是Rails的新手,所以请原谅简单的问题。我正在为一家公司创建一个网站。那家公司想在网站上展示它的客户。我想让客户自己管理这个。我正在为“客户”生成一个表格,我想要的三列是:公司名称、公司描述和Logo。对于名称,我使用的是name:string但不确定如何在脚本/生成脚手架终端命令中最好地创建描述列(因为我打算将其设置为文本区域)和图片。我怀疑描述(我想成为一个文本区域)应该仍然是描述:字符串,然后以实际形式进行调整。不确定如何处理图片字段。那么……说来话长:我在脚手架命令中输入什么来生成描述和图片列? 最佳答案 对于“文本”数
我需要一个表,其中行实际上是2行表,一个嵌套表是..我怎样才能在Prawn中做到这一点?也许我需要延期..但哪一个? 最佳答案 现在支持子表:Prawn::Document.generate("subtable.pdf")do|pdf|subtable=pdf.make_table([["sub"],["table"]])pdf.table([[subtable,"original"]])end 关于ruby-on-rails-PrawnPDF:Ineedtogeneratenested
我正在学习http://ruby.railstutorial.org/chapters/static-pages上的RubyonRails教程并遇到以下错误StaticPagesHomepageshouldhavethecontent'SampleApp'Failure/Error:page.shouldhave_content('SampleApp')Capybara::ElementNotFound:Unabletofindxpath"/html"#(eval):2:in`text'#./spec/requests/static_pages_spec.rb:7:in`(root)'
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o