vue2框架配置路由设计打印单

业务效果:

查询出列表后,点击申请单按钮,弹出申请表格,可进行打印

后端实现

控制器、服务层等省略,关联查出数据提供接口给前端即可

<!--获取详细信息(用于申请单打印)-->
    <select id="selectXxxxDetail" parameterType="String" resultType="xxxVo">
    SELECT
       c.`name` AS xxx,
       c.xxx,
       c.xxxAS xxx,
       c.xxxAS xxx,
       c.xxxAS xxx,
       ca.xxxAS xxx,
       vr.xxx,
       b.xxx,
       bm.xxx,
       v.xxx,
       dd.xxxas xxx,
       v.xxx,
       v.xxx,
       v.xxx,
       v.xxx,
       de.xxx,
       d.xxx
    FROM
       xxx  vr
    LEFT JOIN xxx  rr ON rr.xxx  = vr.xxx  
    LEFT JOIN xxx  v ON v.id = rr.xxx  _id
    LEFT JOIN xxx  c ON c.id = rr.xxx  
    LEFT JOIN xxx  ca ON ca.id = rr.xxx  
    LEFT JOIN xxx  b ON b.id = v.xxx  
    LEFT JOIN xxx  bm ON bm.id = v.xxx  
    LEFT JOIN xxx  cf ON cf.id = rr.xxx  
    LEFT JOIN xxx  bc ON bc.id = v.xxx  
    LEFT JOIN xxx  bd ON bd.xxxid = bc.xxx  
    LEFT JOIN sys_dict_data dd ON dd.xxx  = v.xxx  
    LEFT JOIN sys_user u ON u.user_name = vr.create_by
    LEFT JOIN sys_dept d ON d.dept_id = u.dept_id
    LEFT JOIN xxx  dm ON dm.user_id = u.user_id
    LEFT JOIN xxx   de ON de.id = dm.xxx  
    WHERE
       vr.id = #{id}
    </select>

前端实现

1.首先在配置跳转路由

具体配置项: 

 

  {
    path: '/xxxxxxForm',
    component: (resolve) => require(['@/views/xxx/xxxxx/xxxxxxForm'], resolve),
    hidden: true,
    meta: { title: 'xxxx申请表' }
  },

2.这个配置申请单的数据查询接口到js

分析:因为这个表格的数据要比当前业务表的数据要集成得多,所以需要重新写接口关联查询进行获取,通过VO接收后给到前端

// 获取车辆补证详情信息详细信息(用于申请单打印)
export function getReissuecertDetail(id) {
  return request({
    url: '/ddc/vehicleTransactReissuecert/getReissuecertDetail/' + id,
    method: 'get'
  })
}

3.页面加“申请单”按钮,及配置跳转的处理逻辑

4.表格页面代码:


<!-- 超级飞侠申请表 -->
<template>
  <div :visible.sync="openView.open" class="app-container">
    <div id="main-div">
      <p class="bold-large-text" style="text-align: center">超级飞侠申请表</p>
      <table class="table table-bordered"   valign="center" style="table-layout: fixed">
        <tr>
          <td colspan="12">入伍信息</td>
        </tr>
        <tr>
          <td colspan="2" rowspan="4" >申请人</td>
          <td colspan="2" >姓名/名称</td>
          <td colspan="3" >{{formData.xxxName}}</td>
          <td colspan="2" >个人类型</td>
          <td colspan="3" >
            <div v-if="formData.xxxtype==='1'">个人</div>
            <div v-if="formData.xxxtype==='2'">组织</div>
          </td>
        </tr>
        <tr>
          <td colspan="2" >身份证号</td>
          <td colspan="3" >{{ formData.xxxIdcard }}</td>
          <td colspan="2" >手机号码</td>
          <td colspan="3" >{{ formData.xxxMobilephone }}</td>
        </tr>
        <tr>
          <td colspan="2" >户籍地址</td>
          <td colspan="8" >{{ formData.xxxPermanentaddress }}</td>
        </tr>
        <tr>
          <td colspan="2" >现居住地址</td>
          <td colspan="8" >{{ formData.xxxResidenceaddress }}</td>
        </tr>
        <tr>
          .
          .
          .
        </tr>
        <tr>
          <td colspan="6" rowspan="5"  class="signature-cell">
            <div align='left'>
            <br>
              *申请人签字:
            </div>
            <div align='right'>
            <br><br>
            时间 _____年_____月_____日
            </div>
          </td>
          <td colspan="6" rowspan="5"  class="signature-cell">
            <div align='left'>
              <br>
            *经办人签字:
            </div>
            <div align='right'>
              <br><br>
            时间 _____年_____月_____日
            </div>
          </td>
        </tr>
        </table>
          </div>
          <div style="float: right;">
            <el-button ref="printClick" type="primary" @click="printer">打 印</el-button>
            <el-button @click="close">取 消</el-button>
          </div>
        </div>
