麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 開(kāi)發(fā) > HTML5 > 正文

input file上傳文件樣式支持html5的瀏覽器解決方案

2024-09-05 07:19:52
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
最近在使用畫(huà)布處理圖像像素時(shí)用到了file上傳控件,發(fā)現(xiàn)了file上傳控件的兩個(gè)兼容性問(wèn)題。一個(gè)是file上傳控件在火狐下無(wú)法通過(guò)css改變width,另一個(gè)是file上傳控件在不同的瀏覽器下的外觀和行為都不一樣。
下面是file上傳控件在IE10,firefox16,chrome22,opera12,safari5.1.7里的截圖:

 
在IE10里,雙擊輸入框或者單擊按鈕都彈出文件選擇框。在其他瀏覽器里單擊輸入框,按鈕或文字都可以觸發(fā)文件選擇框。
鑒于這種混亂情況,有必要要統(tǒng)一樣式和行為。下面是我的兼容性方案。
先看一下最終結(jié)果在各瀏覽器的截圖:


基本思路:創(chuàng)建輸入框和按鈕模擬file上傳控件。將file上傳控件設(shè)置成透明。讓file上傳控件與用于模擬的按鈕右對(duì)齊。修改元素的堆疊順序,讓按鈕處于下面,file上傳控件在中間,輸入框在上面。在文件選擇完畢后將file上傳控件里的值賦給用于模擬的輸入框。
原理:在不同的瀏覽器里,file上傳控件的按鈕的height都是可調(diào)的,而且file上傳控件的右側(cè)都是可以單擊的。所以通過(guò)調(diào)節(jié)file上傳控件的height,并調(diào)整file上傳控件的位置(右對(duì)齊),可以讓file上傳控件的可單擊區(qū)域與用于模擬的按鈕完全覆蓋。當(dāng)file上傳控件透明時(shí)用戶單擊用于模擬的按鈕就觸發(fā)了文件選擇框。但同時(shí)file上傳控件的堆疊順序不能先于用于模擬的輸入框,不然當(dāng)用戶將鼠標(biāo)置于所見(jiàn)的輸入框上時(shí)可能會(huì)看到光標(biāo)不是指示文本而是為一個(gè)箭頭(而且為一個(gè)箭頭時(shí)單擊會(huì)彈出文件選擇框),用戶將感到困惑。
實(shí)現(xiàn):先看看html部分的代碼。

復(fù)制代碼
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: av免费大全 | 国产一级淫片免费看 | 久久精品视频69 | 久久精品之| 精品国产一区二区三区四区阿崩 | 久久亚洲国产精品 | 精品国产乱码一区二区三区四区 | 国产精品麻豆一区二区三区 | ⅴideo裸体秀hd | 49vv看片免费| 激情在线免费观看 | 午夜视频在线观 | 午夜视频在线 | 亚州综合网 | 欧美国产成人在线 | 免费a级毛片大学生免费观看 | 黄色成人小视频 | 日本aaaa片毛片免费观蜜桃 | 久久久三级免费电影 | 青青草成人影视 | 性欧美极品xxxx欧美一区二区 | 久久爽精品区穿丝袜 | 99精品国产成人一区二区 | 亚洲视频黄 | 日本在线播放一区二区 | 精精国产xxxx视频在线野外 | 一二区成人影院电影网 | 全免费午夜一级毛片真人 | 国产剧情v888av | 欧美毛片在线观看 | 叉逼视频 | 男女一边摸一边做羞羞视频免费 | 性生活香蕉视频 | 久久国产免费 | 欧美精品18 | 国产91一区二区三区 | 黄色免费av网站 | 久久成人动漫 | 免费日本一区二区 | 亚洲综合一区二区三区 | av手机在线电影 |