Vue中打印网页的指定部分的几种方法

楔子

  • 这里是以下会用到的一些知识和说明
  • 可以在GitHub上下载打印插件,但是自己写更简单,所以我就自己写了
  • 本例为打印网页上的一个表格
  • window.print()打印的是整个网页的HTML内容,不包括CSS
  • @media print{ ... }可以设置打印时样式

正文

  • 网页效果:
    在这里插入图片描述

  • 目标:右键点击打印按钮时能打印表格,忽略下方的文字和图片,并且保留样式

  • 思路:点击打印按钮时,将整个页面的HTML替换为目标区域的HTML,配合@media print{}保留样式,但是页面的HTML被替换后造成页面的改变,因此最后需要刷新一下页面

  • 代码:

      <!--HTML部分-->
      <!--将需要打印的部分用一个div框起来,给div一个id,这里用print-->
      <div id="print">
      	<table>...表格里面的内容...</table>
      </div>
     
     <!--将下面的打印函数绑定到打印按钮上-->
     <button @click=print()>打印报销单</button>
    
    //JS部分
    //将这个函数绑定到打印按钮上
    print(){
            let print = document.getElementsByClassName("print")[0]  //获取目标区域的HTML结构
            document.body.innerHTML = print.innerHTML   //替换网页的html内容
            window.print()   //打印
            window.location.reload()  //刷新页面,因为网页的html被替换后很丑
          }
    
    /*css部分*/
    /*用@media print{}保留打印时的样式*/
    ...直接写在style下的样式,在打印时会丢失,比如:...
    table{border: 2px solid black;width: 80%;margin: 0 auto;border-collapse: collapse}
    ...写在@media print{}中的样式,打印时会保留,比如...
    @media print {
    	table{border: 2px solid black;width: 80%;margin: 0 auto;border-collapse: collapse}
    }
    /*写在@media print{}中的样式在不打印的时候不会生效,因此打印时的样式要写两遍,里面和外面各一遍*/
    
  • 此时点击打印按钮的效果为在这里插入图片描述

  • 打印的效果并不理想,因为使用的是A4纸的尺寸,我们可以通过在@media print中设置size配合打印时的设置来解决这个问题

    @page{
        size: landscape;
        margin: 0 ;
      }
    
  • 最终的css部分

<style scoped>
	...在网页中正常显示的样式...
	@media print{
		@page{  
        size: landscape; /*对打印的尺寸进行设置*/
        margin: 0 ;  /*去掉上面的水印*/
      }
      ...在打印时需要保留的样式...
    }