</template>

<script>
import {
  getxxxDetail
} from "@/api/ccc/xxx";
import printJS from 'print-js';

const printer = () => {
  printJS({
    printable: 'main-div',
    type: 'html',
    popTitle:"超级飞侠入伍管理系统",
    style: `h2{ text-align: center;font-size: 14px;}
      table{width: 95%;border-collapse: collapse;font-size: 8px; }
      th, td {border: 1px solid #000000;text-align: center;}
      .div-text-left { text-align: left; margin-bottom: 10px;}
      .bold-large-text { text-align: center; font-weight: bold; font-size: 30px; }
      .divText { text-align: right;}`,
    scanStyles: true,
  })
}
export default {
  name: "txxxForm",
  data() {
    return {
      printer,
      baseURL: process.env.VUE_APP_BASE_API,
      //车辆转移登记数据
      formData: {},
      // 弹出层标题
      title: "",
      // 是否显示弹出层
      open: false,
      // 是否显示详细弹出层
      openView: false,
      // 表单参数
      form: {},
    };
  },
  created() {
    //根据changeId加载数据
    const xxxId = this.$route.query.xxxId;
    console.log(xxxId)
    this.loadData(xxxId);
  },
  methods: {
    close() {
      window.close();
    },
    dialogVisible() {
      this.$store.dispatch("xxxForm", this.$route)
    },
    /** 根据changeId查询查验单信息 */
    loadData(xxxId) {
      getxxxDetail(xxxId).then(response => {
        this.formData = response.data;
      });
    },
  }
};
</script>

