- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 jquery 和 Materialize 来执行异步文件上传和表单提交。该代码仅在我使用 get(0).files[0] 时才有效,但仅返回索引 [0] 处的第一个文件,但每当我尝试使用下面的代码循环上传数组中的所有文件时,它都会抛出一个 Uncaught Error 类型错误
script.js:7 Uncaught TypeError: Cannot read property 'type' of undefined
这是我的ajax上传代码==> (script.js)
$(function(){
$('#file').change(function(){
for (i=0; i = $('#file').get(0).files.length; i++){
console.log(this,'this');
console.log($('#file').get(0).files[i]);
var file=this.files[i];
var imagetype=file.type;
var imgtags =['image/jpeg','image/pjpeg',"image/png","image/jpg","image/gif"];
if(imgtags.indexOf(imagetype)>0){
Materialize.toast('File Is an image!', 2000);
var filereader=new FileReader();
filereader.onload=FileLoadCheck;
filereader.readAsDataURL(this.files[i]);
FileUploadAjaxCall();
}else{
Materialize.toast('File Is not an image!', 2000);
$('#previewImage').attr('src','images/images.png');
var filereader=new FileReader();
filereader.onload=FileLoadCheck;
filereader.readAsDataURL(this.files[i]);
FileUploadAjaxCall();
return false;
}
}
});
function FileLoadCheck(e){
console.log(e,'Object');
$('#previewImage').attr('src',e.target.result);
}
});
function FileUploadAjaxCall(){
$.ajax({
url:'fileupload.php?_'+new Date().getTime(),
type:'POST',
data:new FormData($('#UploadMedia').get(0)),
contentType:false,
cache:false,
processData:false,
success:function(data){
console.log(data,'data');
Materialize.toast('File Upload Successfully!', 2000);
}
});
}
这是我的 php 文件,用于将文件移动到服务器上的目录。
<?php
echo "<pre>";
print_r($_FILES);
// die;
$sourcePath = $_FILES['file']['tmp_name'];
$targetPath = "uploads/" . round(microtime(true)) . '.' . end($_FILES['file']['name']);
echo $targetPath;
move_uploaded_file($sourcePath, $targetPath);
echo "<br/><b>File Name:</b> " . $_FILES["file"]["name"] . "<br>";
echo "<b>Type:</b> " . $_FILES["file"]["type"] . "<br>";
echo "<b>Size:</b> " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
echo "<b>Temp file:</b> " . $_FILES["file"]["tmp_name"] . "<br>";
?>
编辑以包含 html 表单来处理上传:
<form method="post" enctype="multipart/form-data" id="UploadMedia">
<div class="container-fluid">
<div class="row">
<div class="col s6 push-s3">
<div class="card card-panel hoverable">
<div class="card-image">
<img src="images/images.png" class="img-responsive" id="previewImage">
<span class="card-title">Image Show Here</span>
</div>
<div class="card-content">
<div class="file-field input-field">
<div class="btn" style="background-color:#757575">
<span>File</span>
<input type="file" name="file" id="file" multiple>
</div>
<div class="file-path-wrapper">
<input class="file-path validate" type="text" placeholder="Upload one or more files">
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</form>
最佳答案
我认为应该是for (i = 0; i < this.files.length; i++){
重点<
.
编辑
$('#file').change(function() {
console.clear();
for (i = 0; i < this.files.length; i++) {
var file = this.files[i];
var imagetype = file.type;
var imgtags = ['image/jpeg', 'image/pjpeg', "image/png", "image/jpg", "image/gif"];
console.log(imagetype);
if (imgtags.indexOf(imagetype) !== -1) {
console.log('File Is an image!');
} else {
console.log('File Is not an image!');
}
}
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="file" name="file" id="file" multiple>
关于javascript - Ajax文件上传仅获取filelist数组中的第一个文件进行上传,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45958537/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!