{"id":6649,"date":"2023-06-14T17:25:59","date_gmt":"2023-06-14T09:25:59","guid":{"rendered":"https:\/\/app.applebyme.cn\/cloud\/?p=6649"},"modified":"2023-06-14T17:25:59","modified_gmt":"2023-06-14T09:25:59","slug":"vue%e5%89%8d%e7%ab%af%e5%bc%80%e5%8f%91%e6%88%aa%e5%9b%be%e5%8a%9f%e8%83%bd%e6%80%8e%e4%b9%88%e5%81%9a%ef%bc%9f","status":"publish","type":"post","link":"https:\/\/app.applebyme.cn\/cloud\/appkaifa\/6649.html","title":{"rendered":"vue\u524d\u7aef\u5f00\u53d1\u622a\u56fe\u529f\u80fd\u600e\u4e48\u505a\uff1f"},"content":{"rendered":"<p>Vue\u524d\u7aef\u5f00\u53d1\u622a\u56fe\u529f\u80fd\u662f\u6307\u5728Vue\u6846\u67b6\u4e0b\uff0c\u5b9e\u73b0\u7f51\u9875\u622a\u56fe\u7684\u529f\u80fd\u3002\u8fd9\u4e2a\u529f\u80fd\u5728\u5f88\u591a\u573a\u666f\u4e0b\u90fd\u975e\u5e38\u6709\u7528\uff0c\u6bd4\u5982\u7f51\u7ad9\u6d4b\u8bd5\u3001\u5206\u4eab\u3001\u62a5\u544a\u64b0\u5199\u7b49\u7b49\u3002\u4e0b\u9762\u5c06\u8be6\u7ec6\u4ecb\u7ecdVue\u524d\u7aef\u5f00\u53d1\u622a\u56fe\u529f\u80fd\u7684\u539f\u7406\u548c\u5b9e\u73b0\u65b9\u6cd5\u3002<\/p>\n<p>\u4e00\u3001\u539f\u7406<\/p>\n<p>\u7f51\u9875\u622a\u56fe\u529f\u80fd\u7684\u539f\u7406\u5c31\u662f\u5229\u7528\u6d4f\u89c8\u5668\u7684\u6e32\u67d3\u5f15\u64ce\u5c06\u9875\u9762\u6e32\u67d3\u6210\u56fe\u7247\uff0c\u7136\u540e\u5c06\u56fe\u7247\u4fdd\u5b58\u4e0b\u6765\u3002\u5728Vue\u6846\u67b6\u4e0b\uff0c\u6211\u4eec\u53ef\u4ee5\u901a\u8fc7Vue\u7ec4\u4ef6\u4e2d\u7684ref\u5c5e\u6027\u83b7\u53d6\u5230DOM\u5143\u7d20\uff0c\u518d\u5229\u7528html2canvas\u7b49\u7b2c\u4e09\u65b9\u5e93\u5c06DOM\u5143\u7d20\u8f6c\u6362\u6210\u56fe\u7247\u3002<\/p>\n<p>\u5177\u4f53\u539f\u7406\u5982\u4e0b\uff1a<\/p>\n<p>1. \u83b7\u53d6DOM\u5143\u7d20<\/p>\n<p>\u5728Vue\u7ec4\u4ef6\u4e2d\uff0c\u6211\u4eec\u53ef\u4ee5\u7ed9\u9700\u8981\u622a\u56fe\u7684DOM\u5143\u7d20\u6dfb\u52a0\u4e00\u4e2aref\u5c5e\u6027\uff0c\u7136\u540e\u901a\u8fc7this.$refs.\u5c5e\u6027\u540d\u83b7\u53d6\u5230DOM\u5143\u7d20\u3002<\/p>\n<p>2. \u5c06DOM\u5143\u7d20\u8f6c\u6362\u6210canvas<\/p>\n<p>\u5229\u7528html2canvas\u7b49\u7b2c\u4e09\u65b9\u5e93\uff0c\u5c06DOM\u5143\u7d20\u8f6c\u6362\u6210canvas\u3002<\/p>\n<p>3. \u5c06canvas\u8f6c\u6362\u6210\u56fe\u7247<\/p>\n<p>\u5229\u7528canvas.toDataURL()\u65b9\u6cd5\uff0c\u5c06canvas\u8f6c\u6362\u6210base64\u683c\u5f0f\u7684\u56fe\u7247\u6570\u636e\u3002<\/p>\n<p>4. \u4e0b\u8f7d\u56fe\u7247<\/p>\n<p>\u5c06base64\u683c\u5f0f\u7684\u56fe\u7247\u6570\u636e\u8f6c\u6362\u6210Blob\u5bf9\u8c61\uff0c\u7136\u540e\u5229\u7528URL.createObjectURL()\u65b9\u6cd5\u751f\u6210\u4e0b\u8f7d\u94fe\u63a5\uff0c\u6700\u540e<a href=\"https:\/\/www.yimenapp.cn\/fengzhuang-1083.html\">vscode\u4e2d\u521b\u5efawebapp<\/a>\u901a\u8fc7a\u6807\u7b7e\u7684download\u5c5e\u6027\u5b9e\u73b0\u56fe\u7247\u4e0b\u8f7d\u3002<\/p>\n<p>\u4e8c\u3001\u5b9e\u73b0\u65b9\u6cd5<\/p>\n<p>\u4e0b\u9762\u662f\u4e00\u4e2a\u7b80\u5355\u7684Vue\u7ec4\u4ef6\uff0c\u5b9e\u73b0\u4e86\u7f51\u9875\u622a\u56fe\u529f\u80fd\uff1a<\/p>\n<p>&#8220;`<\/p>\n<p>\n<p>\n<p>    \u9700\u8981\u622a\u56fe\u7684\u5185\u5bb9<\/p>\n<p>    <button>\u622a\u56fe<\/button><\/p>\n<\/p>\n<\/p>\n<p>import html2canvas from &#8216;html2canvas&#8217;<\/p>\n<p>export default {<\/p>\n<p>  methods: {<\/p>\n<p>    async handleScreenshot() {<\/p>\n<p>      const target = this.$refs.screenshot<\/p>\n<p>      const canvas = await html2canvas(t<\/p>\n<p><figure class=\"wp-block-image\"><img decoding=\"async\" src=\"https:\/\/i.cdn.yimenapp.com\/2023-03\/29\/12\/20293273057.jpg\" \/><\/figure>\n<\/p>\n<p>arget)<\/p>\n<p>      const dataUrl = canvas.toDataURL(&#8216;image\/png&#8217;)<\/p>\n<p>      const blob = this.dataURLtoBlob(dataUrl)<\/p>\n<p>      const url = URL.createObjectURL(blob<a href=\"https:\/\/www.yimenapp.cn\/fengzhuang-1849.html\">ipad \u5f00\u53d1\u8f6f\u4ef6<\/a>)<\/p>\n<p>      const link = document.createElement(&#8216;a&#8217;)<\/p>\n<p>      link.href = url<\/p>\n<p>      link.download = &#8216;screenshot.png&#8217;<\/p>\n<p>      document.body.appendChild(link)<\/p>\n<p>      link.click()<\/p>\n<p>      document.body.removeChild(link)<\/p>\n<p>    },<\/p>\n<p>    dataURLtoBlob(dataURL) {<\/p>\n<p>      const arr = dataURL.split(&#8216;,&#8217;)<\/p>\n<p>      const mime = arr[0].match(\/:(.*?);\/)[1]<\/p>\n<p>      const bstr = atob(arr[1])<\/p>\n<p>      let n = bstr.length<\/p>\n<p>      const u8arr = new Uint8Array(n)<\/p>\n<p>      while (n&#8211;) {<\/p>\n<p>        u8arr[n] = bstr.charCodeAt(n)<\/p>\n<p>      }<\/p>\n<p>      return new Blob([u8arr], { type: mime })<\/p>\n<p>    }<\/p>\n<p>  }<\/p>\n<p>}<\/p>\n<\/p>\n<p>&#8220;`<\/p>\n<p>\u4e0a\u9762\u7684\u4ee3\u7801\u4e2d\uff0c\u6211\u4eec\u901a\u8fc7Vue\u7ec4\u4ef6\u4e2d\u7684ref\u5c5e\u6027\u83b7\u53d6\u5230\u9700\u8981\u622a\u56fe\u7684DOM\u5143\u7d20\uff0c\u7136\u540e\u5229\u7528html2canvas\u5c06DOM\u5143\u7d20\u8f6c\u6362\u6210canvas\uff0c\u6700\u540e\u5229\u7528canvas.toDataURL()\u65b9\u6cd5\u5c06canvas\u8f6c\u6362\u6210base64\u683c\u5f0f\u7684\u56fe\u7247\u6570\u636e\u3002\u5c06\u56fe\u7247\u6570\u636e\u8f6c\u6362\u6210Blob\u5bf9\u8c61\u540e\uff0c\u5229\u7528URL.createObjectURL()\u751f\u6210\u4e0b\u8f7d\u94fe\u63a5\uff0c\u901a\u8fc7a\u6807\u7b7e\u7684download\u5c5e\u6027\u5b9e\u73b0\u56fe\u7247\u4e0b\u8f7d\u3002<\/p>\n<p>\u4e09\u3001\u603b\u7ed3<\/p>\n<p>Vue\u524d\u7aef\u5f00\u53d1\u622a\u56fe\u529f\u80fd\u53ef\u4ee5\u5e2e\u52a9\u6211\u4eec\u5feb\u901f\u5b9e\u73b0\u7f51\u9875\u622a\u56fe\u7684\u529f\u80fd\uff0c\u901a\u8fc7html2canvas\u7b49\u7b2c\u4e09\u65b9\u5e93\u7684\u5e2e\u52a9\uff0c\u6211\u4eec\u53ef\u4ee5\u5f88\u65b9\u4fbf\u5730\u5c06DOM\u5143\u7d20\u8f6c\u6362\u6210canvas\uff0c\u518d\u5c06canvas\u8f6c\u6362\u6210\u56fe\u7247\u3002\u5229\u7528\u8fd9\u4e2a\u529f\u80fd\uff0c\u6211\u4eec\u53ef\u4ee5\u66f4\u52a0\u65b9\u4fbf\u5730\u8fdb\u884c\u7f51\u7ad9\u6d4b\u8bd5\u3001\u5206\u4eab\u3001\u62a5\u544a\u64b0\u5199\u7b49\u5de5\u4f5c\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Vue\u524d\u7aef\u5f00\u53d1\u622a\u56fe\u529f\u80fd\u662f\u6307\u5728Vue\u6846\u67b6\u4e0b\uff0c\u5b9e\u73b0\u7f51\u9875\u622a\u56fe\u7684\u529f\u80fd\u3002\u8fd9\u4e2a\u529f\u80fd\u5728\u5f88\u591a\u573a\u666f\u4e0b\u90fd\u975e\u5e38\u6709\u7528\uff0c\u6bd4\u5982\u7f51\u7ad9\u6d4b\u8bd5\u3001\u5206\u4eab\u3001\u62a5\u544a\u64b0\u5199\u7b49\u7b49\u3002\u4e0b\u9762\u5c06\u8be6\u7ec6\u4ecb\u7ecdVue\u524d\u7aef\u5f00\u53d1\u622a\u56fe\u529f\u80fd\u7684\u539f\u7406\u548c\u5b9e\u73b0\u65b9\u6cd5\u3002\u4e00\u3001\u539f\u7406\u7f51\u9875\u622a\u56fe<\/p>\n","protected":false},"author":16,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[10],"tags":[9831,3126,1331,9830,3728],"class_list":["post-6649","post","type-post","status-publish","format-standard","hentry","category-appkaifa","tag-vue","tag-3126","tag-1331","tag-app","tag-3728"],"_links":{"self":[{"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/posts\/6649","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/users\/16"}],"replies":[{"embeddable":true,"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/comments?post=6649"}],"version-history":[{"count":0,"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/posts\/6649\/revisions"}],"wp:attachment":[{"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/media?parent=6649"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/categories?post=6649"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/app.applebyme.cn\/cloud\/wp-json\/wp\/v2\/tags?post=6649"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}