{"id":2025,"date":"2022-08-24T22:45:23","date_gmt":"2022-08-24T14:45:23","guid":{"rendered":"https:\/\/yukihiew.com\/?p=2025"},"modified":"2023-06-27T15:31:12","modified_gmt":"2023-06-27T07:31:12","slug":"%e7%94%a8js%e4%bf%ae%e6%94%b9%e5%88%97%e5%8d%b0%e6%96%b9%e5%90%91","status":"publish","type":"post","link":"https:\/\/yukihiew.com\/%e7%94%a8js%e4%bf%ae%e6%94%b9%e5%88%97%e5%8d%b0%e6%96%b9%e5%90%91\/","title":{"rendered":"Vue | \u7528js\u4fee\u6539\u5217\u5370\u65b9\u5411 \u8b93\u5404\u9801\u9762\u53ef\u81ea\u8a02\u6a6b\u5411\u6216\u76f4\u5411\u5217\u5370"},"content":{"rendered":"
\u5982\u4f55\u7528js\u4fee\u6539\u5217\u5370\u65b9\u5411<\/strong> \u7528\u4e2d\u6587\u67e5\u9019\u500b\u554f\u984c\u5341\u5206\u7684\u7121\u89e3\uff0c\u6240\u5e78\u67e5\u82f1\u6587\u95dc\u9375\u5b57\u63db\u4e863\u7a2e\u65b9\u5f0f\u5c31\u627e\u5230\u5c0d\u61c9\u7684\u554f\u984c\u4e86\uff0c\u5148\u611f\u8b1d StackOverflow \u4e0a\u7684\u9019\u4f4d\u8001\u54e5\u7528\u6700\u6a38\u5be6\u7684 js \u65b9\u5f0f\u56de\u7b54\u9019\u500b\u5927\u90e8\u5206\u4eba\u90fd\u6703\u4ee5 css @page \u8a2d\u5b9a\u89e3\u6c7a\u7684\u554f\u984cQQ Vue\u53ea\u80fd\u5728app\u7684\u5730\u65b9\u5f15\u5165\u5217\u5370\u7684css\u8a2d\u5b9a\uff0c\u6bd4\u5982\u4f60\u4e00\u958b\u59cb\u8a2d\u5b9a\u662fportrait\u7684\u8a71\uff0c\u6bcf\u500b\u9801\u9762\u90fd\u6703\u5957\u7528\uff0c\u6c92\u8fa6\u6cd5\u5728\u5404\u5143\u4ef6 style scoped \u7684\u5730\u65b9\u518d\u8a2d\u5b9a\u4e00\u500b @media print \u8986\u84cb\u904e\u53bb\u3002 \u65b0\u589e\u4e00\u500b\u8b8a\u6578\u5c07@page\u8a2d\u5b9a\u7684\u5b57\u8207\u4f9d\u64da\u50b3\u9032\u4f86\u7684\u53c3\u6578\u6c7a\u5b9a\u662fportrait(\u76f4\u5f0f)\u9084\u662f landscape(\u6a6b\u5f0f)\u5b58\u9032\u53bb\uff0c\u4e26\u7528js\u8a2d\u5b9a\u5728\u7db2\u9801\u7684head\u6a19\u7c64\u88e1\u5c31\u53ef\u4ee5\u4e86! \u7136\u5f8c\u5728\u8981\u89f8\u767c\u5217\u5370\u7684\u6309\u9215\u7d81\u4e0a window.print(); \uff0c\u5c31\u80fd\u5217\u5370\u60f3\u8981\u7684\u7d19\u5f35\u65b9\u5411\u4e86!<\/p>\n\n\n\n \u5982\u679c\u539f\u672c\u6709\u5728app.vue\u5f15\u5165print\u7528\u7684css\uff0c\u8981\u8a18\u5f97\u628a@page\u9019\u500b\u8a2d\u5b9a\u522a\u6389\uff0c\u5176\u9918\u5728@media print\u88e1\u7684\u8a2d\u5b9a\u53ef\u4ee5\u7559\u8457\uff0c\u4e0d\u5f71\u97ff\u3002<\/p>\n\n\n \u70ba\u4e86\u653e\u4e0acodepen\u53ef\u4ee5\u8b93\u4eba\u64cd\u4f5c\u770b\u770b\u53c8\u6539\u52d5\u4e86\u4e00\u4e9b\u90e8\u5206\uff0c\u900f\u904ebutton\u5728\u540c\u9801\u5207\u63db\u5217\u5370\u7684\u65b9\u5411\uff0c\u4e26\u4fee\u6b63\u4e86\u591a\u65bc\u4e00\u6b21\u89f8\u767cfunction\u6703\u65b0\u589e\u91cd\u8907style\u7684\u90e8\u5206~
\u55ae\u7d14\u8a2d\u5b9a@print @page\u9019\u500b\u8ab0\u4e0d\u6703\u5587~~(\u5436\u558a
\u751a\u81f3\u9084\u6709\u770b\u5230\u8aaa\u9019\u500b\u554f\u984c\u7121\u89e3\u7684\u4ec1\u5144Orz
\u90a3\u5c31\u7531YUKI\u4f86\u5beb\u4e2d\u6587\u7248\u89e3\u6cd5\u5427!!
\u8aaa\u5be6\u5728\u4e5f\u4e0d\u662f\u4ef6\u96e3\u4e8b\uff0c\u5c31\u662f\u5c07\u9019\u4efd js \u6539\u5beb\u6210 vue \u80fd\u7528\u7684\u914d\u7f6e\uff0c\u5be6\u969b\u6e2c\u8a66\u904e\u4e5f\u662f\u53ef\u4ee5\u9806\u5229\u4f7f\u7528\u7684\u5594!
(\u751a\u81f3\u901a\u904e\u4e86 chrome 49 \u7684\u6e2c\u8a66XD)<\/p>\n\n\n\u554f\u984c\u9ede<\/h2>\n\n\n
\u4f46\u5982\u679c\u5c08\u6848\u662f\u8981\u6bcf\u500b\u4e0d\u540c\u5143\u4ef6\u9801\u9762\u662f\u4e0d\u540c\u6587\u4ef6\u505a\u5217\u5370\uff0c\u6709\u4e9b\u8981\u5370\u76f4\u7684\u3001\u6709\u4e9b\u6a6b\u7684\uff0c\u90a3\u600e\u9ebc\u8fa6\u5462?!<\/p>\n\n\n\u89e3\u6cd5<\/h2>\n\n\n
\u5c07\u4e0b\u9762\u7684\u7a0b\u5f0f\u78bc\u7d81\u5728\u9700\u8981\u5217\u5370\u7684\u5143\u4ef6\u9801\u9762\u7684methods\u88e1\uff0c\u4e26\u4e14\u5728mounted()\u968e\u6bb5\u89f8\u767c\u4e00\u6b21\u5f8c\uff0chead\u6a19\u7c64\u88e1\u5c31\u6703\u6709print\u7684\u8a2d\u5b9a\u4e86\u3002<\/p>\n\n\n\n\/\/methods\nfunction changePrintOrietation(orientation){\n var css = css = `@page { size: A4 ${orientation}; margin: 0.5cm 0.5cm; }`;\n var head = document.head || document.getElementsByTagName('head')[0],\n style = document.createElement('style');\n style.media = 'print';\n\n if (style.styleSheet){ \n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n head.appendChild(style);\n }<\/code><\/pre>\n\n\n\n
<\/figure>\n\n\n\n
<\/figure>\n\n\n\n
\/\/template\n<div class=\"printbutton\">\n <a href=\"javascript:void(0)\" click=\"window.print();\" >\n \u5217\u5370\n <\/a>\n<\/div><\/code><\/pre>\n\n\n\n
<\/figure>\n\n\n\n
\u7528\u9ede\u64ca\u6309\u9215\u8f49\u63db\u5217\u5370\u65b9\u5411<\/h2>\n\n\n
\u6539\u5b8c\u4e5f\u883b\u6709\u6210\u5c31\u611f\u7684:3<\/p>\n\n\n\n