zoukankan      html  css  js  c++  java
  • 图片上传组件webuploader

    前端组件webuploader

    当时也是搞了很久参考这种demo,但是没记、现在事后大致总结下。直接上大概代码(我使用asp.net  MVC来做的):

    执行顺序:(get)Record/Add——Add.cshtml页面,点击确认上传执行上传图片,可多选——(post)Photo/UploadPhotos,完成图片上传。多图分别执行post接口上传、1张图失败可能不会有提示;返回图片url保存在页面的隐藏字段内——(post)Record/Add保存整个实体信息,图片url解析(用|或;)保存

     1    public ActionResult Add()
     2         {
     3             return View();
     4         }
     5 
     6         [HttpPost]
     7         public JsonResult Add(string key1, string key2, string photoUrlSplits, int typeId = 1, string remark = "")
     8         {
     9             if (key1.IsNullOrWhiteSpace() || photoUrlSplits.IsNullOrWhiteSpace() || photoUrlSplits.Length < 3)
    10                 return Json(new BaseResponse(ApiCodeEnum.ParamError.GetHashCode(), "参数错误"));
    11 
    12             var photoUrls = photoUrlSplits.Trim(';').Split(';').ToList();
    13             _service.SaveRecord(CurrentUser, key1, key2, photoUrls, typeId, remark);
    14             return Json(new BaseResponse());
    15         }
    View Code
     1 public class PhotoController : BaseControllerWithUser
     2     {
     3         private readonly PhotoService _service = new PhotoService();
     4         
     5         static string urlPath = string.Empty;
     6 
     7         public PhotoController() 
     8         {
     9             var applicationPath = VirtualPathUtility.ToAbsolute("~") == "/" ? "" : VirtualPathUtility.ToAbsolute("~");
    10             urlPath = applicationPath + "/Upload";
    11         }
    12 
    13         public JsonResult UploadPhotos(string id, string name, string type, string lastModifiedDate, int size, HttpPostedFileBase file)
    14         {
    15             string filePathName = string.Empty;
    16 
    17             string localPath = Path.Combine(HttpRuntime.AppDomainAppPath, "Upload");
    18             if (Request.Files.Count == 0)
    19             {
    20                 return Json(new { jsonrpc = 2.0, error = new { code = 102, message = "保存失败" }, id = "id" });
    21             }
    22 
    23             string ex = Path.GetExtension(file.FileName);
    24             filePathName = Guid.NewGuid().ToString("N") + ex;
    25             if (!System.IO.Directory.Exists(localPath))
    26             {
    27                 System.IO.Directory.CreateDirectory(localPath);
    28             }
    29             file.SaveAs(Path.Combine(localPath, filePathName));
    30 
    31             return Json(new
    32             {
    33                 jsonrpc = "2.0",
    34                 id = id,
    35                 filePath = urlPath + "/" + filePathName
    36             });
    37 
    38             //_service.UploadPhotos();
    39             //return Json("");
    40         }
    41 
    42     }
    View Code

    前端页面代码:

      1 @using OuymxPhotoRecordSystem.Web.Service
      2 @{
      3     Layout = null;
      4 }
      5 
      6 <!DOCTYPE html>
      7 <html>
      8 <head>
      9     <meta name="viewport" content="width=device-width" />
     10     <title>上传图片数据</title>
     11     @*<script src="../../js/plugins/jQuery/jquery-2.2.3.min.js"></script>*@
     12     <script src="/Scripts/jquery-1.8.2.min.js"></script>
     13     <link href="/CSS/webuploader.css" rel="stylesheet" />
     14     <script src="/Scripts/webuploader.js"></script>
     15     <link href="/CSS/bootstrap.min.css" rel="stylesheet" />
     16     <link href="/CSS/style.css" rel="stylesheet" />
     17     <link href="/CSS/demo.css" rel="stylesheet" />
     18     <link href="/CSS/font-awesome.css" rel="stylesheet" />
     19 
     20     <script src="/js/plugins/layer/layer.js"></script>
     21 </head>
     22 <body>
     23     @using (Html.BeginForm("Add", "Record", FormMethod.Post))
     24     {
     25     <table class="tc_table_cp" border="0">
     26         <tr>
     27             <td width="104">图片上传</td>
     28             <td colspan="3">
     29                 <div id="fileList">
     30                     
     31                 </div>
     32                 <div class="cp_img_jia" id="filePicker"></div>
     33                 <input id="photoUrlSplits" name="photoUrlSplits" type="hidden" value="" />
     34                 <button id="ctlBtn" class="btn btn-default">开始上传</button>
     35             </td>
     36         </tr>
     37         @*空的行,主要为了显示上传失败的文字提醒*@
     38         <tr>
     39             <td width="104"></td>
     40             <td colspan="3">
     41             </td>
     42         </tr>
     43         @*上传按钮和隐藏控件移到前面去了*@
     44         @*<tr>
     45             <td width="104"></td>
     46             <td colspan="3">
     47                 <input id="photoUrlSplits" name="photoUrlSplits" type="hidden" value="" />
     48                 <button id="ctlBtn" class="btn btn-default">开始上传</button>
     49             </td>
     50         </tr>*@
     51         <tr>
     52             <td>主键1</td>
     53             <td>@Html.TextBox("key1")</td>
     54         </tr>
     55         <tr>
     56             <td>主键2</td>
     57             <td>@Html.TextBox("key2")</td>
     58         </tr>
     59         <tr>
     60             <td>类型</td>
     61             <td>@Html.DropDownList("typeId", WebMvcHelper.GetPhotoTypes())</td>
     62         </tr>
     63         <tr>
     64             <td>备注</td>
     65             <td>@Html.TextBox("remark")</td>
     66         </tr>
     67         <tr>
     68             <td></td>
     69             <td>
     70                 <input id="btnSubmit" type="submit" style=" 120px;" value="提交保存" disabled="disabled" title="先上传图片后才能提交保存"/>
     71             </td>
     72         </tr>
     73     </table>
     74     }
     75 </body>
     76 </html>
     77 
     78 <script type="text/javascript">
     79 
     80     $("#btnSubmit").click(function (event) {
     81         event.preventDefault();
     82 
     83         var photoUrlSplits = $('#photoUrlSplits').val();
     84         var key1 = $('#key1').val();
     85         if (photoUrlSplits == null || photoUrlSplits.length <= 3 || key1 == null || key1 == '') {
     86             layer.msg('保存失败,原因:主键不得为空,待上传图片不得为空', { icon: 2, time: 0, closeBtn: 1 }, function () {
     87                 //no-op
     88             });
     89             return;
     90         }
     91         $.ajax({
     92             type: 'POST',
     93             url: '@Url.Action("Add")',
     94             data: { 'photoUrlSplits': photoUrlSplits, 'key1': key1, 'key2': $('#key2').val(), 'typeId': $("#typeId").val(), 'remark': $('#remark').val(), },
     95                 success: function (data) {
     96                     if (data.code == 0) {
     97                         layer.msg('保存成功', { icon: 1, time: 1000 }, function () {
     98                             parent.layer.closeAll();    //成功则关闭自身layer
     99                             //window.parent.location.reload();  //无需执行,因为Index父页面已定义关闭本layer时自动执行
    100                         });
    101                     }
    102                     else {
    103                         layer.msg('保存失败,原因:' + data.message, { icon: 2, time: 0, closeBtn: 1 }, function () {
    104                             //no-op
    105                         });
    106                     }
    107                 },
    108                 dataType: 'json'
    109          });
    110     });
    111 
    112     var applicationPath = window.applicationPath === "" ? "" : window.applicationPath || "../../";
    113     $(function () {
    114         var $ = jQuery,
    115         $list = $('#fileList'),
    116         // 优化retina, 在retina下这个值是2
    117         ratio = window.devicePixelRatio || 1,
    118         // 缩略图大小
    119         thumbnailWidth = 90 * ratio,
    120         thumbnailHeight = 90 * ratio,
    121         // Web Uploader实例
    122         uploader;
    123         uploader = WebUploader.create({
    124             // 选完文件后,是否自动上传。
    125             auto: false,
    126             disableGlobalDnd: true,
    127             // swf文件路径
    128             swf: applicationPath + '/Script/Uploader.swf',
    129             // 文件接收服务端。
    130             server: applicationPath + '/Photo/UploadPhotos',
    131             // 选择文件的按钮。可选。
    132             // 内部根据当前运行是创建,可能是input元素,也可能是flash.
    133             pick: '#filePicker',
    134             //只允许选择图片
    135             accept: {
    136                 title: 'Images',
    137                 extensions: 'gif,jpg,jpeg,bmp,png',
    138                 mimeTypes: 'image/jpg,image/jpeg,image/png,image/bmp'
    139             }
    140         });
    141        
    142         // 当有文件添加进来的时候
    143         uploader.on('fileQueued', function (file) {
    144             var $li = $(
    145                     '<div id="' + file.id + '" class="cp_img">' +
    146                         '<img>' +
    147                     '<div class="cp_img_jian"></div></div>'
    148                     ),
    149                 $img = $li.find('img');
    150             // $list为容器jQuery实例
    151             $list.append($li);
    152             // 创建缩略图
    153             // 如果为非图片文件,可以不用调用此方法。
    154             // thumbnailWidth x thumbnailHeight 为 100 x 100
    155             uploader.makeThumb(file, function (error, src) {
    156                 if (error) {
    157                     $img.replaceWith('<span>不能预览</span>');
    158                     return;
    159                 }
    160 
    161                 $img.attr('src', src);
    162             }, thumbnailWidth, thumbnailHeight);
    163         });
    164 
    165         // 文件上传过程中创建进度条实时显示。
    166         uploader.on('uploadProgress', function (file, percentage) {
    167             var $li = $('#' + file.id),
    168                 $percent = $li.find('.progress span');
    169 
    170             // 避免重复创建
    171             if (!$percent.length) {
    172                 $percent = $('<p class="progress"><span></span></p>')
    173                         .appendTo($li)
    174                         .find('span');
    175             }
    176 
    177             $percent.css('width', percentage * 100 + '%');
    178         });
    179 
    180         // 文件上传成功,给item添加成功class, 用样式标记上传成功。
    181         uploader.on('uploadSuccess', function (file, response) {
    182             $('#' + file.id).addClass('upload-state-done');
    183             $("#photoUrlSplits").val($("#photoUrlSplits").val() + response.filePath + ";");//"/Upload/9bd17b72a61043cf857fb112df3c3cf1.png"
    184             //alert("uploadSuccess");
    185         });
    186 
    187         // 文件上传失败,显示上传出错。
    188         uploader.on('uploadError', function (file) {
    189             var $li = $('#' + file.id),
    190                 $error = $li.find('div.error');
    191 
    192             // 避免重复创建
    193             if (!$error.length) {
    194                 $error = $('<div class="error"></div>').appendTo($li);
    195             }
    196             $error.text('上传失败');
    197         });
    198 
    199         // 完成上传完了,成功或者失败,先删除进度条。
    200         uploader.on('uploadComplete', function (file) {
    201             $('#' + file.id).find('.progress').remove();
    202             //alert("uploadComplete");
    203         });
    204 
    205         //所有文件上传完毕
    206         uploader.on("uploadFinished", function ()
    207         {
    208            //提交表单
    209             //alert("uploadFinished");
    210             
    211             if ($("div.error").length > 0) {
    212                 $("#btnSubmit").attr("disabled");
    213                 //alert("部分文件上传失败,可能是文件过大或文件格式不正确。请排查或咨询管理员!");
    214                 layer.msg("部分文件上传失败,可能是文件过大或文件格式不正确。请排查或咨询管理员!", { icon: 2, time: 0, closeBtn: 1 });
    215             }
    216             else {
    217                 $("#btnSubmit").removeAttr("disabled");
    218                 //alert("所有文件上传完毕,请检查是否有错误,若全部正确请提交");
    219 
    220                 layer.msg("所有文件上传完毕,请检查是否有错误,若全部正确请提交!", { icon: 1, time: 4000, closeBtn: 1 });
    221             }
    222         });
    223 
    224         //开始上传
    225         $("#ctlBtn").click(function () {
    226             uploader.upload();
    227 
    228             event.preventDefault();
    229         });
    230         //以下方法原计划实现:鼠标移上去显示删除按钮,移出则不显示。原demo的live代码可实现、但live在jq1.9已被删除、新的on()做不到对未来元素、指定某未来元素的控制。而本AdminLTEd需要需要jq2.2
    231         //
    232         //1.
    233         //$(document).on("mouseover", ".cp_img_jian", function () {
    234         //    //此处的$(this)指$( "#testDiv"),而非$(document) 
    235         //    $(this).show();
    236         //});
    237 
    238         //2.
    239         //$(document).on("mouseout", ".cp_img_jian", function () {
    240         //    //此处的$(this)指$( "#testDiv"),而非$(document) 
    241         //    $(this).hide();
    242         //});
    243 
    244         //3.
    245         //$('#fileList').on('mouseover', function (e) {
    246         //    $('.cp_img_jian').show();
    247         //});
    248         //$('#fileList').on('mouseout', function (e) {
    249         //    $('.cp_img_jian').hide();
    250         //});
    251 
    252         //4.
    253         //$(".cp_img").mouseover(function () {
    254         //    alert("mouseover");
    255         //});
    256         //$(".cp_img").mouseout(function () {
    257         //    alert("mouseout");
    258         //});
    259 
    260         //5.
    261         //显示删除按钮
    262         $(".cp_img").live("mouseover", function ()
    263         {
    264             $(this).children(".cp_img_jian").css('display', 'block');
    265         });
    266         //隐藏删除按钮
    267         $(".cp_img").live("mouseout", function () {
    268             $(this).children(".cp_img_jian").css('display', 'none');
    269         });
    270         //执行删除方法
    271         $list.on("click", ".cp_img_jian", function ()
    272         {
    273             var Id = $(this).parent().attr("id");
    274             uploader.removeFile(uploader.getFile(Id,true));
    275             $(this).parent().remove();
    276         });
    277       
    278     });
    279 
    280 </script>
    View Code

    效果图:

    不足(都不是大问题):

    1.图片是单个单个上传的、没有分片,可能会速度慢

    2.单个图片失败可能会没有提示

    3.仅在点击“上传图片”后可定点删除图片,不能在点击“上传图片”前删除。不过这个不是重点问题不大

  • 相关阅读:
    【VUE】自定义组件
    【docker】Dockerfile
    【docker】常用命令
    【Java Web开发学习】跨域请求
    xshell6和xftp6运行提示缺少mfc110u.dll文件的解决办法
    【NPM】使用问题记录
    【Zuul】使用学习
    第八章 泛型程序设计
    第九章 集合
    分布式系列二: 分布式系统的通信
  • 原文地址:https://www.cnblogs.com/nlh774/p/10142746.html
Copyright © 2011-2022 走看看