【Vue】使用print.js插件实现打印预览功能,超简单

news2024/11/25 12:29:55

目录

一、实现效果

 二、实现步骤

【1】安装插件

【2】在需要打印的页面导入

【3】在vue文件中需要打印的部分外层套一层div,给div设置id。作为打印的区域

【4】在打印按钮上添加打印事件

【5】在methods中添加点击事件

三、完整代码


一、实现效果

 

 二、实现步骤

print.js插件,可以打印html、pdf、json数据等。

官网:https://printjs.crabbly.com/

【1】安装插件

npm install print-js --save

【2】在需要打印的页面导入

import print from 'print-js'

【3】在vue文件中需要打印的部分外层套一层div,给div设置id。作为打印的区域

<el-table :data="showData" id="printBox" style="display: flex;">
      <el-table-column type="index" label="序号" width="180" align="center"></el-table-column>
      <el-table-column prop="adminname" label="账号" align="center"></el-table-column>
      <el-table-column label="权限" align="center">
        <template #default="{ row }">
          <el-tag v-if="row.role == 1" type="" effect="dark">
            管理员
          </el-tag>
          <el-tag v-else-if="row.role == 2" type="warning" effect="dark">
            超级管理员
          </el-tag>
          <el-tag v-else type="info" effect="dark">
            未知
          </el-tag>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center">
        <template #default="{ row }">
          <el-button circle type="success" @click="editHandler(row)">
            <el-icon>
              <Edit></Edit>
            </el-icon>
          </el-button>

          <el-popconfirm title="你确定删除吗?" confirm-button-text="是" cancel-button-text="取消" @confirm="delHandler(row)">
            <template #reference>
              <el-button circle type="danger">
                <el-icon>
                  <Delete></Delete>
                </el-icon>
              </el-button>
            </template>
          </el-popconfirm>
        </template>
      </el-table-column>
    </el-table>

【4】在打印按钮上添加打印事件

    <el-button type="primary" @click="printBox">打印</el-button>

【5】在methods中添加点击事件

必要的就是printable和bype

methods: {
    printBox() {
      setTimeout(function () {
        print({
          printable: 'printBox',
          type: 'html',
          scanStyles: false,
          targetStyles: ['*']
        })
      }, 500)
    },
}

三、完整代码

<template>
  <el-breadcrumb class="breadcrumb" separator="/">
    <el-breadcrumb-item :to="{ path: '/layout' }">主页</el-breadcrumb-item>
    <el-breadcrumb-item>账号管理</el-breadcrumb-item>
    <el-breadcrumb-item>管理员列表</el-breadcrumb-item>
  </el-breadcrumb>
  <div>
    <!-- 按钮 -->
    <el-button type="primary" @click="openAdd">添加管理员</el-button>
    <el-button type="primary" @click="printBox">打印</el-button>
    <!-- 表格 -->
    <el-table :data="showData" id="printBox" style="display: flex;">
      <el-table-column type="index" label="序号" width="180" align="center"></el-table-column>
      <el-table-column prop="adminname" label="账号" align="center"></el-table-column>
      <el-table-column label="权限" align="center">
        <template #default="{ row }">
          <el-tag v-if="row.role == 1" type="" effect="dark">
            管理员
          </el-tag>
          <el-tag v-else-if="row.role == 2" type="warning" effect="dark">
            超级管理员
          </el-tag>
          <el-tag v-else type="info" effect="dark">
            未知
          </el-tag>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center">
        <template #default="{ row }">
          <el-button circle type="success" @click="editHandler(row)">
            <el-icon>
              <Edit></Edit>
            </el-icon>
          </el-button>

          <el-popconfirm title="你确定删除吗?" confirm-button-text="是" cancel-button-text="取消" @confirm="delHandler(row)">
            <template #reference>
              <el-button circle type="danger">
                <el-icon>
                  <Delete></Delete>
                </el-icon>
              </el-button>
            </template>
          </el-popconfirm>
        </template>
      </el-table-column>
    </el-table>
    <!-- 分页器 -->
    <div class="pagination">
      <el-pagination v-model:current-page="count" v-model:page-size="limitNum" :page-sizes="[1, 3, 5, 8]"
        layout="total, sizes, prev, pager, next, jumper" :total="allData.length" />
    </div>
    <!-- 抽屉 -->
    <el-drawer v-model="isShow">
      <template #header>
        <h4>{{ type }} 管理员</h4>
      </template>
      <template #default>
        <div>
          <el-form :model="form">
            <el-form-item label="账号" size="small">
              <el-input v-model="form.adminname">
              </el-input>
            </el-form-item>

            <el-form-item label="密码">
              <el-input v-model="form.password">
              </el-input>
            </el-form-item>

            <el-form-item label="角色">
              <el-select v-model="form.role">
                <el-option label="管理员" :value="1">
                </el-option>
                <el-option label="超级管理员" :value="2">
                </el-option>
              </el-select>
            </el-form-item>

            <el-form-item label="权限">
              <el-tree ref="treeRef" :data="treeData" show-checkbox default-expand-all node-key="path"
                :props="defaultProps" />
            </el-form-item>


          </el-form>
        </div>
      </template>

      <template #footer>
        <div style="flex:auto">
          <el-button @click="cancelClick">取消</el-button>
          <el-button type="primary" @click="confirmClick">确定</el-button>
        </div>
      </template>

    </el-drawer>

  </div>
