【架构师(第五十二篇)】 几个前端工具的基本使用

news2025/7/3 4:31:52

前端截图

html2canvas 基本用法

import html2canvas from 'html2canvas'
const screenshot = () => {// 获取需要截图的 dom 节点const el = document.getElementById('target-id')// 第一个参数是节点,第二个参数是一些配置// 默认是不对跨域资源做处理, 需要添加额外的配置 useCORS,并且需要资源本身支持跨域// scale 默认使用 window.devicePixelRatio 导致图片尺寸可能和设置的不同, 这里手动改为1html2canvas(el, { width: 375, useCORS: true, scale: 1 }).then(canvas => {// 获取要显示的节点const image = document.getElementById('show-id')// 调用 canvas 的 toDataUrl 方法转成 base64 的图片赋值给 srcimage.src = canvas.toDataUrl()})
} 

踩坑1

在截图的时候,虽然设置了 width,但是会出现实际尺寸和设置的值不一样的情况。

设备像素/物理像素

设备像素也被称为物理像素,是显示设备中一个最微小的物理部件,在同一设备中,物理像素的总数是固定的。

独立像素/CSS像素

CSS 像素是一个抽象的单位,主要使用在浏览器上,用来精确的度量 Web 页面上的内容,CSS 像素被称为与设备无关的像素(device-independent像素),简称为 DIPs

window.devicePixelRatio

返回当前显示设备的物理像素分辨率与CSS像素分辨率之比,简单来说,它告诉浏览器应该使用多少屏幕实际像素来绘制单个 CSS 像素。

所以在标准屏幕下,devicePixelRatio 应该为 1

特例

视网膜(Retina)显示屏,它会使用更多的屏幕像素绘制相同的对象,从而获得更清晰的图像,devicePixelRatio2

所以虽然我们设置的元素 css 尺寸是 375px,但是因为 Apple 是视网膜屏幕,所以使用了两倍于 css 尺寸的设备像素来渲染它,这就是最后图片尺寸为 750px 的原因。

踩坑2

html2canvas 在截图的时候, 无法渲染 box-shadow 属性,哪怕是初始值,会渲染出一块黑色的东西。

需要把 box-shadow 属性的值给设置为 none

另外,无法截取隐藏部分的内容。

生成二维码

qrcode

TS 需要单独安装类型文件

npm install --save qrcode
npm install --save-dev @types/qrcode 

基础用法

// 需要一个 canvas 节点
<canvas id='canvas-qrcode'></canvas>

import QRCode from 'qrcode'

const qrCode = () => {// 获取需要生成二维码的 dom 节点const ele = document.getElementById('canvas-qrcode')// 生成二维码QRCode.toCanvas(ele, 'www.baidu.com', { width: 100 }).then(() => {console.log('success')})
} 

复制到剪切板

TS 不需要单独安装类型文件

npm install --save clipboard 

基础用法

// 需要一个目标元素, 拥有唯一的 id
<div id='target-id'>我是被复制的内容</div>
// 需要一个进行复制操作的元素 ,需要添加自定义属性 data-clipboard-target, 需与目标 id 相同
// data-clipboard-action 属性是要进行的操作, 默认是 copy 复制, 也支持 cut 剪切
<div data-clipboard-target="#target-id" class="copy-btn" data-clipboard-action="cut">点我进行复制</div>

import Clipboard from 'clipboard'

// 参数是复制元素的选择器
const clipboard = new Clipboard(".copy-btn")

// 基于事件的回调
clipboard.on('success', (e) => {console.log('复制成功');e.clearSelection()
})
clipboard.on('error', (e) => {console.log('复制失败');
}) 

下载文件

FileSaver.js

TS 需要单独安装类型文件

npm install --save file-saver
npm install --save-dev @types/file-saver 

基础用法

import { saveAs } from 'file-saver'

// 第一个参数是文件, 字符串或blob类型, 第二个参数是文件名
saveAs(file, filename) 

最后

整理了75个JS高频面试题,并给出了答案和解析,基本上可以保证你能应付面试官关于JS的提问。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

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

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

相关文章

绿色高效办公,华为云桌面不可或缺

