使用 jsPDF 時(shí),需要注意的是其默認(rèn)單位為 mm,需要在 new jsPDF() 時(shí)傳入配置
目前創(chuàng)新互聯(lián)已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、網(wǎng)站托管運(yùn)營(yíng)、企業(yè)網(wǎng)站設(shè)計(jì)、昭平網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶(hù)導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶(hù)和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
const doc = new jsPDF({
unit: 'px',
format: 'a4'
})
這個(gè)方法廢了。這個(gè)鬼東西多行文本和多個(gè)圖片,簡(jiǎn)直要人命!
使用 Vue.js ,需要 *** 支持,否則頁(yè)面為空白
使用 Nuxt.js 作為服務(wù)端渲染框架,這里記錄一下遇到的問(wèn)題和解決方案
Element UI 版本問(wèn)題,使用最新的 2.8.x 會(huì)出現(xiàn)問(wèn)題,則需要降版本并在 package.json 中配置版本策略,僅更新小版本范圍
"element-ui": "~2.4.11",
在使用 wkhtmltopdf 時(shí),提示報(bào)錯(cuò):Warning: http://localhost:3000/_nuxt/vendors.app.js:1941 SyntaxError: Parse error
,估計(jì)是 ES6 的語(yǔ)法在wkhtmltopdf 的運(yùn)行環(huán)境當(dāng)中不支持,導(dǎo)致出現(xiàn)了這些錯(cuò)誤提示。
官方Nuxt.js 2.6.X 版本其實(shí)給了 babel 的配置,默認(rèn)會(huì)自動(dòng)根據(jù)瀏覽器的運(yùn)行環(huán)境做代碼兼容,并不需要以下的這些設(shè)置(下面只是自己的實(shí)踐過(guò)程,供參考),請(qǐng)直接使用第3點(diǎn)的解決方法。
Nuxt.js 2.6.X 文檔
通過(guò)查找資料,發(fā)現(xiàn) Nuxt.js 并沒(méi)有加入 Babel 進(jìn)行 ES6 -> ES5 的轉(zhuǎn)換,下面是解決方法
web前端開(kāi)發(fā)學(xué)習(xí)Q-q-u-n: 784783012 ,分享學(xué)習(xí)的方法和需要注意的小細(xì)節(jié),不停更新最新的教程和學(xué)習(xí)方法
(從零基礎(chǔ)開(kāi)始到前端項(xiàng)目實(shí)戰(zhàn)教程,學(xué)習(xí)工具,職業(yè)規(guī)劃)
extend(config, ctx) {
// Run ESLint on save
if (ctx.isDev && ctx.isClient) {
config.module.rules.push(
{
enforce: 'pre',
test: /\.(js|vue)$/,
loader: 'eslint-loader',
exclude: /(node_modules)/
},
// 添加下方內(nèi)容
{
test: /\.js$/,
loader: 'babel-loader',
exclude: /(node_modules)/
}
)
}
}
.babelrc
文件{
"presets": [
[
"@babel/preset-env",
{
"useBuiltIns": "entry",
"corejs": "2",
}
]
],
"plugins": [
"@babel/plugin-syntax-dynamic-import"
]
}
以上設(shè)置完后,可能會(huì)提示以下類(lèi)似的錯(cuò)誤
ERROR in ./.nuxt/client.js
Module build failed (from ./node_modules/babel-loader/lib/index.js):
Error: Cannot find module 'babel-preset-env' from '/Users/wyj/Workspace/nuxt-example'
- Did you mean "@babel/env"?
at Function.module.exports [as sync] (/Users/wyj/Workspace/nuxt-example/node_modules/resolve/lib/sync.js:58:15)
at resolveStandardizedName (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/files/plugins.js:101:31)
at resolvePreset (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/files/plugins.js:58:10)
at loadPreset (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/files/plugins.js:77:20)
at createDescriptor (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/config-descriptors.js:154:9)
at items.map (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/config-descriptors.js:109:50)
at Array.map ()
at createDescriptors (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/config-descriptors.js:109:29)
at createPresetDescriptors (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/config-descriptors.js:101:10)
at presets (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/config-descriptors.js:47:19)
at mergeChainOpts (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/config-chain.js:320:26)
at /Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/config-chain.js:283:7
at buildRootChain (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/config-chain.js:120:22)
at loadPrivatePartialConfig (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/partial.js:85:55)
at Object.loadPartialConfig (/Users/wyj/Workspace/nuxt-example/node_modules/@babel/core/lib/config/partial.js:110:18)
at Object. (/Users/wyj/Workspace/nuxt-example/node_modules/babel-loader/lib/index.js:144:26)
根據(jù)錯(cuò)誤提示,說(shuō)明 babel-preset-env
還沒(méi)有安裝,命令行中執(zhí)行相應(yīng)的包,安裝一下即可
yarn add @babel/preset-env core-js@2 -D
注意,這里的 corejs 版本為 2,使用 3 會(huì)出現(xiàn)以下錯(cuò)誤
friendly-errors 01:38:28 ERROR Failed to compile with 35 errors
friendly-errors 01:38:28 These dependencies were not found:
friendly-errors 01:38:28
friendly-errors 01:38:28 * core-js/modules/es6.array.find in ./.nuxt/client.js
friendly-errors 01:38:28 * core-js/modules/es6.array.iterator in ./.nuxt/client.js
friendly-errors 01:38:28 * core-js/modules/es6.date.to-string in ./.nuxt/utils.js
friendly-errors 01:38:28 * core-js/modules/es6.function.name in ./.nuxt/client.js
friendly-errors 01:38:28 * core-js/modules/es6.object.assign in ./.nuxt/client.js
friendly-errors 01:38:28 * core-js/modules/es6.object.keys in ./.nuxt/client.js
friendly-errors 01:38:28 * core-js/modules/es6.object.to-string in ./.nuxt/client.js
friendly-errors 01:38:28 * core-js/modules/es6.promise in ./.nuxt/client.js
friendly-errors 01:38:28 * core-js/modules/es6.regexp.constructor in ./.nuxt/utils.js
在 nuxt.config.js 中加入兼容的 js 文件
|
`head``: {`
`//` `...`
`script: [`
`{`
`src:`
`'[https://cdnjs.cloudflare.com/ajax/libs/es5-shim/4.5.10/es5-shim.min.js](https://cdnjs.cloudflare.com/ajax/libs/es5-shim/4.5.10/es5-shim.min.js)'`
`},`
`{`
`src:` `'[https://cdnjs.cloudflare.com/ajax/libs/json3/3.3.2/json3.min.js](https://cdnjs.cloudflare.com/ajax/libs/json3/3.3.2/json3.min.js)'`
`},`
`{`
`src:`
`'[https://cdnjs.cloudflare.com/ajax/libs/es6-shim/0.35.3/es6-sham.min.js](https://cdnjs.cloudflare.com/ajax/libs/es6-shim/0.35.3/es6-sham.min.js)'`
`},`
`{`
`src:`
`'[https://cdnjs.cloudflare.com/ajax/libs/es7-shim/6.0.0/es7-shim.min.js](https://cdnjs.cloudflare.com/ajax/libs/es7-shim/6.0.0/es7-shim.min.js)'`
`},`
`{`
`src:`
`'[https://cdnjs.cloudflare.com/ajax/libs/babel-polyfill/6.16.0/polyfill.min.js](https://cdnjs.cloudflare.com/ajax/libs/babel-polyfill/6.16.0/polyfill.min.js)'`
`}`
`]`
`}`
|
然后將代碼打包出來(lái)再運(yùn)行即可,就不會(huì)出現(xiàn)不兼容的問(wèn)題了**(注意,之前我用 yarn dev 運(yùn)行,還是會(huì)出現(xiàn)第3點(diǎn)的錯(cuò)誤,然而 generate 出來(lái)之后,就好了,估計(jì)webpack熱更新里面的代碼不兼容wkhtmltopdf的運(yùn)行環(huán)境)**
yarn generate
yarn start
運(yùn)行 wkhtmltopdf 命令,開(kāi)啟 JavaScript 調(diào)試模式、延遲10秒保證頁(yè)面接口請(qǐng)求完畢渲染完成
wkhtmltopdf --enable-javascript --debug-javascript --javascript-delay 10000 http://localhost:3000/echarts 1.pdf
最后的測(cè)試效果,圖表和其他內(nèi)容都呈現(xiàn)出來(lái)了