<style rel="stylesheet/scss" lang="scss">
#main-div {
  display: table;
  width: 700px;
  max-width: 100%;
  margin: 0 auto;
}
.table {
  width: 100%;
  border-collapse: collapse;
  text-align: center;
}
.table td, .table th {
  padding: 8px;
  border: 1px solid rgb(50, 66, 74);
}
.kuang {
  font-size: 30px; /* 调整方框大小 */
  text-align: center;
}
.bold-large-text {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
@media print {
  .signature-cell {
    text-align: left !important; /* 确保打印时文字居左 */
    line-height: 1.5; /* 调整行高 */
    padding-top: 10px; /* 上边距 */
  }
  .div-text-left {
    text-align: left;
    margin-bottom: 20px;
  }
}
</style>

 

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

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

相关文章

第29天:Web开发-PHP应用弱类型脆弱Hash加密Bool类型Array数组函数转换比较

#知识点 1、安全开发-原生PHP-弱类型脆弱 2、安全开发-原生PHP-函数&数据类型 3、安全开发-原生PHP-代码审计案例 一、PHP弱类型对比 1、 和 两个等号是弱比较&#xff0c;使用进行对比的时候&#xff0c;php解析器就会做隐式类型转换&#xff0c;如果两个值的类型不相等就…

在Ubuntu 18.04.6 LTS安装OpenFace流程

一、修改配置:将gcc8&#xff0c;g8作为默认选项 sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-8 100 sudo update-alternatives --config gcc 选择版本&#xff0c;再查看gcc --version sudo update-alternatives --install /usr/bin/g g /usr/bin/g-…

【亚马逊云科技】基于Amazon EKS部署高可用的OceanBase的最佳实践

一、前言 随着企业业务的快速发展和数据量的不断增长&#xff0c;高性能、高可用的数据库解决方案成为了关键需求。OceanBase作为一款分布式关系型数据库&#xff0c;以其高扩展性、高可用性和高性能的特点&#xff0c;逐渐受到企业的广泛关注。然而&#xff0c;在复杂的分布式…

计算机网络:网络层知识点及习题(一)

网课资源&#xff1a; 湖科大教书匠 1、概述 网络层实现主机到主机的传输&#xff0c;主要有分组转发和路由选择两大功能 路由选择处理机得出路由表&#xff0c;路由表再生成转发表&#xff0c;从而实现分组从不同的端口转发 网络层向上层提供的两种服务&#xff1a;面向连接…

简历_熟悉缓存高并发场景处理方法,如缓存穿透、缓存击穿、缓存雪崩

系列博客目录 文章目录 系列博客目录1.缓存穿透总结 2.缓存雪崩3.缓存击穿代码总结 1.缓存穿透 缓存穿透是指客户端请求的数据在缓存中和数据库中都不存在&#xff0c;这样缓存永远不会生效&#xff0c;这些请求都会打到数据库。 常见的解决方案有两种&#xff1a; 缓存空对…

阿里云 人工智能与机器学习

阿里云的 人工智能&#xff08;AI&#xff09;与机器学习&#xff08;ML&#xff09; 服务为企业提供了全面的AI解决方案&#xff0c;帮助用户在多个行业实现数据智能化&#xff0c;提升决策效率&#xff0c;推动业务创新。阿里云通过先进的技术和丰富的工具&#xff0c;支持用…

LabVIEW语言学习过程是什么?

学习LabVIEW语言的过程可以分为几个阶段&#xff0c;每个阶段的重点内容逐步加深&#xff0c;帮助你从入门到精通。以下是一个简洁的学习过程&#xff1a; ​ 1. 基础入门阶段 理解图形化编程&#xff1a;LabVIEW是一种图形化编程语言&#xff0c;与传统的文本编程语言不同&am…

【办公类-47-02】20250103 课题资料快速打印(单个docx转PDF,多个pdf合并一个PDF 打印)

背景需求&#xff1a; 2023区级大课题《运用Python优化3-6岁幼儿学习活动材料的实践研究》需要做阶段资料 本来应该2024年6月就提交电子稿和打印稿。可是python学具的教学实验实在太多了&#xff0c;不断生成&#xff0c;我忙着做教学&#xff0c;都没有精力去整理。 2025年…

【CSS】第一天 基础选择器与文字控制属性

【CSS】第一天 1. CSS定义2. css引入方式2.1 内部样式2.2 外部样式2.3 行内样式 3. 选择器3.1 标签选择器3.2 类选择器3.3 id选择器3.4 通配符选择器 1. CSS定义 层叠样式表(CSS)是一种样式表语言&#xff0c;用来描述HTML文档的呈现(美化内容)。 书写位置&#xff1a;title标…

Nginx (40分钟学会,快速入门)

目录​​​​​​​ 一、什么是Nginx ? 可以做什么 &#xff1f; 二、正向代理和反向代理 三、负载均衡 四、动静分离 五、Nginx 常用命令 六、Nginx实战及总结 一、什么是Nginx ? 可以做什么 &#xff1f; Nginx 是高性能的 HTTP 和反向代理的 web 服务器&#xff0c…

单片机从入门到放弃教程001

1. 单片机介绍 单片微型计算机(Single Chip Microcomputer)简称单片机&#xff0c;是典型的嵌入式微处理器(Micro Controller Unit简称MCU)&#xff0c;是一种将中央处理器&#xff08;CPU&#xff09;、内存、输入输出接口以及其他功能模块集成在单一芯片上的微型计算机。 1…

[极客大挑战 2019]HardSQL 1

看了大佬的wp&#xff0c;没用字典爆破&#xff0c;手动试出来的&#xff0c;屏蔽了常用的关键字&#xff0c;例如&#xff1a;order select union and 最搞的是&#xff0c;空格也有&#xff0c;这个空格后面让我看了好久&#xff0c;该在哪里加括号。 先传入1’ 1试试&#…

深入Android架构(从线程到AIDL)_12 Android UI 单线程程序

目录 6、 Android UI 单线程程序 單線程程序概念 单线程可避免线程安全问题 SurfaceView与非UI线程 6、 Android UI 单线程程序 單線程程序概念 单线程程序意谓着两个(或多个)线程不能共享对象或变量值。Android的UI是单线程程序的环境。UI控件(如Button等)都是由UI线程所…

庐山派K230学习日记3 外设模块GPIO

GPIO和FPIOA 1 本节介绍​ 本节您将学习如何通过控制开发板的GPIO引脚&#xff0c;实现对RGB灯和按键的控制。 &#x1f3c6;学习目标 1️⃣如何将GPIO引脚配置为输出模式&#xff0c;通过引脚电平来控制RGB灯的颜色变化。 2️⃣如何将GPIO引脚配置为输入模式&#xff0c;来检…

【网络安全 | 漏洞挖掘】通过模拟功能实现提权(Bugcrowd)

未经许可,不得转载。 我将与大家分享我在 Bugcrowd 的某个项目中发现的一个漏洞,该项目中有一个“用户模拟”功能。 什么是用户模拟? 用户模拟允许管理员在不知晓用户凭据的情况下“以用户身份登录”。这种功能常见于管理员需要调试问题、审查用户权限或解决投诉的平台中。…

TCP Analysis Flags 之 TCP Retransmission

前言 默认情况下&#xff0c;Wireshark 的 TCP 解析器会跟踪每个 TCP 会话的状态&#xff0c;并在检测到问题或潜在问题时提供额外的信息。在第一次打开捕获文件时&#xff0c;会对每个 TCP 数据包进行一次分析&#xff0c;数据包按照它们在数据包列表中出现的顺序进行处理。可…

doris:基于 Arrow Flight SQL 的高速数据传输链路

Doris 基于 Arrow Flight SQL 协议实现了高速数据链路&#xff0c;支持多种语言使用 SQL 从 Doris 高速读取大批量数据。 用途​ 从 Doris 加载大批量数据到其他组件&#xff0c;如 Python/Java/Spark/Flink&#xff0c;可以使用基于 Arrow Flight SQL 的 ADBC/JDBC 替代过去…

HTML5实现好看的二十四节气网页源码

HTML5实现好看的新年春节元旦网站源码 前言一、设计来源1.1 主界面1.2 关于我们界面1.3 春季节气界面1.4 夏季节气界面1.5 秋季节气界面1.6 冬季节气界面 二、效果和源码2.1 动态效果2.2 源代码 源码下载结束语 HTML5实现好看的二十四节气网页源码&#xff0c;春季节气&#xf…

Elasticsearch:利用 AutoOps 检测长时间运行的搜索查询

作者&#xff1a;来自 Elastic Valentin Crettaz 了解 AutoOps 如何帮助你调查困扰集群的长期搜索查询以提高搜索性能。 AutoOps 于 11 月初在 Elastic Cloud Hosted 上发布&#xff0c;它通过性能建议、资源利用率和成本洞察、实时问题检测和解决路径显著简化了集群管理。 Au…

mysql报错2059

客户端连接mysql服务时提示2059错误&#xff0c;通常与身份验证插件有关&#xff0c;具体表现为客户端无法加载指定的身份验证插件。这个错误在MySQL 8.0及更高版本中较为常见&#xff0c;因为从MySQL 8.0开始&#xff0c;默认的加密规则从mysql_native_password变为了caching_…