生活工程体验信仰哲学精神
投稿投诉
精神世界
探索历史
哲学文学
艺术价值
信仰创造
境界审美
体验技术
技能工具
工程信息
医学生产
生活运用
操作能力

电子签章处理文件和打印基于ABP框架的前端项目Vueampa

3月11日 倾城傷投稿
  在一些内部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
投诉 评论 转载

种田才是王道!模拟农场22在欧洲销量超2021年多款大作《模拟农场22》自11月份发布以来,一直在打破该系列的记录。该游戏在第一周的销量迅速上升至150万,在Steam上的销量和最高玩家人数方面超过《战地2042》。而欧洲人对这款游……高鹏说药材家庭煎煮代煎,免煎中药,选择哪种方式更实惠?当前人们越来越重视中医养生,健康保健。近年来,中医药在疾病预防、治疗、康复,特别是疫病方面具有独特的优势。中药有丸、散、膏、丹,运用最多的是汤剂。随着科技的进步,中医药逐步发展……新手如何开快递驿站代收快递驿站怎么开?2022年想开快递驿站代收点怎么入手,新手如何开快递驿站代收在这里我推荐快递第三方平台八戒快递驿站一、店址问题快递驿站怎么开?店址选得好,快递驿站的包裹数量就会有保……何炅出事,谢娜吃红利说起来上一次何炅爆出新消息,还是他深夜街头买醉,抱着周迅痛哭流涕呢,而当时他也是借机狠狠卖了一波惨,他的粉丝更是重拳出击,在各大社交平台发帖留言,为何老师抱屈,说什么何老师是娱……宇宙只有一个电子?单电子假设探究了反物质与时间反转的联系1940春天,物理学家约翰惠勒灵光一现,他给理查德费曼打了电话:我知道为什么所有电子都具有相同的电荷和相同的质量了,因为它们都是同一个电子。惠勒描述的这种方法是单电子宇宙的想法……人生除了喜乐,还是喜乐很多人读杨定一博士全部生命系列的书,有一个最大的感受烧脑。我也有同感。尽管如此,我还是非常喜欢读他的书,因为烧脑的同时被疗愈了,心里会生出喜悦,越读心里越开阔清朗。……关于如何正确叫孩子起床叫孩子起床关于叫孩子起床1。家长要怀着一定能将孩子叫起来的信念和毅力去交叫。2。提前一天说好:孩子需要几点起,家长会在几点叫。3。叫的时候采取的方式是:……北京冬奥会开幕式灯光设计解析2022年北京冬季奥运会开幕式2022年2月4日,立春。北京,这座双奥之城在鸟巢点燃奥运圣火,开启冬奥会开幕式。一场不一样的开幕式!考虑到节俭办赛、天气……每一个清晨,都是新的开始每一个清晨,都是新的开始,如果是晴天,就好好的感受温暖的阳光,如果是阴天,就自个儿从心里长出个太阳来,温暖自己。以阳光的心态,迎接每一个清晨,心态充满阳光,世界也因你而阳……切阳什姐称递补金牌开心又难过来源:人民日报体育时隔十年终于递补奥运金牌,切阳什姐发微博表示:开心又难过。开心的是我能成为自己心中的冠军,开心我可以拥有奥运金牌,虽然很多事情已经过去了,也不会拥有,但……电子签章处理文件和打印基于ABP框架的前端项目Vueampa在一些内部OA或者流转的文件,或者给一些客户的报价文件、合同,或者一些医院出示的给保险机构的病历资料等,有时候可能都希望快速的使用电子签章的处理方式来给文件盖上特定的印章,本篇……从测量员7号,到阿波罗11,美国登月为何少了无人采样返回这一上世纪60年代末到70年代初,美国先后进行了7次载人登月,其中6次成功,仅有1次失败。要知道,阿波罗11号阿姆斯特朗成功登月,距离人类发射第一颗卫星才刚刚过去约12年,距离加加……
换季如何呵护宝宝健康?葵花药业发来护娃宝典科尔接下来克莱和普尔都会发挥出高水准球队表现会更加稳定有一个地方叫鲅鱼圈生了病的城市水果和蔬菜都要吃王思聪也来投新材料了大量中企入局后,腾讯也要发力RISCV芯片?20221123尿素钾肥行情名导太太陈红封杀杨幂打压谢霆锋,踩洪晃上位获陈凯歌独宠106公斤独立分区全能洗烘,TCL双子舱复式分区洗衣机Q10刘加林鄱阳故乡处暑徐如玉酒后有感秋游有感教育部发布新版职业教育专业简介,工业互联网专业建设全面提速关于企业安全承诺书合集九篇建设土地使用权属于刚劲造句用刚劲造句大全哪些食品适合痴呆老人奥运最后一天!美国狂揽金牌,或将在最后一天反超中国成第一初中生什么的变化作文是什么导致看NBA的人越来越少?没时间只是借口这5点是关键你是怀才不遇还是压根没有能力蜂蜜如何搭配喝最好?便利店成了新风口曾经风光一时的怎么办美体内衣免费送是如何赚钱的,高手都在用这种套路抖音运营方案怎么写

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找