本文实例讲述了tp5框架实现一次选择多张图片并预览的方法。分享给大家供大家参考,具体如下:

点击选择图片(可选多张),确定后将选择的图片显示在页面上,已经选择的图片也可以删除,点击提交将图片提交给后台。

1、效果图

2、code

用input标签并选择type=file,记得带上multiple,不然就只能单选图片了

如果不想通过 ajax 提交,一定要加上文件传输协议 ( enctype=”multipart/form-data” )

view

<!doctype html>
<html>
<head>
  <meta charset="utf-8">
  <title>showimages</title>
  <style type="text/css">
    .float{
      float:left;
      width : 200px;
      height: 200px;
      overflow: hidden;
      border: 1px solid #cccccc;
      border-radius: 10px;
      padding: 5px;
      margin: 5px;
    }
    img{
      position: relative;
    }
    .result{
      width: 200px;
      height: 200px;
      text-align: center;
      box-sizing: border-box;
    }
    #file_input{
      display: none;
    }
    .delete{
      width: 200px;
      height:200px;
      position: absolute;
      text-align: center;
      line-height: 200px;
      z-index: 10;
      font-size: 30px;
      background-color: rgba(255,255,255,0.8);
      color: #777;
      opacity: 0;
      transition-duration: :0.7s;
      -webkit-transition-duration: 0.7s;
    }
    .delete:hover{
      cursor: pointer;
      opacity: 1;
    }
  </style>
  <script src="http://libs.baidu.com/jquery/2.0.0/jquery.min.js"></script>
  <script type="text/javascript">
    window.onload = function(){
      var input = document.getelementbyid("file_input");
      var result;
      var dataarr = []; // 储存所选图片的结果(文件名和base64数据)
      var fd; //formdata方式发送请求
      var oselect = document.getelementbyid("select");
      var oadd = document.getelementbyid("add");
      var osubmit = document.getelementbyid("submit");
      var oinput = document.getelementbyid("file_input");

      if(typeof filereader==='undefined'){
        alert("抱歉,你的浏览器不支持 filereader");
        input.setattribute('disabled','disabled');
      }else{
        input.addeventlistener('change',readfile,false);
      }     //handler

      function readfile(){
        fd = new formdata();
        var ilen = this.files.length;
        var index = 0;
        for(var i=0;i<ilen;i++){
          if (!input['value'].match(/.jpg|.gif|.png|.jpeg|.bmp/i)){  //判断上传文件格式
            return alert("上传的图片格式不正确,请重新选择");
          }
          var reader = new filereader();
          reader.index = i;
          fd.append(i,this.files[i]);
          reader.readasdataurl(this.files[i]); //转成base64
          reader.filename = this.files[i].name;

          reader.onload = function(e){
            var imgmsg = {
              name : this.filename,//获取文件名
              base64 : this.result  //reader.readasdataurl方法执行完后,base64数据储存在reader.result里
            }
            dataarr.push(imgmsg);
            result = '<div class="delete">delete</div><div class="result"><img src="'+this.result+'" alt=""/></div>';
            var div = document.createelement('div');
            div.innerhtml = result;
            div['classname'] = 'float';
            div['index'] = index;
            document.getelementsbytagname('body')[0].appendchild(div);   //插入dom树
            var img = div.getelementsbytagname('img')[0];
            img.onload = function(){
              var nowheight = resizepic(this); //设置图片大小
              this.parentnode.style.display = 'block';
              var oparent = this.parentnode;
              if(nowheight){
                oparent.style.paddingtop = (oparent.offsetheight - nowheight)/2 + 'px';
              }
            }

            div.onclick = function(){
              this.remove();         // 在页面中删除该图片元素
              delete dataarr[this.index]; // 删除dataarr对应的数据

            }
            index++;
          }
        }
      }

      function send(){
        var submitarr = [];
        for (var i = 0; i < dataarr.length; i++) {
          if (dataarr[i]) {
            submitarr.push(dataarr[i]);
          }
        }
        // console.log('提交的数据:'+json.stringify(submitarr))
        $.ajax({
          url : 'http://39.106.182.218',
          type : 'post',
          data : json.stringify(submitarr),
          datatype: 'json',
          //processdata: false,  用formdata传fd时需有这两项
          //contenttype: false,
          success : function(data){
            console.log('返回的数据:'+json.stringify(data))
          }

        })
      }

      oselect.οnclick=function(){
        oinput.value = "";  // 先将oinput值清空,否则选择图片与上次相同时change事件不会触发
        //清空已选图片
        $('.float').remove();
        dataarr = [];
        index = 0;
        oinput.click();
      }

      oadd.οnclick=function(){
        oinput.value = "";  // 先将oinput值清空,否则选择图片与上次相同时change事件不会触发
        oinput.click();
      }

      osubmit.οnclick=function(){
        if(!dataarr.length){
          return alert('请先选择文件');
        }
        send();
      }
    }
    /*
     用ajax发送fd参数时要告诉jquery不要去处理发送的数据,
     不要去设置content-type请求头才可以发送成功,否则会报“illegal invocation”的错误,
     也就是非法调用,所以要加上“processdata: false,contenttype: false,”
     * */

    function resizepic(thispic) {
      var repicwidth = 200; //这里修改为您想显示的宽度值

      var truewidth = thispic.width; //图片实际宽度
      var trueheight = thispic.height; //图片实际高度

      if(truewidth>trueheight){
        //宽大于高
        var rewidth = repicwidth;
        thispic.width = rewidth;
        //垂直居中
        var nowheight = trueheight * (rewidth/truewidth);
        return nowheight; //将图片修改后的高度返回,供垂直居中用
      }else{
        //宽小于高
        var reheight = repicwidth;
        thispic.height = reheight;
      }
    }
  </script>
</head>
<body>
<div class="container">
  <label>请选择一个图像文件:</label>
  <button id="select">(重新)选择图片</button>
  <button id="add">(追加)图片</button>

<form action="" method="post" enctype="multipart/form-data">
  <input type="file" id="file_input" name="image[]" multiple/>
  <!--用input标签并选择type=file,记得带上multiple,不然就只能单选图片了-->
  <button id="submit">提交</button>
</form>

</div>
</body>
</html>

controller

$image=request()->file('image');
print_r($image);

3、over!!!