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

做网站 长化妆品营销型网站案例

做网站 长,化妆品营销型网站案例,重庆网站建设的公司,设计说明模版数据量太大使用dom》canvas》image》pdf.addimage方法弊端是canvas超出 浏览器承受像素会图片损害,只能将其切割转成小块的canvas,每一次调用html2canvas等待时间都很长累积时间更长,虽然最终可以做到抽取最小dom节点转canvas拼接数据,但是死…

数据量太大使用dom=》canvas=》image=》pdf.addimage方法弊端是canvas超出

浏览器承受像素会图片损害,只能将其切割转成小块的canvas,每一次调用html2canvas等待时间都很长累积时间更长,虽然最终可以做到抽取最小dom节点转canvas拼接数据,但是死卡

jspdf提供了不需要操作dom的方法,

Global - Documentation

 使用line方法和text方法可以通过传递线坐标和文字位置在pdf页上画线和文字,组成表格

function getStrLen(cItem, strLen) {let str = typeof cItem === 'string' || typeof cItem === 'number' ? cItem : 'null'let len = Math.ceil(str.length / strLen)if (len <= 1) {return str}str = String(str)let strn = ''for (let i = 0; i < len; i++) {strn = strn + str.substring(i * strLen, (i + 1) * strLen) + '\n'}return strn
}async function downPDF(list, columns) {// 1in = 2.54cm = 25.4 mm = 72pt = 6pclet tablePdf = null
//绘制表格的参数let cardTop = 10, cardLeft = 7, textLeft = 9, textTop = 14, oneColumnNum = 35, oneRowNum = 7, oneCellWidth = 28, oneCellHeight = 8, oneStrLen = 5, pdfWidth = 203, pdfHeight = 290, strLen = 8let endPageNum = 0
//表格数据的整理
//整理格式成一个二维数组,第一层以列为单个元素,元素是整列的值组成的数组let testList = columns[0].childrenlet propList = testList.map((item) => {return { prop: item.props.prop, label: item.props.label }})let dataList = []propList.forEach((item, index) => {let cArr = []cArr.push(item.label)list.forEach((cItem, cIndex) => {cArr.push(cItem[item.prop])})dataList.push(cArr)})console.log(dataList)//处理好表格数据的二维数组,配置pdf对象tablePdf = new jsPDF('p', 'mm', 'a4');
//解决中文乱码tablePdf.addFont("/fonts/SourceHanSansCN-Normal.ttf", "SourceHanSans", "normal")tablePdf.setFont("SourceHanSans");//1)doc中设置font: "SourceHanSans" // 2)style中设置tablePdf.setLineWidth(0.1)tablePdf.setFontSize(8)tablePdf.line(cardLeft, cardTop, pdfWidth, cardTop);let columnPages = Math.ceil(dataList.length / oneRowNum) + 1let rowPages = Math.ceil(dataList[0].length / oneColumnNum) + 1let currentData = []for (let i = 1; i < columnPages; i++) {
//横向分页let currentColumnData = dataList.slice((i - 1) * oneRowNum, i * oneRowNum)
//纵向分页for (let rowInddex = 1; rowInddex < rowPages; rowInddex++) {currentData = currentColumnData.map((item, index) => {return item.slice((rowInddex - 1) * oneColumnNum, rowInddex * oneColumnNum)})currentData.forEach((item, index) => {item.forEach((cItem, cIndex) => {cItem = getStrLen(cItem, strLen)//填文字,超过长度换行tablePdf.text(cItem, textLeft + index * oneCellWidth, textTop + cIndex * oneCellHeight, 'left')//画一次横线if (index === currentData.length - 1) {tablePdf.line(cardLeft, cardTop + cIndex * oneCellHeight, pdfWidth, cardTop + cIndex * oneCellHeight);//画最后一条横线if (cIndex === item.length - 1) {tablePdf.line(cardLeft, cardTop + (cIndex + 1) * oneCellHeight, pdfWidth, cardTop + (cIndex + 1) * oneCellHeight);endPageNum = item.lengthlet ks = (pdfHeight - cardTop) / oneColumnNumfor (let l = 0; l < oneRowNum + 1; l++) {tablePdf.line(cardLeft + l * oneCellWidth, cardTop, cardLeft + l * oneCellWidth, endPageNum * ks + cardTop);}}}})});if (rowInddex + 1 !== rowPages) {tablePdf.addPage();}}if (i + 1 !== columnPages) {tablePdf.addPage();}}tablePdf.save('dd.pdf')
}

 数组datalist结构

效果

http://www.yayakq.cn/news/549974/

相关文章:

  • 网站建设与管理题有哪些游戏可以做网站
  • 四川营销网站建设推广软文范例大全500
  • 网站域名使用费多少监控视频怎么做直播网站
  • 温州网站推广公司中山专业外贸网站开发公司
  • 秦皇岛市建设局网站苏州网站优化建设
  • 网络公司网站制作岗位职责为什么没人做同城购物网站
  • 网站备案掉了精简版wordpress
  • 山西建设网站的公司页面设计中为什么要有优先级排列
  • 忻州市建设厅网站首页建设商城网站制作
  • 易无忧建站重庆市建设厅网站首页
  • 做网站打算套用模板重庆网站建设团队
  • 自己做首饰的好网站深汕特别合作区包括哪些地方
  • 聊城网站建设工作室中国工程建筑网
  • 永川集团网站建设做破解的网站
  • 固原市建设局网站个人网站制作wordpress
  • 正规的佛山网站建设wordpress空间转移
  • 怎么做淘宝客个人网站深圳专业设计网站平台
  • 福田网站建设推广物联网技术是学什么的
  • 织梦网站模板免费宁波正规网络推广多少钱
  • 建设彩票开奖网站ASP.NET与网站开发编程实战
  • 西安网站建设雄账号做原创短视频网站
  • 制作网站网站如何更换网站的logo
  • 枣强网站建设公司wordpress docker中文文档
  • 企业建设网站有用么免费logo商标设计
  • 做网站收入怎样开发者大会
  • 做图模板网站有哪些网站开发兼职群
  • 上海门户网站制作公司wordpress主题播放音乐不刷新
  • 免费下载软件大厅福州seo网站推广优化
  • WordPress偷模板优化网站要怎么做
  • 网站建设续费是什么费用手机app安装下载注册