日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

ASP.NET工作笔记之一:图片上传预览及无刷新上传

發(fā)布時間:2025/3/15 asp.net 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ASP.NET工作笔记之一:图片上传预览及无刷新上传 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

轉自:http://www.cnblogs.com/sibiyellow/archive/2012/04/27/jqueryformjs.html

最近項目里面涉及到無刷新上傳圖片的功能,其實也就是上傳一些封面,然后我就想當選擇圖片的時候,右邊出現(xiàn)預覽圖(在沒有上傳到服務器的情況下),當點擊上傳的時候在上傳到服務器(無刷新上傳),所以也就找了些資料,做了下這方面的功能。

??? 折騰著,折騰著,也就折騰出來啦?,F(xiàn)在在這寫個筆記。

??? 首先是預覽功能,使用了cloudgamer的JavaScript 圖片上傳預覽效果,這里也遇到了些問題,就是我會在File控件的后面設置一個按鈕來清空前面File里面的值,并且在預覽圖片的地方顯示默認的圖片(是為了項目里面,當這條記錄有封面時,則顯示他的封面圖片)。

???? JS代碼如下:

//清空File控件的值,并且預覽處顯示默認的圖片function clearFileInput(){var form = document.createElement('form');document.body.appendChild(form);//記住file在舊表單中的的位置var file = document.getElementById("idFile");var pos = file.nextSibling;form.appendChild(file);form.reset();//通過reset來清空File控件的值document.getElementById("colspan").appendChild(file);document.body.removeChild(form);//在預覽處顯示圖片 這是在瀏覽器支持濾鏡的情況使用的document.getElementById("idImg").style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale',src='images/abshiu.jpg'";//這是是火狐里面顯示默認圖片的if (navigator.userAgent.indexOf('Firefox') >= 0) {$("#idImg").attr('src', 'images/abshiu.jpg');}}

???? HTML代碼如下:

<table border="0" class="perview"><tr><th width="45%">選擇文件</th><th width="45%">預覽圖</th><th width="10%">上傳圖片</th></tr><tr><td><span id="colspan"><input id="idFile" runat="server" name="pic" type="file" /></span>&nbsp;&nbsp;&nbsp;&nbsp;<input type="button" id="resets" name="resets" value="還原" οnclick="clearFileInput()" /></td><td align="center"><img id="idImg" src="images/abshiu.jpg" /></td><td><input type="button" name="resets" value="上傳保存圖片" οnclick="upLoadFile()" /></td></tr></table><script>var ip = new ImagePreview($$("idFile"), $$("idImg"), {maxWidth: 200, maxHeight: 200, action: "ImagePreview.ashx"});ip.img.src = ImagePreview.TRANSPARENT;ip.file.onchange = function() { ip.preview(); };</script>

做到這里的話 預覽效果就已經搞定啦,然后就是無刷新上傳,雖然cloudgamer的博客里面有簡便無刷新文件上傳系統(tǒng),但是我沒有采用,而是使用了jquery.form.js來做無刷新上傳效果,代碼如下:

function upLoadFile(){var options = {type: "POST",url: 'Files.ashx',success: showResponse};// 將options傳給ajaxForm$('#myForm').ajaxSubmit(options);}function showResponse(){alert("上傳成功!");}

關于jquery.form.js的API,百度下吧。#myForm就是頁面的form的ID,Files.ashx則負責圖片的上傳處理,Files.ashx的代碼如下:

public class File_WebHandler : IHttpHandler {public void ProcessRequest(HttpContext context){HttpFileCollection files = context.Request.Files;if (files.Count > 0){Random rnd = new Random();for (int i = 0; i < files.Count; i++){HttpPostedFile file = files[i];if (file.ContentLength > 0){string fileName = file.FileName;string extension = Path.GetExtension(fileName);int num = rnd.Next(5000, 10000);string path = "file/" + num.ToString() + extension;file.SaveAs(System.Web.HttpContext.Current.Server.MapPath(path));}}}}public bool IsReusable{get{return false;}}

代碼到這里一個簡單的例子也就完成啦。附上小例子的源碼:

圖片上傳預覽及無刷新上傳

? ?

轉載于:https://www.cnblogs.com/cugwx/p/3801523.html

總結

以上是生活随笔為你收集整理的ASP.NET工作笔记之一:图片上传预览及无刷新上传的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。