当前位置: 首页 > news >正文

网站失败的原因软文营销网

网站失败的原因,软文营销网,濮阳新闻综合频道回看,全国互联网安全管理服务平台1.安装print.js npm install print-js --save2.在main.js文件中引入并注册(我使用的是print.js的源码文件&#xff0c;并且做了一修改&#xff09; //引入 import Print from ./utils/print//注册 Vue.use(Print); //注册3.在页面中使用 <template> <div class&quo…

1.安装print.js

npm install print-js --save

2.在main.js文件中引入并注册(我使用的是print.js的源码文件,并且做了一修改)

//引入
import Print from './utils/print'//注册
Vue.use(Print); //注册

3.在页面中使用

<template>
<div class="detailsPrint"><div class="move" ref="pdfContent" id="pdfContent">需要打印的内容 </div><el-button type="primary" @click="printPDF">打 印</el-button></div>
</template><script>
export default {name: "",data() {return {};},methods: {// 打印PDFprintPDF() {this.$nextTick(() => {this.$print(this.$refs.pdfContent, {watermark: {companyName: '公司名称',name: '姓名',date: '2024-08-01',}});}},
};
</script>
<style scoped>
//我希望打印出来的格式是A4纸的格式
@media print {@page {size: B5(JIS);margin: 10mm 16mm;margin-top: 8mm;margin-bottom: 8mm;}
}
</style>

4.在utils下新增print.js

/* eslint-disable */
const Print = function (dom, options) {if (!(this instanceof Print)) return new Print(dom, options);this.options = this.extend({'noPrint': '.no-print','watermark': {} // 接受单个水印数据对象}, options);if ((typeof dom) === "string") {this.dom = document.querySelector(dom);} else {this.dom = dom;}setTimeout(() => {this.init();}, 2000);
};Print.prototype = {init: function () {var content = this.getStyle() + this.getHtml();this.writeIframe(content);},extend: function (obj, obj2) {for (var k in obj2) {obj[k] = obj2[k];}return obj;},getStyle: function () {var str = "",styles = document.querySelectorAll('style,link');for (var i = 0; i < styles.length; i++) {str += styles[i].outerHTML;}str += "<style>" + (this.options.noPrint ? this.options.noPrint : '.no-print') + "{display:none;}</style>";str += `<style>.watermark {position: absolute;top: 0;left: 0;width: 100%;height: 100%;opacity: 0.2;pointer-events: none;}.watermark-content {color:rgba(0,0,0,0.4)text-align: center;transform: rotate(-45deg);font-size: 24px;}/* 打印样式 */@media print {body, html {width: 100%;height: 100%;margin: 0;padding: 0;}.watermark {opacity: 0.2;pointer-events: none;position: fixed; /* 修正水印固定位置 */}.watermark-content {text-align: center;transform: rotate(-45deg);font-size: 24px;color:rgba(0,0,0,0.4)}/* 隐藏不需要打印的内容 */${this.options.noPrint} {display: none !important;}/* 设置A4纸大小和页边距 */@page {size: B5(JIS);margin: 10mm 16mm;margin-top: 8mm;margin-bottom: 8mm;}}</style>`;return str;},getHtml: function () {var inputs = document.querySelectorAll('input');var textareas = document.querySelectorAll('textarea');var selects = document.querySelectorAll('select');for (var k in inputs) {if (inputs[k].type == "checkbox" || inputs[k].type == "radio") {if (inputs[k].checked == true) {inputs[k].setAttribute('checked', "checked")} else {inputs[k].removeAttribute('checked')}} else if (inputs[k].type == "text") {inputs[k].setAttribute('value', inputs[k].value)}}for (var k2 in textareas) {if (textareas[k2].type == 'textarea') {textareas[k2].innerHTML = textareas[k2].value}}for (var k3 in selects) {if (selects[k3].type == 'select-one') {var child = selects[k3].children;for (var i in child) {if (child[i].tagName == 'OPTION') {if (child[i].selected == true) {child[i].setAttribute('selected', "selected")} else {child[i].removeAttribute('selected')}}}}}// 使用传递的单个水印数据对象生成多个随机位置的水印var watermarkHtml = '';var numWatermarks = 12; // 生成的水印数量var leftStart = -50; // 修改此处,从最左边开始的起始位置(百分比)var leftEnd = 95; // 最右边的结束位置(百分比)var topPositions = ['20%', '40%', '60%', '80%']; // 垂直方向的位置var step = (leftEnd - leftStart) / (numWatermarks - 1); // 计算步长for (var i = 0; i < numWatermarks; i++) {var leftPosition = `${leftStart + i * step}%`;var topPosition = topPositions[i % topPositions.length];watermarkHtml += `<div class="watermark" style="top: ${topPosition}; left: ${leftPosition};"><div class="watermark-content"><div> ${this.options.watermark.companyName}</div><div> ${this.options.watermark.name}</div><div> ${this.options.watermark.date}</div></div></div>`;}return this.dom.outerHTML + watermarkHtml;},writeIframe: function (content) {var iframe = document.createElement('iframe');iframe.style = "position:absolute;width:0;height:0;top:-10px;left:-10px;";document.body.appendChild(iframe);var doc = iframe.contentDocument || iframe.contentWindow.document;doc.open();doc.write(content);doc.close();this.toPrint(iframe.contentWindow);setTimeout(function () {document.body.removeChild(iframe);}, 100);},toPrint: function (frameWindow) {try {setTimeout(function () {frameWindow.focus();try {if (!frameWindow.document.execCommand('print', false, null)) {frameWindow.print();}} catch (e) {frameWindow.print();}frameWindow.close();}, 10);} catch (err) {console.log('err', err);}}
};const MyPlugin = {};
MyPlugin.install = function (Vue, options) {Vue.prototype.$print = Print;
};export default MyPlugin;
http://www.hkea.cn/news/394177/

相关文章:

  • 网站建设seo 视频做网站哪个平台好
  • 旅行社网站建设方案论文百度seo公司
  • 长沙网站建设与维护百度开户联系方式
  • 做pcr查基因序列的网站南京百度网站快速优化
  • 数据服务网站策划方案关键词快速优化排名软件
  • 响应式网站缺点学大教育培训机构电话
  • 江苏天德建设工程有限公司网站一个平台怎么推广
  • 石家庄做网络推广的网站推广平台收费标准
  • 贵阳天柱网站建设招聘域名注册平台有哪些
  • 网站建设电话营销百度问一问官网
  • 网站优化建设河南怎么关闭seo综合查询
  • 自贡做响应式网站开发公司google搜索引擎入口google
  • 东莞哪种网站推广好微信朋友圈推广文案
  • 现在学做网站赚钱吗东莞市优速网络科技有限公司
  • 宁津做网站公司宣传推广图片
  • 陕西的建设厅官方网站数据分析报告
  • 企业网站建设的定位互联网
  • 注册域名之后如何做网站优化清理大师
  • wordpress+在线播放推广seo网站
  • 丽水网站建设明恩玉杰网站开发框架
  • 如何设计网站中的上传功能搜索引擎技术基础
  • 余江区建设局网站百度搜索引擎优化的方法
  • 做网站用c 还是java万网域名注册教程
  • 青岛做网站那家好专业的网站优化公司排名
  • 网站如何做淘宝推广seo服务 收费
  • 学完js了可以做哪些网站营业推广的形式包括
  • 网站会员系统怎么做模版seo是指什么职位
  • 上海集团网站制作新闻 近期大事件
  • 商城网站验收标准seo关键词排名优化怎样收费
  • 睢宁做网站公司珠海百度关键字优化