上傳圖片做些事情是這樣插件,我這樣做通過ajax上傳圖片,文件上傳後uploadAllComlete函數設置圖片tage src到文件通過上傳存儲在服務器上的URL,你完成:
<input type="file" name="fileUpload" value="" id="fileInput1" />
<p><a href="javascript:$('#fileInput1').uploadifyUpload();">Upload Files</a></p>
這裏是JavaScript函數:
<script type="text/javascript">
$("#fileInput1").uploadify({
'uploader': '@Url.Content("~/Scripts/jquery.uploadify-v2.1.4/uploadify.swf")',
'script': '@Url.Content("~/Resource/Upload")',
'auto': false,
'multi': false,
'expressInstall': '@Url.Content("~/Scripts/jquery.uploadify-v2.1.4/expressInstall.swf")',
'cancelImg': '@Url.Content("~/Scripts/jquery.uploadify-v2.1.4/cancel.png")',
'scriptAccess': 'always',
'hideButton': false,
'fileTypeDesc': 'Image Files',
'fileTypeExts': ' *.jpg; *.png',
'fileDataName': 'uploadedFile',
'sizeLimit': 1000000000,
'onError': function (event, ID, fileObj, errorObj) {
$('#UploadedPicture').val('');
$('#uploadedImage').attr('src', '');
$('#uploadedImage').hide();
//alert("name: " + fileObj.name + " error type: " + errorObj.type + ", info: " + errorObj.info);
},
'onAllComplete': function (event, data) {
//alert("allcomplete => " + data.filesUploaded + ":" + data.errors + ":" + data.allBytesLoaded + ":" + data.speed);
},
'onCheck': function() {
//alert("oncheck");
},
'onComplete': function (event, id, fileObj, response, data) {
//alert("oncomplete => " + ":" + fileObj.name + ":" + fileObj.filePath + ":" + fileObj.size + ":" + response);
$('#fileInput2').val(fileObj.name);
$('#uploadedImage').attr('src', '/uploads/' + fileObj.name);
},
'onOpen': function (event, id, fileObj) {
//alert("onopen => " + ":" + fileObj.name + ":" + fileObj.filePath + ":" + fileObj.size);
var temp = fileObj.name.split('(');
var filename = $.trim(temp[0]);
$('#UploadedPicture').val('~/uploads/' + filename);
$('#uploadedImage').attr('src', '/uploads/' + filename);
$('#uploadedImage').show();
},
'onProgress': function (event, id, fileObj, data) {
//alert("onprogress => " + ":" + fileObj.name + ":" + fileObj.filePath + ":" + fileObj.size + ":" + data.percentage + ":" + data.bytesLoaded + ":" + data.allBytesLoaded + ":" + data.speed);
},
'onUploadSuccess': function (file, data, response) { alert('test'); $('#fileInput2').val(file.name); },
'onUploadComplete': function (file) {
//alert('The file ' + file.name + ' finished processing.');
},
'onCancel': function (file) {
$('#UploadedPicture').val('');
$('#uploadedImage').attr('src', '');
$('#uploadedImage').hide();
}
});
</script>
這裏是哪個文件張貼了我的服務器端功能:
public ActionResult Upload(HttpPostedFileBase uploadedFile)
{
if (uploadedFile.ContentLength == 0) return new EmptyResult();
string[] temp = uploadedFile.FileName.Split('(');
string FileName = temp[0].Trim();
string savedFileName = Path.Combine(HttpContext.Server.MapPath("~/Uploads"), uploadedFile.FileName);
uploadedFile.SaveAs(savedFileName);
return new EmptyResult();
}
你正在做錯誤的文件沒有張貼在通過AJAX的形式,,你需要將它張貼在正常形式 –
使用jQuery的uploadify,你將能夠完成您的需要, –
我可以在html 4中實現jquery uploadify嗎? – Athi