在互联网高速发展的今天&#xff0c;互联网应用已经成为人们日常生活中不可或缺的一部分。随着网络技术的不断成熟&#xff0c;越来越多的人开始使用云桌面作为工作平台来满足自己对高效便捷工作的需求&#xff0c;而其中最为典型的就是企业内部远程协同办公系统。 那么什么是云…

InnoDB详解 (1)

文章目录1 InnoDB详解 &#xff08;1&#xff09;1 概念介绍2 页介绍1 页内部结构介绍1 File Header&#xff08;文件头部&#xff09;&#xff08;38字节&#xff09;2 File Trailer&#xff08;文件尾部&#xff09;&#xff08;8字节&#xff09;3 Free Space (空闲空间)4 U…

十、51单片机之步进电机

1、什么是步进电机 1.1、外观 1.2、概念 (1)步进电机是一种将电脉冲信号转换成相应角位移或线位移的电动机。每输入一个脉冲信号&#xff0c;转子就转动一个角度或前进一步&#xff0c;其输出的角位移或线位移与输入的脉冲数成正比&#xff0c;转速与脉冲频率成正比。因此&am…

VSCode调试C/C++项目

最近写完了自己的操作系统&#xff0c;深感有一个方便的调试环境是有多么重要&#xff0c;能够提升不少开发效率。恰好最近在的技术交流群里群友在问如何搭建VSCode调试操作系统的环境&#xff0c;刚考完试&#xff0c;就先把这篇VSCode调试C/C的通用教程发出来&#xff0c;而后…

Hadoop综合项目——二手房统计分析(MapReduce篇)

Hadoop综合项目——二手房统计分析&#xff08;MapReduce篇&#xff09; 文章目录Hadoop综合项目——二手房统计分析&#xff08;MapReduce篇&#xff09;0、 写在前面1、MapReduce统计分析1.1 统计四大一线城市房价的最值1.2 按照城市分区统计二手房数量1.3 根据二手房信息发布…

全网首发“Java面试考点大全”,20+互联网公司,应有尽有

受疫情影响&#xff0c;今年似乎给人感觉时间比往年还要流逝得更快。显然&#xff0c;春节一过&#xff0c;我们又将迎来面试旺季金三银四。对于程序员来说&#xff0c;秋招的失利更意味着在金三银四要打一场“硬战”&#xff0c;可又有多少人做好了面试的准备呢&#xff1f;对…

Fabric.js 监听元素相交(重叠)

本文简介 点赞 关注 收藏 学会了 fabric.js 提供了一个方法可以检查对象是否与另一个对象相交&#xff08;也可以叫元素是否重叠&#xff09;。 这个方法叫 intersectsWithObject()。 本文主要想提一下 fabric.js 存在这么一个方便的方法。 检测元素是否相交有什么用呢&am…

【UE4 第一人称射击游戏】04-血溅效果

素材资料地址&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1epyD62jpOZg-o4NjWEjiyg 密码&#xff1a;jlhr 效果&#xff1a; 步骤&#xff1a; 1.将图片素材导入UE4 2.创建一个控件蓝图&#xff0c;命名为“Damageeffect” 双击打开“Damageeffect”&#xff0…

【关于时间序列的ML】项目 6 :机器学习中使用 LSTM 的时间序列

&#x1f50e;大家好&#xff0c;我是Sonhhxg_柒&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流&#x1f50e; &#x1f4dd;个人主页&#xff0d;Sonhhxg_柒的博客_CSDN博客 &#x1f4c3; &#x1f381;欢迎各位→点赞…

现在转行学python,前景和优势有哪些?

正所谓“男怕入错行&#xff0c;女怕嫁错郎”&#xff0c;可想而知进入一个正确的行业有多重要。 IT行业的高薪吸引着越来越多转行“入坑”&#xff0c;python作为目前的大势&#xff0c;是很多人转行的首选。 为什么这么多的人都想转行学习python&#xff0c;python有哪些前…

【架构师(第四十九篇)】 服务端开发之认识 Docker-compose

