在一些内部OA或者流转的文件,或者给一些客户的报价文件、合同,或者一些医院出示的给保险机构的病历资料等,有时候可能都希望快速的使用电子签章的处理方式来给文件盖上特定的印章,本篇随笔介绍基于VueElement的前端项目采用第三方组件 vuedragresize和图片转换Base64的方式实现图片印章的盖章处理。1、图片转换为Base64处理 图片转换为Base64编码可以通过在线工具的转换方式实现图片转Base64编码,网上很多在线的处理,百度一下即可。 如:https:c。runoob。comfrontend59或者https:tool。chinaz。comtoolsimgtobase试过都可以,非常方便。 如果我们喜欢通过C代码进行图片的转换也可以使用自己封装的函数实现处理,如下所示。 Base64在CSS中的使用。demoImg{backgroundimage:url(img01。bs178。combcwh1a1ee134683cb153。jpg);} Base64在HTML中的使用imgwidth40height30srca2020imgdataimg。jpgdatasrcimg01。bs178。combcwh1a1ee134683cb153。jpg 我们使用C代码转换的处理代码如下所示。privatevoidbtnBase64Click(objectsender,EventArgse){varbase64ImageHelper。ImageToBase64Str(this。pictureBox1。Image);if(chkData。Checked){base64data:base64,base64;}this。txtBase64。Textbase64;} 而其中调用是通过我们公用类库中的图片辅助类进行,详细转换代码如下所示。summary从文件中转换图片对象到Base64编码summaryparamnameimageFilePath图片文件路径paramreturnsreturnspublicstaticstringImageToBase64Str(stringimageFilePath){ImageimageImage。FromFile(imageFilePath);using(MemoryStreammsnewMemoryStream()){image。Save(ms,image。RawFormat);ImageFormat。Jpegbyte〔〕imageBytesms。GetBuffer();stringimgBase64StrConvert。ToBase64String(imageBytes);释放资源,让别的使用image。Dispose();returnimgBase64S}}summary转换图片对象到Base64编码summaryparamnameimageImage图片对象paramreturnsreturnspublicstaticstringImageToBase64Str(Imageimage){using(MemoryStreammsnewMemoryStream()){image。Save(ms,image。RawFormat);ImageFormat。Jpegbyte〔〕imageBytesms。GetBuffer();stringimgBase64StrConvert。ToBase64String(imageBytes);returnimgBase64S}} 这样,我们在前端Vue的项目中,就可以赋值这段图片Base64代码到HTML文件中就可以了,如下是前端Vue项目代码所示(缩减了部分Base64编码)。 这样我们就可以在页面中放置一个Base64编码的图片在页面中了。 2、使用vuedragresize组件实现印章图片的拖动 常规的图片,放置在页面中,位置是固定的,如果我们需要拖动印章,那么就需要引入可拖动面板的Vue组件vuedragresize来处理它了。 vuedragresize是Github上的一个开源组件,地址是:https:github。comkirillmurashovvuedragresize 这个组件的使用和其他组件的使用方式一样,非常方便。importVuefromvueimportVueDragResizefromvuedragresizeVue。component(vuedragresize,VueDragResize) 在组件或者页面中使用的代码如下所示。importVueDragResizefromvuedragresizeexportdefault{components:{VueDragResize}, 它的HTML代码如下所示。templateVueDragResize:isActivetrue:w200:h200von:resizingresizevon:draggingresizeh3HelloWorld!h3p{{top}}{{left}}p{{width}}{{height}}VueDragResizetemplate 为了把印章图片可以拖动,我们在HTML中放置印章图片包含在这个组件面板中。 如下面代码所示。 把图片放置在这个组件容器中后,图片就可以随意拖动,确认位置后,就可以确定它的位置,我们可以通过记录图片的位置X,Y的值并存储起来,下次直接确定位置也可以。 定义组件的初始X位置。vuedragresize:x0 定义组件的初始Y位置。vuedragresize:y0 例如我们定义了一个报价单,并通过设置,把图片放置在页面中,让使用者可以通过拖动印章的方式,放到合适的位置上去,然后进行打印报价单即可带有印章的报价单出来了。 这样就可以实现电子印章的拖动和放置处理了,记住其位置和状态,下次就可以直接定位到指定的位置上了。 另外,一般文档都需要打印,关于打印的处理,有很多方式,可以使用print。js(https:github。comcrabblyPrint。js),也可以使用vueprintnb(https:github。comPowerkxLeevueprintnb),甚至复杂的定义可以考虑使用CLODOP组件来处理,不过我们这里可以简单的内置Windows对象的打印操作方式来处理普通的页面打印即可。 print(){constprintthis。refs。print。innerHTMLconstprintPconstnewTabwindow。open(blank);newTab。document。body。innerHTMLprintPnewTab。print();newTab。close();}, 打印效果如下所示,采用了对应的CSS样式处理后,和实际的页面效果相当。 在项目中,涉及到了html内容打印的需求,调用了浏览器的window。print用于打印显示不全问题 由于window。print是1:1打印,打印内容过宽时,浏览器会自动从左截取掉超宽部分,因此在打印前需将页面进行调整 打印页边距设定为0mm时,网页内最大元素的分辨率:7941123 因此可以将内容p设置为700px,剩余空间设置为页边距去除浏览器默认页眉页脚 页眉打印默认有页眉页脚信息,展现到页面外边距范围,我们可以通过去除页面模型page的外边距,使得内容不会延伸到页面的边缘,再通过设置body元素的margin来保证A4纸打印出来的页面带有外边距 由于window。print打印自带页眉页脚,用于存放打印url,日期时间,页面名称等内容,为屏蔽这些内容可使用css进行屏蔽mediaprint{page{margin:0;}body{margin:1}} 只屏蔽页脚page{marginbottom:0;}事件监听 有两个事件可以监听到到打印事件,一个是beforeprint,一个是afterprint,分别表示打印事件触发前后。 这个事件在IE6就已经支持了,兼容大概是Firefox、IE全支持,Chrome63支持,Safari暂不支持 我们可在处理事件onbeforeprint()将一些不需要打印的元素隐藏,和打印后的处理事件onafterprint()放开隐藏的元素window。addEventListener(beforeprint,(){document。body。innerHTML打印前触发;});window。addEventListener(afterprint,(){document。body。innerHTML打印后触发;});设置打印布局(横向、纵向、边距)mediaprint{page{纵向size:横向size:边距margin:0cm0cm0cm0}} 文章转自https:www。cnblogs。comwuhuacongp16033604。html