成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

獲取在input:file中選中圖片的寬高信息

Benedict Evans / 2555人閱讀

摘要:前言想直接看干貨的直接跳到第二點(diǎn)有時(shí)我們想在希望在表單提交前獲取到中選中圖片的一些信息比如說圖片的寬高等等但是我們知道的通過控件的事件只能獲取到文件的一些基本信息像文件大小最后修改時(shí)間等等嗯哼首先先想想前提怎樣才能獲得一個(gè)圖片的寬高呢噢只要

1. 前言

想直接看干貨的直接跳到第二點(diǎn)

有時(shí)我們想在希望在表單提交前獲取到中選中圖片的一些信
息,比如說圖片的寬高等等,但是我們知道的,通過file控件的onchange事件只能獲取
到文件的一些基本信息,像文件大小,最后修改時(shí)間等等.

嗯哼,首先先想想前提,怎樣才能獲得一個(gè)圖片的寬高呢?!噢,只要先獲取到目標(biāo)圖
元素,那圖片元素怎么獲取呢?!第一種方式可以用過DOM操作獲得目標(biāo)(這里不再說明),然
后寬高通過對(duì)應(yīng)的width屬性和height屬性獲取,第二種是在js里面手動(dòng)創(chuàng)建一個(gè)Image
對(duì)象(下面有具體代碼事例),再給這個(gè)Image對(duì)象賦予對(duì)應(yīng)的src不就得了,哇哈哈,基本的
條理已經(jīng)梳理清楚了,那么請(qǐng)看下面的實(shí)際代碼操作:

2. 操作方法

① window.URL || window.webkitURL

Basic support:
Chrome:8.0[2]
Firefox (Gecko): 4.0 (2.0)[1] 19.0 (19.0)
ie:10.0
Opera:15.0[2]
Safari:6.0[2] 7.0

    注意:這只是一個(gè)試驗(yàn)性的技術(shù)還不穩(wěn)固,語法未來可能會(huì)隨著瀏覽器的更新?lián)Q代
 隨之改變.
    
    window.URL屬性返回一個(gè)對(duì)象,這和對(duì)象提供了一個(gè)靜態(tài)createObjectURL()方法去
 創(chuàng)建和管理object URLs.
//基于jquery,選的某一個(gè)本地文件
$("#file").on("change",function () {
        let url = window.URL || window.webkitURL;
        console.log(url.createObjectURL(this.files[0]));//this.files[0]為選中的文件(索引為0因?yàn)槭菃芜x一個(gè)),這里是圖片
            let img = new Image();              //手動(dòng)創(chuàng)建一個(gè)Image對(duì)象
            img.src = url.createObjectURL(this.files[0]);//創(chuàng)建Image的對(duì)象的url
            img.onload = function () {
                console.log("height:"+this.height+"----width:"+this.width)
            }
    });

結(jié)果(google瀏覽器測試):

②HTML5中的FileReader

既然是HTML5中的方法,當(dāng)然一些ie低版本就使用不了啦,具體歡迎測試反饋,嘻嘻
   $("#file").on("change",function () {
        let reader = new FileReader();
        reader.readAsDataURL(this.files[0]);//這里把一個(gè)文件用base64編碼,具體什么是base64編碼,我將稍后在不久的文章中介紹
        reader.onload = function(e){
            let img = new Image();
            img.src = e.target.result;//獲取編碼后的值,也可以用this.result獲取
            img.onload = function () {
                console.log("height:"+this.height+"----width:"+this.width)
            }
        }

結(jié)果(google瀏覽器測試):

3.結(jié)論

這兩種方式都有低版本瀏覽器不兼容的現(xiàn)象,但考慮到它們會(huì)逐漸退出市場,所以先大膽
用吧,遇到問題再討論,拜了個(gè)拜.

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/51552.html

相關(guān)文章

  • 瀏覽器兼容問題

    摘要:一什么是瀏覽器兼容問題所謂的瀏覽器兼容性問題,是指因?yàn)椴煌臑g覽器對(duì)同一段代碼有不同的解析,造成頁面顯示效果不統(tǒng)一的情況。條件注釋最初于微軟的瀏覽器中出現(xiàn),并且直至均支持。 一、什么是瀏覽器兼容問題 所謂的瀏覽器兼容性問題,是指因?yàn)椴煌臑g覽器對(duì)同一段代碼有不同的解析,造成頁面顯示效果不統(tǒng)一的情況。在大多數(shù)情況下,我們的需求是,無論用戶用什么瀏覽器來查看我們的網(wǎng)站或者登陸我們的系統(tǒng),都...

    wenshi11019 評(píng)論0 收藏0
  • JavaScript圖片處理與合成(一)

    摘要:中的圖片處理與合成一引言圖片處理現(xiàn)在已經(jīng)成為了我們生活中的剛需,想必大家也經(jīng)常有這方面的需求。實(shí)際前端業(yè)務(wù)中,也經(jīng)常會(huì)有很多的項(xiàng)目需要用到圖片加工和處理。 JavaScript中的圖片處理與合成(一) 引言: 圖片處理現(xiàn)在已經(jīng)成為了我們生活中的剛需,想必大家也經(jīng)常有這方面的需求。實(shí)際前端業(yè)務(wù)中,也經(jīng)常會(huì)有很多的項(xiàng)目需要用到圖片加工和處理。由于過去一段時(shí)間公司的業(yè)務(wù)需求,讓我在這方面積累...

    Charles 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<