当前位置: 首页 > 图文教程 > 网页制作 > HTML/XHTML教程 > 类型File的Input按钮功能研究

HTML/XHTML教程
HTML教程:脚本JS标记script详解
后缀是.shtml的网页文件你知道是什么意思吗?
中文Web设计HTML的em标记使用
IE8开发人员工具的菜单讲解(2)
精确测量网页的软件:FastStone Capture
HTML教程:iframe标记常见的几种使用方法
图片IMG标记的alt属性和title属性
网页中的H1标记的使用注意事项
Webjx推荐下载Photoshop网页按钮源文件
如何把PSD文件制作成XHTML+CSS文件
ASP生成静态Html文件的技术总结
网站建设过程中常见的5个HTML错误
HTML列表标记:dl、dt、dd
网页布局方案:弹性流体布局
真正的离线Web要靠HTML 5
采用列表设计网页的9个好处
连续滚动的超级链接文字网页代码
24个漂亮的个性化HTML表单技术
怎样解决DIV层被Flash动画遮盖问题?
Safari 4浏览器的一些新特性

HTML/XHTML教程 中的 类型File的Input按钮功能研究


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-11   浏览: 326 ::
收藏到网摘: n/a


在一些网站进行上传时,当单击了“浏览”按钮之后会弹出【选择文件】的对话框。很多时候我们需要只上传图像文件,那么在弹出的【选择文件】对话框中只显示了相关图片格式的文件,此外其余格式文件一律过滤不被显示。
比如 http://www.youku.com/v1.0.0326/v/swf/up.swf
这是优酷的视频上传选择,其是通过FLASH的方法来实现了不显示非视频类文件。
FLASH到这种效果一般也就是如这里所描述的
import flash.net.FileReferenceList;
var fileRef:FileReferenceList = new FileReferenceList();
var allTypes:Array = [];
var 浏览类型:Object = new Object();
浏览类型.description = "浏览类型(*.mp3)";
浏览类型.extension = "*.mp3";
allTypes.push(浏览类型);
fileRef.browse(allTypes);
所以针对我们的网页中<input type="File">能不能也实现弹出窗口限制文件类型呢?
现在的解决方法只能是通过监测来提醒用户上传文件的格式不正确
<script>
function check(){
var filepath=path.value
filepath=filepath.substring(filepath.lastIndexOf('.') 1,filepath.length)
if(filepath != 'jpg' && filepath != 'gif')
alert("只能上传JPG或GIF格式的图片")
}
</script>
<input type=file name=path onpropertychange="check()"> (只能上传JPG或GIF格式的图片)
<script>
function ck(obj){if(obj.value.length>0){
var af="jpg,gif,png,zip,rar,txt,htm";
if(eval("with(obj.value)if(!/" af.split(",").join("|") "/ig.test(substring(lastIndexOf('.') 1,length)))1;")){alert("Allowed file types:\n" af);obj.createTextRange().execCommand('delete')};
}}
</script>
<form>
<input type=file name=path onpropertychange="ck(this)"/></form>
不过这种效果显然没有FLASH的用户体验好。有必要对这类FLASH上传关注一下了。