首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JS获取图片原始宽高

最近在给博客的相册模块做优化,需要知道图片的原始大小,我以前的做法是把图片的真实宽高分别放在data-width和data-height中,效果是达到了,但是总觉得扩展性很低,当不知道图片的大小时,还要一张一张图片的去查看图片信息手动输入图片大小...,很繁琐 获取图片大小: 1.使用innerWidth,innerHeight 使用HTMLImageElement.innerWidth 是可以拿到图片的宽度 但是需要注意的是这里拿到的宽度是图像在CSS...像素中渲染的宽度 也就是说如果图片原始大小1200,使用css或者width属性设置为600,那么这里拿到的宽度为600,显然用innerWidth获取图片原始尺寸是不靠谱的 2.使用document.createElement...document.createElement("img") img.src = "1.jpg" var width = img.width 动态创建一个imgElement,通过给src赋值,最终来获取...img的宽和高 需要注意的是在给img的src赋值时,这是一个异步过程,会存在获取img的宽度时值为0(图片还未加载完成),可以在给img赋值之前加上onload事件 var img = document.createElement

6.1K20

剪切板图片粘贴上传

,具体过程是从电脑拖拽图片到网页,js在drop的事件中取到当前事件对象的dataTransfer进而得到文件对象,然后实例化formData对象,借助xhr异步上传图片,这无疑是一个锦上添花的功能,至此...这就是我今天要说的,剪切板图片粘贴上传,这个没什么太多可讲的,就是一些API的应用,所以直接看实现了。...二、代码实现 1、首先我们看一下怎么获取剪切版中的图片 document.addEventListener('paste', function(event) { var items = (event.clipboardData.../upload_file.php', true); xhr.send(formData); 当然上面的上传只是上传了图片,如果除了图片还需要上传其他内容比如文件名,时间之类的,只需要在初始化formData...三、局限性 对于qq,微信等的截图或者按print screen得到的截图,还有任意网页的右击复制图片都能完美支持,但是,对于电脑本地图片文件的复制没办法从剪切版获取到,如果有哪位朋友发现了可以实现的方法

2.7K10
您找到你想要的搜索结果了吗?
是的
没有找到

Vue实现剪切板图片压缩

前言 监听剪切板粘贴事件,读取剪切板中的图片文件,转成base64通过img标签显示出来,此时可能会存在剪切板图片过大,产生上传速度慢问题,接下来就跟大家分享下如何将base64图片进行压缩。...先跟大家展示下最终实现的效果: 实现思路 监听剪切板粘贴事件 从事件回调中获取clipboardData中的image对象声明一个变量接收该对象 使用reader.readAsDataURL方法加载clipboardData...中的image对象 在reader.onload回调中获取图片base64码 创建Image对象,赋值图片base64码至当前对象的src属性 调用Image对象的onload函数,获取图片宽高等信息...声明canvas画布宽高分别为当前图片宽高除以缩放比例的值 使用drawImage方法绘制当前图片 实现过程 本篇文章主要讲解剪切板图片压缩的实现,效果图中如何将剪切板图片插入可编辑div以及如何发送...,请移步我的另一篇文章:Vue解析剪切板图片并实现发送功能 监听剪切板粘贴事件: 实现图片粘贴 const that = this; document.body.addEventListener

1.1K40

JS获取图片中随机一点颜色

实现效果 昨天泽泽分享了一篇有意思的文章:纯CSS根据图片取色设置背景色,主要分享了一个就是div嵌套img的时候,如何实现div的颜色为img中一点的颜色。...如下图所示,在PS中打开一张图片,如果将这张图片一直放大,具体到每个像素点,会发现图片单个像素点内的颜色值都是唯一的。...实现效果 有了具体的思路了就是如何实现了,因为我这个页面是前后端渲染的动态页面,改PHP代码的话有点麻烦,所以我就考虑从前端入手,使用JQuery来实现: 获取每一个友链链接.board-item; 然后通过显示迭代获取每一个友链中的背景图...; 然后将下方文字的背景图设置为获取的背景图地址,同时,使用Math.random()产生一个随机数,这样的话就可以实现对图片中随机一点进行取色,且每次刷新都会产生不一样的效果。...text-align:center; } span { color:red; } <script src="https://code.jquery.com/jquery-latest.<em>js</em>

3.7K30

Vue解析剪切板图片并实现发送功能

实现思路 页面挂载时监听剪切板粘贴事件 监听文件流 读取文件流中的数据 创建img标签 将获取到的base64码赋值到img标签的src属性 将生成的img标签append到即将发送的消息容器里 监听回车事件...获取可编辑div容器中的所有子元素 遍历获取到的元素,找出img元素 判断当前img元素是否有alt属性(表情插入时有alt属性), 如果没有alt属性当前元素就是图片 将base64格式的图片转成文件上传至服务器...上传成功后,将服务器返回的图片地址推送到websocket服务 客户端收到推送后,渲染页面 实现过程 本片文章主要讲解剪切板图片的解析以及将base64图片转换成文件上传至服务器,下方代码中的axios...的封装以及websocket的配置与使用可参考我的另外两篇文章:Vue合理配置axios并在项目中进行实际应用和Vue合理配置WebSocket并实现群聊 监听剪切板事件(mounted生命周期中),将图片渲染到即将发送到消息容器里...$fullScreenLoading.show("读取图片中"); // 获取当前输入框内的文字 const oldText = that.

1.3K20

clipboard.js:最轻便的复制页面内容到剪切板JS

传统的复制页面内容到剪切板主要方法是通过 Flash,但是在现代浏览器中,Flash 逐渐没落,慢慢被淘汰,搜索了一圈,发现 clipboard.js 是目前实现该功能最轻便的工具。...clipboard.js 的使用方法 clipboard.js 只有3kb大小,无需 Flash,兼容所有现代浏览器,但是经过测试不支持微信内置浏览器。...使用还算简单,简单几步就搞定,下面简单介绍下clipboard.js的使用方法: 1....首先下载或者使用CDN的资源: <script type='text/javascript' src="https://cdn.staticfile.org/clipboard.<em>js</em>/1.5.15/clipboard.min.<em>js</em>...的演示 我爱水煮鱼是最好的博客 复制 clipboard.<em>js</em> 的事件 有时候我们需要一些用户反馈,在初始化对象的时候可以定义 success 和 error 两个事件: var clipboard

2.5K60

JS 图片压缩

前言 说起图片压缩,大家想到的或者平时用到的很多工具都可以实现,例如,客户端类的有图片压缩工具 PPDuck3, JS 实现类的有插件 compression.js ,亦或是在线处理类的 OSS 上传,...文件上传后,在访问文件时中也有图片的压缩配置选项,不过,能不能自己撸一套 JS 实现的图片压缩代码呢?...压缩思路 涉及到 JS图片压缩,我的想法是需要用到 Canvas 的绘图能力,通过调整图片的分辨率或者绘图质量来达到图片压缩的效果,实现思路如下: 获取上传 Input 中的图片对象 File 将图片转换成...= `${new Date().getTime()}-${fileObj.name}`; // 获取文件后缀名 const fileNames = fileObj.name.split...,可以是页面上获取的 DOM 对象,也可以是虚拟 DOM 中的图片对象。

25.7K21
领券