JS获取file上传文件路径,后缀,大小,文件名


/**
*函数描述:获取input type=file的图像全路径
* @obj input type=file的对象
**/
function getFullPath(obj)
{
if(obj)
{
//ie
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
obj.select();
return document.selection.createRange().text;
}
//firefox
else if(window.navigator.userAgent.indexOf("Firefox")>=1)
{
if(obj.files)
{
return obj.files.item(0).getAsDataURL();
}
return obj.value;
}
return obj.value;
}
}

 

<input type="file" οnchange="document.getElementById('img').src=getFullPath(this);" >

 

=========================================================================

 

 

#判断IE还是Firefox

function getFullPath(obj)

{

if(obj)

{

//ie

if (window.navigator.userAgent.indexOf("MSIE")>=1)

{

obj.select();

return document.selection.createRange().text;

}

//firefox

else if(window.navigator.userAgent.indexOf("Firefox")>=1)

{

if(obj.files)

{

return obj.files.item(0).getAsDataURL();

}

return obj.value;

}

return obj.value;

}

}

 

 

 

#判断后缀名

function yulan(){

var filePath =getFullPath(document.getElementById('UpFile'));

var fileText =filePath.substring(filePath.lastIndexOf("."),filePath.length);

var fileName =fileText.toLowerCase();

if ((fileName!='.jpg')&&(fileName!='.gif')&&(fileName!='.jpeg')&&(fileName!='.png')&&(fileName!='.bmp'))

{

alert("对不起,系统仅支持标准格式的照片,请您调整格式后重新上传,谢谢 !");

document.form1.UpFile.focus();

}

else

{

document.getElementById("preview").innerHTML="<img src='"+getFullPath(document.getElementById('UpFile'))+"' width=120 style='border:6px double #ccc'>";

}

}

 

 

#判断文件大小

var Sys = {};

if(navigator.userAgent.indexOf("MSIE")>0) {

Sys.ie=true;

}

if(isFirefox=navigator.userAgent.indexOf("Firefox")>0){

Sys.firefox=true;

}

 

var maxLength = 5*1024*1024;

 

function checkFileChange(obj) {

var filesize = 0;

if(Sys.firefox){

filesize = obj.files[0].fileSize;

}else if(Sys.ie){

var filePath = obj.value;

var image=new Image();

image.src=filePath;

filesize=image.fileSize;

}

alert(filesize);

}

获取文件名

firefox的input表单的value值默认就可以获取到文件名,而ie 则显示文件路径。

所以要区别对待,在firefox下 lastIndexOf('/')得到的是-1,而在ie下,目录显示的又是反斜杠,\,当然在Linux
下,其他浏览器获取到的又是正斜杠 / ( 暂时未证明有Linux下有浏览器file获取到的值会是全路径);
得用两次判断:

function getFileName(path){
var pos1 = path.lastIndexOf('/');
var pos2 = path.lastIndexOf('\\');
var pos = Math.max(pos1, pos2)
if( pos<0 )
return path;
else
return path.substring(pos+1);
}

返回不带后缀的文件名

return name.substring(0,name.lastIndexOf('.'));


HTML、CSS和JavaScript可以配合使用实现登录注册功能。其中,HTML负责页面结构和内容,CSS负责页面样式,JavaScript负责页面交互和逻辑。一般情况下,登录注册需要与后端进行交互,以便验证用户输入的信息是否正确。 在HTML中,可以使用form标签来创建表单,通过input标签创建输入框等元素,使用户可以输入信息。在CSS中,可以对表单进行样式设置,美化表单的外观。在JavaScript中,可以通过获取表单元素的值,进行信息的校验和提交等操作。 为了显示文件后缀名,可以使用JavaScript来获取上传文件文件名,并从中提取出文件后缀名。具体实现方法可以参考以下代码: ```html <!DOCTYPE html> <html> <head> <title>Login/Register</title> <style> /* CSS 样式 */ input[type="text"], input[type="password"] { width: 100%; padding: 12px 20px; margin: 8px 0; display: inline-block; border: 1px solid #ccc; box-sizing: border-box; } input[type="submit"] { background-color: #4CAF50; color: white; padding: 14px 20px; margin: 8px 0; border: none; cursor: pointer; } input[type="submit"]:hover { background-color: #45a049; } </style> </head> <body> <h1>Login/Register</h1> <form action="#" method="post"> <label for="username">Username:</label><br> <input type="text" id="username" name="username" required><br> <label for="password">Password:</label><br> <input type="password" id="password" name="password" required><br> <label for="avatar">Avatar:</label><br> <input type="file" id="avatar" name="avatar" onchange="showFileName()"><br> <input type="submit" value="Submit"> </form> <script> // JavaScript 代码 function showFileName() { var fileInput = document.getElementById("avatar"); var fileName = fileInput.value.split("\\").pop(); // 获取文件名并去除路径 var fileExt = fileName.split(".").pop(); // 获取文件后缀名 alert("File name: " + fileName + ", File extension: " + fileExt); } </script> </body> </html> ``` 以上代码实现了一个简单的登录注册页面,并提供了一个上传头像的功能。在上传头像时,通过JavaScript获取文件名并从中提取出文件后缀名,并通过alert函数显示出来。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值