分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

图片上传时获取图片的宽和高

发布时间:2023-09-06 01:39责任编辑:郭大石关键词:暂无标签

  经常会遇到图片上传的问题,这时候我们会传图片的地址,宽和高到服务器,至于图片上传就不说了,这里主要说图片上传时获取图片的原始宽和高的问题。

  一般而言,我们把图片上传至服务器时,服务器会返回一个上传地址给我们,这个就是我们图片的url了,但是光有这个还是不够的,因为还要将图片的宽和高传给服务器,这时候就可以这样做了。直接上代码:  

var img = new Image()img.src = url

  然后就可以使用img.width和img.height来获取图片的宽和高了。当然仅仅这样做是不够的,因为图片上传是异步的,并不能直接使用该方法获取图片的宽和高,这样获取到的都是0.

  必须将上传的图片放置body标签里面才能去使用load事件,可以使用appendChild将img标签插入body标签里面(document.getElementsByTagName(‘body‘)[0].appendChild(img)),这样做会有一个问题,每次上传图片后页面底部都会多一张图,可以使用 display将其隐藏,然后使用onload方法,等图片加载完。 

img.onload = function(){ ?w = img.width; ?h = img.height ???????}

  然后将要发的请求放在一个方法里面,在onload事件里面去调用方法,否则load方法外面是获取不到宽和高的。

  当然了,还有另外一种方法,就是使用ES6的办法。 

async function foo(){ let img = new Image() img.src = ‘https://ss2.bdstatic.com/70cFvnSh_Q1YnxGkpoWK1HF6hhy/it/u=2546717774,3910079056&fm=200&gp=0.jpg‘ document.getElementsByTagName(‘body‘)[0].appendChild(img) // 图片插入body标签中,否则无法执行load事件 ???????img.style.display = ‘none‘ ?// 将图片隐藏 ?return {‘width‘:img.width,‘height‘:img.height} } foo().then((val) => { ??// async函数内部return语句返回的值,会成为then方法回调函数的参数。所以此处的val就是上面return语句返回的值 console.log(val) ?// {‘width‘:img.width,‘height‘:img.height} })

  

  

图片上传时获取图片的宽和高

原文地址:https://www.cnblogs.com/jf-67/p/8343635.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved