關於點擊生成pdf文件並下載到本地的功能

後端

引入模塊

async =  require 'async'

fs = require 'fs'

寫入文件

writeFile = (address, str, cbf) ->
  write = fs.writeFileSync(address,str)
  return cbf null, write

生成html文件

htmlFile = (address, option, cbf) ->
  html = fs.readFileSync(address,option)
  return cbf null, html

生成pdf文件

pdfFile = (html, address, cbf) ->
  # console.log "html",html
  options = { format: 'A3' }
  pdf.create html, options
    .toFile address, (err, res) ->
      if (err) 
        return console.log err
      return cbf null,"success"

刪除html文件

deteleHtml = (address, cbf) ->
  fs.unlink address, (err,res) ->
    if (err) 
      return console.log err
    return cbf null, 'detele success'

調用

funcs = [
  # 寫入文件
  (cbf) ->
    return writeFile htmlAdr, params.str, cbf
  # 生產html文件
  (result1,cbf) ->
    return htmlFile htmlAdr, 'utf-8', cbf
  # 生產pdf文件
  (result2,cbf) ->
    return pdfFile result2, pdfAdr, cbf
  # 刪除html文件
  (result3,cbf) ->
    return deteleHtml htmlAdr, cbf
]
async.waterfall funcs, (error, result) ->
  if error
    return cbf error, null
  # 返回用戶信息
  res.download pdfAdr, fileName

前端

a(href="javascript:;" v-on:click.stop.prevent="onDownEsignatureLh(esignature_lh);") 下載
a = document.createElement "a"
url = window.URL.createObjectURL res.body
a.href = url
a.download = esignature_lh.ciphertext + ".pdf"
a.click()
window.URL.revokeObjectURL res.body
相關文章
相關標籤/搜索