</style>
  • 最后,在打印的选项中,选择纸张尺寸为Ledger即可
    在这里插入图片描述

  • 除了这种方法,还有其他的打印思路

  1. 将html刷新到iframe中,打印iframe 【不需刷新页面,但无法保留样式】
    <!--HTML部分-->
    <!--在html中插入一个iframe节点,插在哪里都行-->
    <iframe src="" frameborder="0" width="0" height="0"></iframe>
    
    //打印函数
    print(){
            let print = document.getElementsByClassName("print")[0]  //获取目标区域
        	doc = iframe.contentWindow.document
            doc.write(print.innerHTML)  //将目标区域的html写入iframe
            iframe.contentWindow.focus()
    		iframe.contentWindow.print()  //打印iframe
          }
    
  2. 将页面中不需要打印的部分隐藏掉 【不需刷新页面,可以保留样式,但是对绝对定位的元素不生效】
    操作方法:在@media print{}中写一个no-print样式,例如:
    @media print{
    	.no-print:{display:none}
    }
    
    将这个类放到不需要打印的标签上,实现打印是隐藏
    然后在打印按钮上绑定window.print()直接打印即可
  • 5
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: vue.js 是一个开源的 JavaScript 框架,用于构建用户界面,而 axios 是一个基于 promise 的 HTTP 客户端,用于在浏览器和 Node.js 发送 HTTP 请求。 在 vue.js 使用 axios 进行跨域访问时,可能会出现跨域访问错误。跨域是指在浏览器通过 JavaScript 发起一个 HTTP 请求,该请求的目标服务器是与当前页面不同域名、端口或协议的地址。 解决这个问题的方法有多种: 1. 后端配置允许跨域访问:在后端服务器进行配置,允许指定的域名或端口进行跨域访问。 2. 使用代理进行跨域请求:在 vue.config.js 文件配置代理,将跨域请求转发到目标服务器。例如,在 vue.config.js 文件添加以下配置: ```javascript module.exports = { devServer: { proxy: { '/api': { target: 'http://api.example.com', changeOrigin: true, pathRewrite: { '^/api': '' } } } } }; ``` 这样,当你在前端代码发送以“/api”开头的请求时,将会使用代理进行跨域请求。 3. JSONP:如果目标服务器支持 JSONP,可以使用 JSONP 进行跨域请求。在 axios ,默认是不支持 JSONP 的,但可以通过配置实现。例如,在请求添加“jsonp”参数: ```javascript axios.get('http://api.example.com/data', { params: { callback: 'jsonCallback', dataType: 'jsonp' } }) .then(response => { console.log(response.data); }) .catch(error => { console.error(error); }); ``` 通过以上方法,可以解决 vue.js axios 跨域访问错误问题。根据具体情况选择合适的解决方法,以确保跨域请求能够正常进行。 ### 回答2: Vue.js使用axios请求数据时,常常会遇到跨域访问错误。这是因为浏览器的同源策略限制了不同域名之间的访问。 解决这个问题的方法几种: 1. 使用代理 可以在项目的配置文件(vue.config.js或者nuxt.config.js)配置代理。通过将请求代理到同域名下的接口,实现跨域访问。 例如,可以在配置文件添加如下代码: ```javascript module.exports = { devServer: { proxy: { '/api': { target: 'http://api.example.com', changeOrigin: true, pathRewrite: { '^/api': '' } } } } } ``` 然后,在axios的请求使用相对路径(不包含域名)进行访问。例如: ```javascript axios.get('/api/data') .then(response => { console.log(response.data) }) ``` 这样就可以跨域访问目标接口了。 2. 设置服务器响应头 在目标服务器上,设置允许跨域访问的响应头。一般来说,可以在后端的接口代码添加以下响应头: ```javascript app.use(function(req, res, next) { res.header('Access-Control-Allow-Origin', '*'); res.header('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept'); next(); }); ``` 这样浏览器就会允许跨域访问该接口了。 3. JSONP JSONP是一种前端跨域访问的解决方案。通过在请求添加一个回调函数作为参数,服务器将返回该函数的调用,并将数据作为参数传递给该函数。 例如,在axios请求使用JSONP: ```javascript axios.jsonp('http://api.example.com/data?callback=handleData') .then(response => { console.log(response.data) }) ``` 然后,在全局定义一个处理返回数据的函数: ```javascript function handleData(data) { console.log(data) } ``` 这样就可以通过JSONP实现跨域访问了。 以上是几种解决Vue.jsaxios跨域访问错误的方法,可以根据具体情况选择使用。 ### 回答3: 在Vue.js,由于浏览器的同源策略,如果我们的Vue应用与后端接口的域名或端口不一致,会出现跨域访问错误。然而,我们可以使用axios库来解决这个问题。 首先,为了解决跨域访问错误,我们可以在后端的API接口添加响应头Access-Control-Allow-Origin: *,允许所有来源的请求访问接口。当然,我们也可以根据需求设置特定的源或域名。 另外,我们还可以通过设置代理来解决跨域访问问题。在项目的根目录下的`vue.config.js`文件,我们可以使用`devServer`配置项来设置代理。例如,我们可以将/api路径下的请求代理到http://localhost:8000路径下,具体配置如下: ``` module.exports = { devServer: { proxy: { '/api': { target: 'http://localhost:8000', changeOrigin: true, pathRewrite: { '^/api': '' } } } } } ``` 以上配置意味着,当我们的Vue应用发起/api路径下的请求时,它将被代理到http://localhost:8000路径下。`changeOrigin`选项设置为true时,请求头的host会被设置为目标url,同时`pathRewrite`选项可以重写请求路径,删除/api前缀。 在前端代码,我们可以使用axios来发起跨域请求。例如,我们可以在Vue的组件使用axios来请求后端接口: ``` import axios from 'axios' export default { methods: { fetchData() { axios.get('/api/data') .then(response => { // 处理响应数据 }) .catch(error => { // 处理错误 }) } } } ``` 通过以上方法,我们可以解决Vue.jsaxios跨域访问错误问题,实现与后端接口的跨域通信。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值