ASP.NET MVC2 項目經驗錯雜談

咱們在作項目的時候常常會遇到傳附件的問題,一是若是附件不符合格式要求,咱們要清空input file。二是點擊附件超連接的時候若是附件不在,應該提示附件不存在。下來咱們就看看怎麼實現。先看一個控制器javascript

  
  
  
  
  1. /// <summary> 
  2.        /// 檢查文件是否存在 
  3.        /// </summary> 
  4.        /// <param name="id"></param> 
  5.        /// <returns></returns> 
  6.        public JsonResult CheckFileExist(string id) 
  7.        { 
  8.            Appurtenances appurtenances = messageEntities.appurtenances.FirstOrDefault(app => app.serial == id); 
  9.            string fileName = appurtenances.file_name; 
  10.            string filePath = Server.MapPath(appurtenances.file_path); 
  11.            if (!System.IO.File.Exists(filePath)) 
  12.            { 
  13.                strJson = "{suc:0,msg:'文件不存在'}"
  14.            } 
  15.            else 
  16.            { 
  17.                strJson = "{suc:1,msg:'文件存在'}"
  18.            } 
  19.            return Json(strJson, JsonRequestBehavior.AllowGet); 
  20.        } 
  
  
  
  
  1. /// <summary> 
  2.        /// 附件下載 
  3.        /// </summary> 
  4.        /// <param name="id"></param> 
  5.        /// <returns></returns> 
  6.        public ActionResult GetFile(string id) 
  7.        { 
  8.            Appurtenances appurtenances = messageEntities.appurtenances.FirstOrDefault(app => app.serial == id); 
  9.            string fileName = appurtenances.file_name; 
  10.            string filePath = Server.MapPath(appurtenances.file_path); 
  11.            FileStream f = new FileStream(filePath, FileMode.Open); 
  12.            byte[] bytes = new byte[(int)f.Length]; 
  13.            f.Read(bytes, 0, bytes.Length); 
  14.            f.Close(); 
  15.            Response.ContentType = "application/octet-stream"
  16.            Response.AddHeader("Content-Disposition""p_w_upload; filename=" + HttpUtility.UrlEncode(fileName + appurtenances.file_path.Substring(appurtenances.file_path.LastIndexOf(".")), System.Text.Encoding.UTF8)); 
  17.            Response.BinaryWrite(bytes); 
  18.            Response.Flush(); 
  19.            Response.End(); 
  20.            return null
  21.        } 

再看看jsjava

  
  
  
  
  1. function checkFileExist(myId) { 
  2.  
  3.     $.ajax({ 
  4.         url: "/Message/CheckFileExist/" + myId, 
  5.         datatype: "json"// 返回的數據類型 
  6.         type: "post"
  7.         //async:false, 
  8.         success: function (data) { 
  9.             var json = eval("(" + data + ")"); 
  10.             new BaseUtil(json).parsJSONError; 
  11.             if (json.suc == 0) { 
  12.                 jAlert(json.msg, "提示信息"); 
  13.             } else { 
  14.                 $("#downLoadSendMsg" + myId).attr("href""/Message/GetFile/" + myId); 
  15.                 $("#downLoadSendMsg" + myId).removeAttr("onclick"); 
  16.                 if (window.ActiveXObject) {//IE 
  17.                     document.getElementById("downLoadSendMsg" + myId).click(); 
  18.                 } 
  19.             } 
  20.         } 
  21.     }); 
  
  
  
  
  1. function readedMesAddUpdateAppendix(readedMesNum, rowid, readedMesUrl, readAppdName) { 
  2.     var readedMesNum = readedMesNum + 1; 
  3.     var mesupdNewRow = "<tr><td width='430px' height='15px' align='left'>附件" + readedMesNum + ":&nbsp;&nbsp;"
  4.     mesupdNewRow += "<a href='javascript:void(0);' id='downLoadSendMsg" + rowid + "' onclick=checkFileExist('" + rowid + "')>" + readAppdName + "<\/a><\/td><\/tr>"
  5.     jQuery("#readedMesShowAppdTabl").append(mesupdNewRow); 
經過上面的代碼咱們能夠看到,若是附件存在,則能夠被打開或者下載,若是不存在,會提示文件不存在。 那麼對於附件不符合條件,咱們如何清空它呢。看看js
  
  
  
  
  1. function deleteFile(file) { 
  2.     var ie = (navigator.appVersion.indexOf("MSIE") != -1); //IE 
  3.     var ff = (navigator.userAgent.indexOf("Firefox") != -1); //Firefox 
  4.  
  5.     if (ie) 
  6.         refreshUploader($("input[name=" + file + "]")[0]); 
  7.     else 
  8.         $("input[name=" + file + "]").attr("value"""); 
  9.  
  10. function refreshUploader(file) { 
  11.     var file2 = file.cloneNode(false); 
  12.     file2.onchange = file.onchange; 
  13.     file.parentNode.replaceChild(file2, file); 

調用的時候僅須要傳一個input file的name值便可。ajax

最後來個實惠的,把sql轉化爲linqsql

  
  
  
  
  1. select sourseware_id,COUNT(*) as num from cours_ewares as a  group by a.sourseware_id having COUNT(*) >1 
  
  
  
  
  1. List<IGrouping<string,EPA_Cours_Ewares>> courseEwaresList = (from ce in examinationPlanArrangementsEntities.cours_ewares 
  2.                                             group ce by ce.sourseware_id into c where c.Count()>1 
  3.                                             select c).ToList(); 

 關於分頁,在寫分頁的時候先獲得IQueryable<T>類型,而後再得到其count(),算出總頁數和總記錄數後,將IQueryable<T>轉化爲List<T>,由於IQueryable不會向數據庫發送sql命令。數據庫

相關文章
相關標籤/搜索