</template>

<script>
import print from 'print-js'
import { formatRoutes } from "@/utils/tools"
import { getAdminList, addAdmin, updataAdmin, delAdmin } from '@/apis/user'
export default {
  data() {
    return {
      // 当前页码
      count: 1,
      // 每页显示条数
      limitNum: 3,
      // 所有管理员列表信息
      allData: [],
      // 管理员抽屉的数据
      form: {
        adminname: '',
        password: '',
        role: 1,
      },
      // 抽屉是否显示
      isShow: false,
      // 区别当前是添加管理员还是更新管理员
      type: '',
      // 树节点信息
      treeData: [],
      // 要显示的元素
      defaultProps: {
        children: 'children',
        label: function (data) {
          // label设置要显示的文字信息,lable的值可以是函数
          return data.meta.title
        }
      }
    };
  },
  watch: {
    isShow(value) {
      if (!value) {
        this.form = {}
      }
      this.$refs.treeRef?.setCheckedNodes([])
    }
  },
  computed: {
    showData() {
      return this.allData.slice((this.count - 1) * this.limitNum, this.count * this.limitNum)
    }
  },
  mounted() {
    this.getAllData(),
      this.treeData = formatRoutes(this.$router.getRoutes())
  },
  methods: {
    printBox() {
      setTimeout(function () {
        print({
          printable: 'printBox',
          type: 'html',
          scanStyles: false,
          targetStyles: ['*']
        })
      }, 500)
    },

    delHandler(row) {
      delAdmin({ adminid: row.adminid }).then(data => {
        this.getAllData()
      })

    },
    cancelClick() {
      this.isShow = false
    },
    confirmClick() {
      this.isShow = false
      // 获取表单数据和树形菜单数据,调用 添加、修改接口
      // getCheckedNodes,选中的节点的数据
      // 第一个false:选中父节点,字节点数据都获取
      // 第二个true:无论父节点有没有被选中,选中的子节点都能获取
      if (this.type == '添加') {
        addAdmin({
          ...this.form,
          checkedKeys: this.$refs.treeRef?.getCheckedNodes(false, true)
        }).then(res => {
          this.getAllData()
        })
      } else {
        updataAdmin({
          ...this.form,
          checkedKeys: this.$refs.treeRef?.getCheckedNodes(false, true)
        }).then(res => {
          this.getAllData()
        })
      }
    },
    // 获取所有管理员列表信息
    getAllData() {
      getAdminList().then(res => {
        console.log("管理员列表", res)
        this.allData = res.data
        this.count = 1
      })
    },
    editHandler(row) {
      this.type = '修改',
        this.isShow = true
      this.form = {
        adminname: row.adminname,
        password: row.password,
        role: row.role
      }
    },
    openAdd() {
      this.type = '添加',
        this.isShow = true
    }
  },
};
</script>

