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

目录

一、实现效果

 二、实现步骤

【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>

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【非欧几里得域信号的信号处理】使用经典信号处理和图信号处理在一维和二维欧几里得域信号上应用低通滤波器研究(Matlab代码实现)

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

Spring与Spring Bean

Spring 原理 它是一个全面的、企业应用开发一站式的解决方案&#xff0c;贯穿表现层、业务层、持久层。但是 Spring 仍然可 以和其他的框架无缝整合。 Spring 特点 轻量级 控制反转 面向切面 容器 框架集合 Spring 核心组件 Spring 总共有十几个组件核心容器(Spring core) S…

RN 使用react-navigation写可以滚动的横向导航条(expo项目)

装包&#xff1a; yarn add react-navigation/material-top-tabs react-native-tab-view npx expo install react-native-pager-view import React from react import { View, Text, ScrollView, SafeAreaView } from react-native import { Icon } from ../../../../../compo…

python编辑器安装与配置,python用哪个编辑器好用

大家好&#xff0c;给大家分享一下python编辑器pycharm安装教程&#xff0c;很多人还不知道这一点。下面详细解释一下。现在让我们来看看&#xff01; 哪些python的编程软件值得推荐&#xff1f; 编写python源代码的软件.首推的Pycharm。 PyCharm用于bai一般IDE具备的功能&…

Redis的安装方法与基本操作

目录 前言 一、REDIS概述 二、REDIS安装 1、编译安装 2.yum安装 三、Redis的目录结构 四、基础命令解析 五、在一台服务器上启动多个redis 六、数据库的基本操作 &#xff08;一&#xff09;登录数据库 &#xff08;二&#xff09;基础命令 七、Redis持久化 &#xff08;一&…

每天一个知识点——Normalization

这里结合大模型的学习&#xff0c;主要分析Layer Norm、RMS Norm和Deep Norm的异同&#xff0c;与此同时&#xff0c;究竟是在之前执行Normalization&#xff08;Pre-Norm&#xff09;还是之后执行&#xff08;Post-Norm&#xff09;&#xff0c;也是一个比较喜欢拿来讨论的知识…

ChatGPT会取代搜索引擎吗?BingChat、GoogleBard与ChatGPT区别

目前暂时不会&#xff0c;ChatGPT为代表的聊天机器人很可能会直接集成到搜索中&#xff0c;而不是取代它。微软已经通过Bing Chat和Bing做到了这一点&#xff0c;它将“聊天”选项卡直接放入Bing搜索的菜单中。Google、百度也分别开始尝试通过其AI生成技术将Google Bard、文心一…

Pytest三种运行方式

Pytest 运行方式共有三种&#xff1a; 1、主函数模式 运行所有 pytest.main() 指定模块 pytest.main([-vs],,./testcase/test_day1.py) 只运行testcase 下的test_day1.py 文件 指定目录 pytest.main([-vs]),./testcase) 只运行testcase 目录下的文件 通过nodeid指定用例…

Cmder:从此告别记事本记命令的日子

前言 平时开发中遇到这样那样的命令需要记下来&#xff0c;一般做法是这样。 新建记事本将需要记下的关键命令保存。每次需要使用时&#xff0c;粘贴复制即可。 好像没什么毛病&#xff01;直到遇到了 Cmder。。。 当看到同事分析问题时在 Cmder 里命令快捷键刷刷一顿操作&…

C#实现邮箱验证码

开发环境&#xff1a;C#&#xff0c;VS2019&#xff0c;.NET Core 3.1&#xff0c;ASP.NET Core Web API&#xff0c;163邮箱 1、在163邮箱的设置中开通IMAP/SMTP的服务&#xff0c;授权成功后会弹出一个窗体&#xff08;如下图所示&#xff09;&#xff0c;上面显示了授权密码…

C++ ModBUS TCP客户端工具 qModMaster 介绍及使用

