ajaxFileUpload.js 很多同名的,因为做出来一个很容易。

我用的是这个:https://github.com/carlcarl/AjaxFileUpload
下载地址在这里:http://xiazai./201701/yuanma/ajaxfileupload().rar
AjaxFileUpload.js并不是一个很出名的插件,只是别人写好的放出来供大家用,原理都是创建隐藏的表单和iframe然后用JS去提交,获得返回值。
当初做了个异步上传的功能,选择它因为它的配置方式比较像jQuery的AJAX,我很喜欢。
评论里面说到的不行。那是因为我们用的不是同一个js。我上github搜AjaxFileUpload出来很多类似js。
ajaxFileUpload是一个异步上传文件的jQuery插件。
传一个不知道什么版本的上来,以后不用到处找了。
语法:$.ajaxFileUpload([options])
options参数说明:
1、url 上传处理程序地址。
2、fileElementId 需要上传的文件域的ID,即<input type="file">的ID。
3、secureuri 是否启用安全提交,默认为false。
4、dataType 服务器返回的数据类型。可以为xml,script,json,html。如果不填写,jQuery会自动判断。
5、success 提交成功后自动执行的处理函数,参数data就是服务器返回的数据。
6、error 提交失败自动执行的处理函数。
7、data 自定义参数。这个东西比较有用,当有数据是与上传的图片相关的时候,这个东西就要用到了。
8、 type 当要提交自定义参数时,这个参数要设置成post
错误提示:
1、SyntaxError: missing ; before statement错误
如果出现这个错误就需要检查url路径是否可以访问
2、SyntaxError: syntax error错误
如果出现这个错误就需要检查处理提交操作的服务器后台处理程序是否存在语法错误
3、SyntaxError: invalid property id错误
如果出现这个错误就需要检查文本域属性ID是否存在
4、SyntaxError: missing } in XML expression错误
如果出现这个错误就需要检查文件name是否一致或不存在
5、其它自定义错误
大家可使用变量$error直接打印的方法检查各参数是否正确,比起上面这些无效的错误提示还是方便很多。
使用方法:
第一步:先引入jQuery与ajaxFileUpload插件。注意先后顺序,这个不用说了,所有的插件都是这样。
<script src="jquery-1.7.1.js" type="text/javascript"></script> <script src="ajaxfileupload.js" type="text/javascript"></script>
第二步:HTML代码:
<body> <p><input type="file" id="file1" name="file" /></p> <input type="button" value="上传" /> <p><img id="img1" alt="上传成功啦" src="" /></p> </body>
第三步:JS代码
<script src="jquery-1.7.1.js" type="text/javascript"></script>
<script src="ajaxfileupload.js" type="text/javascript"></script>
<script type="text/javascript">
$(function () {
$(":button").click(function () {
ajaxFileUpload();
})
})
function ajaxFileUpload() {
$.ajaxFileUpload
(
{
url: '/upload.aspx', //用于文件上传的服务器端请求地址
secureuri: false, //是否需要安全协议,一般设置为false
fileElementId: 'file1', //文件上传域的ID
dataType: 'json', //返回值类型 一般设置为json
success: function (data, status) //服务器成功响应处理函数
{
$("#img1").attr("src", data.imgurl);
if (typeof (data.error) != 'undefined') {
if (data.error != '') {
alert(data.error);
} else {
alert(data.msg);
}
}
},
error: function (data, status, e)//服务器响应失败处理函数
{
alert(e);
}
}
)
return false;
}
</script>
第四步:后台页面upload.aspx代码:
protected void Page_Load(object sender, EventArgs e)
{
HttpFileCollection files = Request.Files;
string msg = string.Empty;
string error = string.Empty;
string imgurl;
if (files.Count > 0)
{
files[0].SaveAs(Server.MapPath("/") + System.IO.Path.GetFileName(files[0].FileName));
msg = " 成功! 文件大小为:" + files[0].ContentLength;
imgurl = "/" + files[0].FileName;
string res = "{ error:'" + error + "', msg:'" + msg + "',imgurl:'" + imgurl + "'}";
Response.Write(res);
Response.End();
}
}
本实例完整代码下载
来一个MVC版本的实例:
控制器代码
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult Upload()
{
HttpFileCollection hfc = System.Web.HttpContext.Current.Request.Files;
string imgPath = "";
if (hfc.Count > 0)
{
imgPath = "/testUpload" + hfc[0].FileName;
string PhysicalPath = Server.MapPath(imgPath);
hfc[0].SaveAs(PhysicalPath);
}
return Content(imgPath);
}
}
前端视图,HTML与JS代码,成功上传后,返回图片真实地址并绑定到<img>的SRC地址
<html>
<head>
<script src="/jquery-1.7.1.js" type="text/javascript"></script>
<script src="/ajaxfileupload.js" type="text/javascript"></script>
<script type="text/javascript">
$(function () {
$(":button").click(function () {
if ($("#file1").val().length > 0) {
ajaxFileUpload();
}
else {
alert("请选择图片");
}
})
})
function ajaxFileUpload() {
$.ajaxFileUpload
(
{
url: '/Home/Upload', //用于文件上传的服务器端请求地址
secureuri: false, //一般设置为false
fileElementId: 'file1', //文件上传空间的id属性 <input type="file" id="file" name="file" />
dataType: 'HTML', //返回值类型 一般设置为json
success: function (data, status) //服务器成功响应处理函数
{
alert(data);
$("#img1").attr("src", data);
if (typeof (data.error) != 'undefined') {
if (data.error != '') {
alert(data.error);
} else {
alert(data.msg);
}
}
},
error: function (data, status, e)//服务器响应失败处理函数
{
alert(e);
}
}
)
return false;
}
</script>
</head>
<body>
<p><input type="file" id="file1" name="file" /></p>
<input type="button" value="上传" />
<p><img id="img1" alt="上传成功啦" src="" /></p>
</body>
</html>
最后再来一个上传图片且附带参数的实例:控制器代码:
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
public ActionResult Upload()
{
NameValueCollection nvc = System.Web.HttpContext.Current.Request.Form;
HttpFileCollection hfc = System.Web.HttpContext.Current.Request.Files;
string imgPath = "";
if (hfc.Count > 0)
{
imgPath = "/testUpload" + hfc[0].FileName;
string PhysicalPath = Server.MapPath(imgPath);
hfc[0].SaveAs(PhysicalPath);
}
//注意要写好后面的第二第三个参数
return Json(new { Id = nvc.Get("Id"), name = nvc.Get("name"), imgPath1 = imgPath },"text/html", JsonRequestBehavior.AllowGet);
}
}
Index视图代码:
<html>
<head>
<script src="/jquery-1.7.1.js" type="text/javascript"></script>
<script src="/ajaxfileupload.js" type="text/javascript"></script>
<script type="text/javascript">
$(function () {
$(":button").click(function () {
if ($("#file1").val().length > 0) {
ajaxFileUpload();
}
else {
alert("请选择图片");
}
})
})
function ajaxFileUpload() {
$.ajaxFileUpload
(
{
url: '/Home/Upload', //用于文件上传的服务器端请求地址
type: 'post',
data: { Id: '123', name: 'lunis' }, //此参数非常严谨,写错一个引号都不行
secureuri: false, //一般设置为false
fileElementId: 'file1', //文件上传空间的id属性 <input type="file" id="file" name="file" />
dataType: 'json', //返回值类型 一般设置为json
success: function (data, status) //服务器成功响应处理函数
{
alert(data);
$("#img1").attr("src", data.imgPath1);
alert("你请求的Id是" + data.Id + " " + "你请求的名字是:" + data.name);
if (typeof (data.error) != 'undefined') {
if (data.error != '') {
alert(data.error);
} else {
alert(data.msg);
}
}
},
error: function (data, status, e)//服务器响应失败处理函数
{
alert(e);
}
}
)
return false;
}
</script>
</head>
<body>
<p><input type="file" id="file1" name="file" /></p>
<input type="button" value="上传" />
<p><img id="img1" alt="上传成功啦" src="" /></p>
</body>
</html>
此实例在显示出异步上传图片的同时并弹出自定义传输的参数。本实例下载地址
2013年1月28日,今天调试过程中发现一个问题,就是作为文件域(<input type="file">)必须要有name属性,如果没有name属性,上传之后服务器是获取不到图片的。如:正确的写法是<input type="file" id="file1" name="file1" />
2013年1月28日,最经典的错误终于找到原因所在了。Object function (a,b){return new e.fn.init(a,b,h)} has no method 'handleError',这个是google浏览器报的错误,非常经典, 不知道是我的版本问题还是真正存在的问题。这个问题的根源经过N次上传才找到问题的根本所在。答案是:dataType参数一定要大写。如:dataType: 'HTML'。
2016-07-28,评论中的一个错误:TypeError: $.ajaxFileUpload is not a function 我们用的不是同一个JS,你下了别的AJAXFileUpload去了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# jQuery
# ajaxFileUpload
# ajaxFileupload实现多文件上传功能
# jQuery插件ajaxFileUpload异步上传文件
# jQuery插件ajaxfileupload.js实现上传文件
# ThinkPHP结合AjaxFileUploader实现无刷新文件上传的方法
# ajaxFileUpload.js插件支持多文件上传的方法
# Thinkphp结合ajaxFileUpload实现ajax异步图片传输全套代码
# 上传
# 设置为
# 文件上传
# 自定义
# 返回值
# 都是
# 是一个
# 下载地址
# 请选择
# 上传图片
# 是否存在
# 错误提示
# 的是
# 在这里
# 去了
# 说了
# 要有
# 下了
# 这个问题
# 说到
相关文章:
如何快速生成ASP一键建站模板并优化安全性?
如何用美橙互联一键搭建多站合一网站?
建站之星客服服务时间及联系方式如何?
建站之星后台管理:高效配置与模板优化提升用户体验
建站之星如何开启自定义404页面避免用户流失?
如何快速搭建FTP站点实现文件共享?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
山东云建站价格为何差异显著?
如何在阿里云域名上完成建站全流程?
建站主机是否属于云主机类型?
如何快速搭建自助建站会员专属系统?
建站之星24小时客服电话如何获取?
建站主机如何安装配置?新手必看操作指南
如何通过西部数码建站助手快速创建专业网站?
Python多线程使用规范_线程安全解析【教程】
建站之星如何快速生成多端适配网站?
如何快速生成凡客建站的专业级图册?
如何通过FTP服务器快速搭建网站?
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
建站主机是否等同于虚拟主机?
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
如何解决ASP生成WAP建站中文乱码问题?
如何选择香港主机高效搭建外贸独立站?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
如何构建满足综合性能需求的优质建站方案?
南京网站制作费用,南京远驱官方网站?
网站制作公司排行榜,抖音怎样做个人官方网站
制作表格网站有哪些,线上表格怎么弄?
如何通过主机屋免费建站教程十分钟搭建网站?
用v-html解决Vue.js渲染中html标签不被解析的问题
如何基于PHP生成高效IDC网络公司建站源码?
相册网站制作软件,图片上的网址怎么复制?
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
成都网站制作公司哪家好,四川省职工服务网是做什么用?
高防服务器如何保障网站安全无虞?
如何在万网自助建站平台快速创建网站?
淘宝制作网站有哪些,淘宝网官网主页?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
,网站推广常用方法?
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
建站之星Pro快速搭建教程:模板选择与功能配置指南
如何在万网主机上快速搭建网站?
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
沈阳制作网站公司排名,沈阳装饰协会官方网站?
如何选择高效可靠的多用户建站源码资源?
建站之星备案流程有哪些注意事项?
如何获取开源自助建站系统免费下载链接?
如何零成本快速生成个人自助网站?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
*请认真填写需求信息,我们会在24小时内与您取得联系。