<style lang="scss" scoped>
.breadcrumb {
  margin-bottom: 25px;

}

.pagination {
  display: flex;
  justify-content: center;

  .el-pagination {
    margin: 10px;
  }
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/849580.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

647. 回文子串

目录 一、题目 二、代码 一、题目 二、代码 双指针&#xff01;&#xff01;&#xff01; class Solution { public:bool Palindrome(string s,int i,int j){int begini;int end j;while(begin<end){if(s[begin]!s[end]){return false;}begin;end--;}return true;}int …

IPWorks S3 Delphi Edition Crack

IPWorks S3 Delphi Edition Crack IPWorksS3使集成基于云的文件存储变得容易。易于使用的组件可用于与任何S3兼容的存储提供商集成&#xff0c;如Amazon S3、Digital Ocean Spaces、Wasabi、Backblaze B2、IBM Cloud Object storage、Oracle Cloud、Linode等。强大的客户端加密…

解决Vue+Element-UI 进行From表单校验时出现了英文提示问题

说明&#xff1a;该篇博客是博主一字一码编写的&#xff0c;实属不易&#xff0c;请尊重原创&#xff0c;谢谢大家&#xff01; 问题描述 在使用form表单时&#xff0c;往往会对表单字段进行校验&#xff0c;字段为必填项时会添加required属性&#xff0c;此时自定义rules规则…

vue中全局状态存储 pinia和vuex对比 pinia比vuex更香 Pinia数据持久化及数据加密

前言 毕竟尤大佬都推荐使用pinia&#xff0c;支持vue2和vue3&#xff01; 如果熟悉vuex&#xff0c;花个把小时把pinia看一下&#xff0c;就不想用vuex了 支持选项式api和组合式api写法pinia没有mutations&#xff0c;只有&#xff1a;state、getters、actionspinia分模块不…

20个程序员接单平台分享

这题我会&#xff01;接单软件那么多&#xff0c;找到适合自己的最重要&#xff01; V2EX https://www.v2ex.com/ 先给一个“非正常选项”&#xff0c;v2ex上有一个“酷工作”板块&#xff0c;运气好的话可以在这里找到不错的单子&#xff0c;最重要的是带你开启新世界的大门…

新型声学攻击通过键盘击键窃取数据,准确率高达 95%

来自英国大学的一组研究人员训练了一种深度学习模型&#xff0c;该模型可利用麦克风记录并分析键盘击键的声音&#xff0c;以此来窃取目标设备中的数据&#xff0c;准确率高达 95%。 不同于其他需要特殊条件并受到数据速率和距离限制的旁道攻击&#xff0c;由于现有大量场景都拥…

LeetCode:Hot100的python版本

94. 二叉树的中序遍历

Python爬虫的Selenium(学习于b站尚硅谷)

目录 一、Selenium  1.为什么要学习Selenium  &#xff08;1&#xff09;什么是Selenium  &#xff08;2&#xff09;为什么使用selenium?  &#xff08;3&#xff09;代码演示 2. selenium的基本使用  &#xff08;1&#xff09;如何安装selenium  &#xff08;2…

jmeter如何压测和存储

一、存储过程准备&#xff1a; 1、建立一个空表&#xff1a; 1 CREATE TABLE test_data ( id NUMBER, name VARCHAR2(50), age NUMBER ); 2、建立一个存储过程&#xff1a; 1 2 3 4 5 6 7 8 9 CREATE OR REPLACE PROCEDURE insert_test_data (n IN NUMBER) AS BEGIN --E…

【工程优化问题】基于多种智能优化算法的压力容器设计问题研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

Linux内核应该怎么去学习?

通过阅读源码来学习操作系统要注意区分共性与平台特性。 1. 中断响应是共性&#xff0c;8259 中断控制器和 IDT 是 x86 的特性。 2. 虚拟内存管理是共性&#xff0c;x86 的 GDT 和 LDT 是特性&#xff0c;而且现在的系统也只是走个过场而已。 3. 任务调度与上下文切换是共性&am…

44.实现爱尔兰B公式计算并输出表格(matlab程序)

1.简述 1.话务量定义 话务量指在一特定时间内呼叫次数与每次呼叫平均占用时间的乘积。 话务量反映了电话负荷的大小&#xff0c;与呼叫强度和呼叫保持时间有关。呼叫强度是单位时间内发生的呼叫次数&#xff0c;呼叫保持时间也就是占用时间。 话务量计算方法 话务量公式为…

智安网络|恶意软件在网络安全中的危害与应对策略

恶意软件是指一类具有恶意目的的软件程序&#xff0c;恶意软件是网络安全领域中的一个严重威胁&#xff0c;给个人用户、企业和整个网络生态带来巨大的危害。通过潜伏于合法软件、邮件附件、下载链接等途径传播&#xff0c;破坏用户计算机系统、窃取敏感信息、进行勒索等不法行…

C语言经典小游戏之扫雷(超详解释+源码)

“少年气&#xff0c;是历尽千帆举重若轻的沉淀&#xff0c;也是乐观淡然笑对生活的豁达&#xff01;” 今天我们学习一下扫雷游戏怎么用C语言来实现&#xff01; 扫雷小游戏 1.游戏介绍2.游戏准备3.游戏实现3.1生成菜单3.2游戏的具体实现3.2.1初始化棋盘3.2打印棋盘3.3布置雷…

Linux root用户执行修改密码命令,提示 Permission denied

问题 linux系统中&#xff08;ubuntu20&#xff09;&#xff0c;root用户下执行passwd命令&#xff0c;提示 passwd: Permission denied &#xff0c;如下图&#xff1a; 排查 1.执行 ll /usr/bin/passwd &#xff0c;查看文件权限是否正确&#xff0c;正常情况是 -rwsr-xr…

VAE、 EM、KL散度

文章目录 VAEVAE额外的损失函数 EMKL散度 VAE 左图相当于变量x&#xff0c;右图相当于z 假如在AE中&#xff0c;一张满月的图片作为输入&#xff0c;模型得到的输出是一张满月的图片&#xff1b;一张弦月的图片作为输入&#xff0c;模型得到的是一张弦月的图片。当从满月的code…

SpringBoot复习:(22)ConfigurationProperties和@PropertySource配合使用及JSR303校验

一、配置类 package cn.edu.tju.config;import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.PropertySource; import org.springframework.stereotype.Component;Component ConfigurationPropertie…

C++初阶——函数重载

前言&#xff1a;C中除了可以在不同的命名空间中使用同名函数&#xff0c;还有一种支持在同一个作用域中同名函数的方式——函数重载。 函数重载 一.什么是函数重载&#xff1f;二.函数重载的3种规则三.特殊情况 一.什么是函数重载&#xff1f; C允许同样同一作用域中声明几个功…

IPWorks OFX Delphi Edition Crack

IPWorks OFX Delphi Edition Crack IPWorks OFX由可以访问电子交易信息的组件组成&#xff0c;并包括银行转账和付款提交等功能。这些组件使应用程序开发人员能够构建包含更快、更准确的交易对账、发送即时交易通知以及完全关闭支付和会计之间循环的解决方案。 IPWorks OFX功能…

请求接口时报异常:org.springframework.web.multipart.MultipartException

请求接口时报异常&#xff1a;org.springframework.web.multipart.MultipartException: Current request is not a multipart request 检查后发现自己忘记传文件参数 添加参数后请求正常。