Docker-compose 介绍 通过一个配置文件&#xff0c;可以让系统一键启动所有的运行环境&#xff0c;nodejs&#xff0c;mysql&#xff0c;redis&#xff0c;mongodb 等。 如果开发环境需要多个服务&#xff0c;就需要启动多个 Docker 容器。 要连通多个 Docker 容器&#xf…

转行程序员,如何挑选既高薪又适合的编程语言?

“你为什么要学这个编程语言&#xff1f;” 很多人面对这个问题时&#xff0c;都回答不上来&#xff0c;大部分都只是看到了表象&#xff0c;或是脑子一热&#xff0c;随意给自己选了一个。事实上自己对这个编程语言的特性和市场现状并不了解&#xff0c;甚至都不知道这个语言到…

关于为什么要做量化白皮书这件事

我们一直想着再为行业做点什么 是从什么时候开始 在心里埋下了种子呢 许是从有人说“高频量化不除&#xff0c;市场再无宁日”的时候 是从中国基金报房佩燕老师写“这锅我们不背“的时候 是从部分量化私募主动站出来说话的时候 现今的互联网时代信息太繁杂 有时可以不用太…

ETCD的创建

一&#xff1a; 好原文链接&#xff1a; 搭建高可用Kubernetes集群之etcd v3.4.13集群搭建(一&#xff09; - 人艰不拆_zmc - 博客园1. etcd 简介 coreos 开发的分布式服务系统&#xff0c;内部采用 raft 协议作为一致性算法。作为服务发现系统&#xff0c;有以下的特点&#x…

【Vue】源码—虚拟DOM和diff算法

1.理解虚拟DOM和diff算法 1.1什么是虚拟DOM&#xff1f; 从本质上来说&#xff0c;虚拟DOM是一个JavaScript对象&#xff0c;通过对象的方式来表示DOM结构。将页面状态抽象为JS对象的形式&#xff0c;配合不同的渲染工具&#xff0c;使跨平台渲染成为可能。虚拟DOM是DOM的抽象…

【Python百日进阶-数据分析】Day136 - plotly旭日图:px.sunburst()实例

文章目录四、实例4.1 带有 plotly.express 的旭日图4.1.1 基础旭日图4.1.2 带有 plotly.express 的矩形 DataFrame 的旭日形4.1.3 改变path顺序&#xff0c;从而改变父子关系4.1.4 在 px.sunburst 中具有连续颜色参数的矩形 DataFrame 的 Sunburst4.1.5 在 px.sunburst 中具有离…

20岁电竞选手自学编程转行程序员,轻松拿下大厂offer

话说 人与人之间的差距 貌似挺小的 毕竟 不管是大佬还是我们 都是两只眼睛、一个鼻子、一张嘴 不多不少 醒醒&#xff0c;别睡了 人和人的差距是很大的&#xff01; 同样身为互联网冲浪选手 别人干啥啥都行 你却只会在评论区扣“牛X” #01 在多数人的认知里 电竞选…

校园网上报修系统/宿舍报修系统的设计与实现

摘要 随着科学技术的飞速发展&#xff0c;社会的方方面面、各行各业都在努力与现代的先进技术接轨&#xff0c;通过科技手段来提高自身的优势&#xff0c;校园网上报修系统当然也不能排除在外&#xff0c;从报修信息的统计和分析&#xff0c;在过程中会产生大量的、各种各样的数…

Java Number Math 类

一般地&#xff0c;当需要使用数字的时候&#xff0c;我们通常使用内置数据类型&#xff0c;如&#xff1a;byte、int、long、double 等。 实例 int a 5000; float b 13.65f; byte c 0x4a; 然而&#xff0c;在实际开发过程中&#xff0c;我们经常会遇到需要使用对象&…

Java -- OSS对象存储服务(Object Storage Service,简称 OSS)文件服务器

一个成熟的技术架构要有一定的分离性&#xff0c; 平台级的产品一般会这么分&#xff1a;应用服务器、数据库服务器、文件服务器。一般文件、数据库、应用服务器&#xff0c;都应该做逻辑和物理的分离。 以前我们想要做文件上传可能要自己去搭建一个专门的服务器&#xff0c;然…