通过FormData对象可以组装一组用 XMLHttpRequest发送请求的键/值对。它可以更灵活方便的发送表单数据,因为可以独立于表单使用。如果你把表单的编码类型设置为multipart/form-data ,则通过FormData传输的数据格式和表单通过submit() 方法传输的数据格式相同
前端文件-Jquery版本:
<form id="form" enctype="multipart/form-data" method="post">
<input type="text" name="desc" placeholder="文件名称"/><br/>
<input type="file" name="file" placeholder="文件"/>
<input type="button" id="submit" value="文件上传"/>
</form>
<script>
$('#submit').click(function () {
//Jquery对象转换为dom对象
var $form = $('#form');
var domForm = $form['0'];
//构建formData对象
var formData = new FormData(domForm);
formData.append('diycontent','我是自定义数据');
//异步上传文件
$.ajax({
url : 'file.php',
type : 'POST',
data : formData,
// 告诉jQuery不要去处理发送的数据
processData : false,
// 告诉jQuery不要去设置Content-Type请求头, jquery 会自动设置为multipart/form-data
contentType : false,
beforeSend:function(){
console.log('开始上传咯');
},
success : function(response) {
console.log(response)
},
error : function(response) {
console.log(response)
}
});
});
</script>前端文件-原生Javacript版本:
<form enctype="multipart/form-data" method="post" onsubmit="return upload()">
<input type="text" name="desc" placeholder="文件名称" /><br />
<input type="file" name="file" placeholder="文件" />
<input type="submit" value="文件上传" />
</form>
<script type="text/javascript">
var upload=function(){
//获取表单对象
form=document.forms[0];
//构建formData对象
formdata=new FormData(form);
formdata.append('diycontent','我是自定义数据');
//Ajax异步上传
var httper=new XMLHttpRequest();
httper.open('POST','file.php');
httper.onload=function(oEvent){
if(httper.status==200){
console.log('success');
console.log(httper.responseText);
}
else{
console.log('error');
}
}
httper.send(formdata);
return false;
}
</script>后端文件-PHP版本:
<?php
//文件上传
if(move_uploaded_file($_FILES['file']['tmp_name'], $_FILES["file"]["name"])){
//记录日志
$str='文件名:'.$_FILES['file']['tmp_name'].'--文件介绍:'.$_POST['desc'].'--Formdata追加的字段值:'.$_POST['diycontent'];
file_put_contents('log/'.time().'.txt',$str);
//让前端控制台输出看
echo $str;
}附件下载:
window.setInterval(method,time)方法本身会返回一个资源句柄,使用clearInterval(Intervalid)方法即可清除定时器<script> var num=0; //每隔1秒再控制台输...
<form action="save.php" method="post" target="nm_iframe"> &nbs...
二期项目中生成的简历二维码是使用canvs生成的,微信浏览器中不能识别二维码,只能扫码。懒的换phpqrcode,于是转canvs。//设置一个url var url = "{yun:}$config.sy_weburl{/yun}/mingli/index....
jQuery 插件——jqueryrotate,它可以实现旋转效果。jqueryrotate 支持所有主流浏览器,包括 IE6。如果提示方法不存在,可能是你的Jquery版本过低或者过高。基本语法:$('#img').rotate(90);//旋转90度其他的参数:参数类型说明默认值...
查看文章前你需要了解以下2点://1.this指向的是windows对象,通过console.log(this)可以查看到对象包含所有的方法和属性//2.全局变量属于this对象的属性通过console.log(this)可以查看到对象包含我们设置的全局变量我们经常在创建相同结构的Js对象会重复的设...
//我们创建每个函数默认都有一个prototype(原型)属性,这个属性是一个对象 //1.我是普通的构造方法,我的属性叫实例属性,我的方法叫实例方法 /* function Box(name,age){ this.name=name; this.age=age; this.run...