qModMaster工具介绍 QModMaster是一个基于Qt的Modbus主站&#xff08;Master&#xff09;模拟器&#xff0c;用于模拟和测试Modbus TCP和RTU通信。它提供了一个直观的图形界面&#xff0c;使用户能够轻松设置和发送Modbus请求&#xff0c;并查看和分析响应数据。 以下是QModM…

湘大 XTU OJ 1256 湘潭大学 题解(非常详细):枚举

一、链接 1256 湘潭大学 二、题目 题目描述 湘潭大学简称“XTU”&#xff0c;作为即将成为湘大的一份子&#xff0c;怎么不能为湘大添砖加瓦了&#xff1f;现在给你一个字符串&#xff0c;请你计算一下&#xff0c;从中选取字符&#xff0c;最多能组成多少个“XTU”&#x…

v-md-editor自定义锚点(生成目录)数组转树结构

接前两篇博文&#xff0c;最终方案终于定了&#xff0c;也把之前做的编辑器模式给否决了&#xff0c;原因是系统中有老的文档需要平替&#xff0c;因此就不能通过编辑器这种模式了&#xff0c;太麻烦了。 最终方案&#xff1a;线下手动pandoc word转markdown&#xff0c;然后将…

Qt 7. 在自定义类TcpClient类中使用信号槽功能

1. 因为只有QObject类及其子类派生的类才能使用信号和槽机制。 使用信号和槽还必须在类声明的最开始处添加Q_OBJECT宏&#xff0c;在这个程序中&#xff0c;类的声明是自动生成的&#xff0c;已经添加了这个宏。UI类继承自QDialog&#xff0c;QDialog类又继承自QWidget类&…

Oracle-创建PDB

Oracle-创建PDB 创建PDB的方式 从PDB$SEED新建PDB克隆已存在的PDB 本地PDB克隆到同一个CDB中将远程PDB克隆到CDB中将非CDB插入或克隆到CDB中通过插拔的方式创建PDB sql 命令语法 条件 CDB必须open并且read write模式连接CDB$ROOT 用户并且具有CREATEPLUGGABLEDATABASE系统权…

解决android studio妙明奇妙出现的模拟器

1&#xff0c;查看设备 adb devices 2&#xff0c; adb命令断开指定的设备 要断开ADB与特定设备的连接&#xff0c;可以使用以下命令&#xff1a; adb disconnect <设备ID> 将 <设备ID> 替换为您要断开连接的设备的实际ID。设备ID可以在运行 adb devices 命令…

Von Maur, Inc EDI 需求分析

Von Maur, Inc 是一家历史悠久的卖场&#xff0c;成立于19世纪&#xff0c;总部位于美国。作为一家知名的零售商&#xff0c;Von Maur 主要经营高端时装、家居用品和美妆产品。其使命是为顾客提供优质的产品和无与伦比的购物体验。多年来&#xff0c;Von Maur 凭借其卓越的服务…

MySQL SUBSTRING_INDEX() 函数的详细介绍

MySQL SUBSTRING_INDEX() 从给定字符串中返回指定数量的分隔符出现之前的子字符串。 当指定数字为正数时从最终分隔符的左侧返回子字符串&#xff0c;当指定数字为负数时从最终分隔符的右侧返回子字符串。 如果指定的次数大于分隔符的出现次数&#xff0c;则返回的子字符串将…

机器人技术及其影响

目录 1.概念 2.发展 3.应用领域 4.对人类的益处 1.概念 机器人是指能够自主执行任务的机械设备或电子设备。它们通常具有一定的感知、决策和执行能力&#xff0c;能够接收和处理来自外部环境的信息&#xff0c;并做出相应的行动。 机器人的形态和功能各异&#xff0c;可以是…

Netty自定义编码解码器

上次通信的时候用的是自带的编解码器&#xff0c;今天自己实现一下自定义的。 1、自定义一下协议 //协议类 Data public class Protocol<T> implements Serializable {private Long id System.currentTimeMillis();private short msgType;// 假设1为请求 2为响应privat…