多次上传图片

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
        <title></title>
        <script type="text/javascript" src="__PUBLIC__/sima/server/js/rem.js" ></script>
        <script type="text/javascript" src="__PUBLIC__/sima/js/jq/jquery-3.1.1.js"></script>
        <link rel="stylesheet" href="__PUBLIC__/sima/server/css/reset.css" />

<link rel="stylesheet" href="__PUBLIC__/sima/server/css/publick.css" />

<link rel="stylesheet" href="__PUBLIC__/sima/server/iconfont4/iconfont.css" />
        <style>
            body{
                width:100%;
                overflow:hidden;
                background-color:#f4f4f4;
            }
            .container{
                width:92%;
                padding:0 4%;
                background:white;
            }
            .con{
                width:100%;
                min-height:4rem;
                padding-top:1rem;
                line-height:1rem;
                font-size:0.65rem;
                color:black;
                outline: none;
            }
            .con:empty:before{
                    content:attr(placeholder);
                    font-size: 14px;
                    color: #b0b0b0;
                }
                .con:focus{
                    content:none;
                }

ul{
                width:96%;
                overflow:hidden;
                display: flex;
                flex-wrap: wrap;
                margin-right:0.5rem;
                margin-top:0.8rem;
            }
            ul li{
                margin-right:1.3rem;
                margin-bottom:0.8rem;
                position:relative;
            }
            ul li:nth-child(3n){
                margin-right:0rem;
            }
            ul li p{
                width:3.4rem;
                height:3.4rem;
                color:#d6d6d6;
                font-size:3rem;
                border:0.15rem solid #d6d6d6;
                text-align:center;
            }
            ul li input{
                width:3.4rem;
                height:3.4rem;
                position:absolute;
                left:0;
                top:0;
                opacity: 0;
            }

.wz{
                width:100%;
                height:1.65rem;
                display:flex;
                align-items: center;
                font-size:0.7rem;
                border-top:1px solid #f4f4f4;
            }
            .wz p:nth-child(2){
                flex:1;
                text-align: right;
            }
            .wz .iconfont:nth-child(1){
                font-size:0.9rem;
                margin-right:0.3rem;
                color:#909090;
            }
            .wz .iconfont:nth-child(2){
                font-size:0.6rem;
                color:#c2c2c2;
            }
            .tj{
                width:22%;
                height:1.5rem;
                text-align:center;
                line-height:1.5rem;
                border-radius: 0.2rem;
                font-size:0.8rem;
                font-weight:bold;
                color:white;
                background-color:#fe773e;
                position:absolute;
                left:39%;
                bottom:2rem;
            }
            ul .pic{
        width: 100%;
        display: flex;
      }
      .pic li{
        margin:0px;
        padding:1px;
      }
      .pic li, .pic li img{
        width: 3.425rem;
        height: 3.425rem;
      }

.z_photo img {
          width: 1rem;
          height: 1rem;
      }
      /*遮罩层*/

.z_mask {
          width: 100%;
          height: 100%;
          background: rgba(0, 0, 0, .5);
          position: fixed;
          top: 0;
          left: 0;
          z-index: 999;
          display: none;
      }

.z_alert {
          width: 8.5rem;
          height: 5.5rem;
          border-radius: .5rem;
          background: #fff;
          font-size: .6rem;
          text-align: center;
          position: absolute;
          left: 50%;
          top: 50%;
          margin-left: -4.5rem;
          margin-top: -2rem;
      }

.z_alert p:nth-child(1) {
          line-height: 3.9rem;
      }

.z_alert p:nth-child(2) span {
          display: inline-block;
          width: 49%;
          height: .5rem;
          line-height: 1.3rem;
          float: left;
          border-top: 1px solid #ddd;
      }

.z_cancel {
          border-right: 1px solid #ddd;
      }
            textarea{
                width:100%;
                height:3rem;
                border:0px solid #bebebe;

border-radius: 0.2rem;
                line-height:1rem;
                resize : none;
                font-size:0.65rem;
                color:black;
                outline-color: #bebebe;

width:100%;
                min-height:4rem;
                padding-top:1rem;
                line-height:1rem;
                font-size:0.65rem;
                color:black;
                outline: none;
            }

</style>
    </head>
    <body>
        <div class="container">
            <form action="__MODULE__/user/cust/upload" enctype="multipart/form-data" method="post" >

<textarea   name="content" placeholder="这一刻的想法!"></textarea>
                <ul class=‘pic z_photo‘ id=‘dd‘>

</ul>
                <ul class="upic">

<li >
                        <p>+</p>
                        <input type="file" num=‘0‘ name="file1"   accept="image/*"  class="imgChange"  />
                    </li>

</ul>
            </form>

<!--遮罩层-->
            <div class="z_mask">
                <!--弹出框-->
                <div class="z_alert">
                    <p>确定要删除这张图片吗?</p>
                    <p>
                        <span class="z_cancel">取消</span>
                        <span class="z_sure">确定</span>
                    </p>
                </div>
            </div>

<div class="wz">
                <p>
                    <span class="iconfont"></span>
                    所在位置
                </p>
                <p class="iconfont"></p>
            </div>
        </div>
        <div class="tj">发表</div>
    </body>
</html>
<script type="text/javascript">
    $(function(){
        $(‘.imgChange‘).change(function(){
            imgChange(‘z_photo‘,‘z_file‘,this);
        });
    });
        //px转换为rem
        (function(doc, win) {
                var docEl = doc.documentElement,
                        resizeEvt = ‘orientationchange‘ in window ? ‘orientationchange‘ : ‘resize‘,
                        recalc = function() {
                                var clientWidth = docEl.clientWidth;
                                if (!clientWidth) return;
                                if (clientWidth >= 640) {
                                    //  docEl.style.fontSize = ‘100px‘;
                                } else {
                                    //  docEl.style.fontSize = 100 * (clientWidth / 640) + ‘px‘;
                                }
                        };

if (!doc.addEventListener) return;
                win.addEventListener(resizeEvt, recalc, false);
                doc.addEventListener(‘DOMContentLoaded‘, recalc, false);
        })(document, window);

function imgChange(obj1, obj2,obj3) {
            var num = 0;
            //alert($(obj3).attr(‘name‘));
                //获取点击的文本框
                var file = document.getElementById("file");
                var file = $(obj3)[0];

//存放图片的父级元素
                var imgContainer = document.getElementsByClassName(obj1)[0];
                //获取的图片文件
                var fileList = file.files;
                //文本框的父级元素
                var input = document.getElementsByClassName(obj2)[0];
                var imgArr = [];
                //遍历获取到得图片文件

for (var i = 0; i < fileList.length; i++) {
                    num = $(‘input[type=file]‘).attr(‘num‘);

var imgUrl = window.URL.createObjectURL(file.files[i]);
                        imgArr.push(imgUrl);
                        var img = document.createElement("img");
                        img.setAttribute("src", imgArr[i]);
                        var imgAdd = document.createElement("li");
                        imgAdd.setAttribute("class", "z_addImg");
                        imgAdd.appendChild(img);
                        imgContainer.appendChild(imgAdd);
                        $(‘input[type=file]‘).attr(‘num‘,num*1+1);

};
                //alert(1);
                //点击之后删除p
                var p = $(obj3).prev(‘p‘);
                //克隆一份
                var li = $(‘.upic li‘).eq(0).clone(true);
                //移除
                p.remove();
                var newnum = $(‘input[type=file]‘).attr(‘num‘);
                //alert(newnum);
                //生成一个p
                var str = ‘‘;
                str += "<li>";
                str += "<p>+</p>";
                //str += ‘<input type="file" num=‘0‘ name="file2"  accept="image/*"  />‘;
                str += ‘<input type="file" name="file5"   accept="image/*"  class="imgChange"  />‘;

str += "</li>";
                //alert(li);
                //添加一个
                $(‘.upic‘).prepend(li);
              //改变name

$(‘.upic li‘).eq(0).find(‘input‘).attr(‘name‘,‘file‘+(newnum*1+1));
            //alert();
                //    $(‘.section_my ul‘).prepend(str);
                if(newnum == 9 || newnum >9 )
                {
                    $(‘ul li p‘).css(‘display‘,‘none‘);
                    //clone bug
                    $(‘.upic li‘).first().remove();
                    //return false;
                }
                imgRemove();
        };

function imgRemove() {
                var imgList = document.getElementsByClassName("z_addImg");
                var mask = document.getElementsByClassName("z_mask")[0];
                var cancel = document.getElementsByClassName("z_cancel")[0];
                var sure = document.getElementsByClassName("z_sure")[0];
                for (var j = 0; j < imgList.length; j++) {
                        imgList[j].index = j;
                        imgList[j].onclick = function() {
                                var t = this;
                                mask.style.display = "block";
                                cancel.onclick = function() {
                                        mask.style.display = "none";
                                };
                                sure.onclick = function() {
                                        mask.style.display = "none";
                                        t.style.display = "none";
                                        $(‘ul li p‘).css(‘display‘,‘block‘);
                                };

}
                };
        };

</script>
<script type="text/javascript">
        $(function(){
            $(‘.con‘).blur(function(){
                var text = $(this).html();
                alert(text);
            });
            $(‘.tj‘).click(function(){
                //console.log(‘onl‘);

var content = $(‘textarea‘).val();
                //console.log(content);

var file = $(‘#file‘).val();

if(content == ‘‘ && file == ‘‘)
                {
                alert(‘请填写您要发表的内容或发表图片‘);
                return false;
                }
                //clone bug
                $(‘.upic li‘).first().remove();
                $(‘form‘).submit();
            });
        });
</script>

时间: 2024-10-10 22:26:43

多次上传图片的相关文章

本地上传图片预览

<!DOCTYPE html > <html > <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>图片上传本地预览,获得图片的base64(可压缩)</title> <style type="text/css"> .upload_image {

java web应用用户上传图片的存储地址

原来工程的上传图片存储地址在web应用的目录下,并且是硬编码到其中的: 每次使用maven tomcat:redeploy以后,这个目录就没有了. 现在想要把上传图片的位置移动到tomcat的webapps目录中专门存放图片的一个目录下. 即,新建的一个images目录用来存放web应用的图片们. 这样就把工程和用户上传图片分离了,以后在redeploy时也不用预先备upload目录,然后再拷贝回去,因而在web应该更新时比较方便些.此外,还想改变文件路径被硬编码到java文件中的现状,所以将文

微信JS-SDK实现上传图片功能

最近在项目开放中,有一个在微信WEB项目中上传图片的需求,一开始使用了传统的<input type="file">的方式去实现,但是后面发现在使用这种传统模式时会由于手机系统的差异而导致一系列的问题,后改用微信JSSDK的方式来实现. 总的来说,利用JSSDK来实现该功能一共分为四步. 1. 调用wx.config(),初始化jssdk的配置,并在jsApiList中配置上传图片需要的四个api('chooseImage','previewImage','uploadIma

jquery html5 file 上传图片显示图片

最近做了一个小例子,在上传用户图像时,如何在上传图片时显示图片.在网上找了很多资料也未能如愿,如是,就用jquery ,html5,实现了,由于开发是在linux 所以未能在ie下测试,在forefox,chrom下是可以的. 一.html下的代码是: <div class=' input_box' > <span class='spac' >头</span>相:<input class="input_style" id="'head

jquery实现上传图片及图片大小验证、图片预览效果代码

jquery实现上传图片及图片大小验证.图片预览效果代码 上传图片验证 */ function submit_upload_picture(){     var file = $('file_c').value;     if(!/.(gif|jpg|jpeg|png|gif|jpg|png)$/.test(file)){            alert("图片类型必须是.gif,jpeg,jpg,png中的一种")        }else{      $('both_form')

检验上传图片大小、尺寸、类型的两种实现方案

做图片上传功能时,我们经常会遇到一个问题就是,就是要对上传的图片进行一个校验,校验的东西包括图片的大小.尺寸(即宽和高)以及图片的类型. 今天我主要介绍两种方式来进行图片的校验,一种是在前端用js校验,另一种是放在服务器端校验.接下来我们来进行介绍 第一种:放在前端用js校验 下面直接贴源代码,注释也写在代码里面 1 <%@ page language="java" contenttype="text/html; charset=UTF-8" pageenco

js 上传图片本地预览缓存

<!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>文件上传</title> <script src="jQuery.js"></script> <style type="text/css"> #file{ display: block; width: 400px; heigh

vue-update-表单形式复写方法上传图片

handleSave() { const formData = new FormData(); /* eslint-disable */ for (let key in this.dataInfo) { if (Object.prototype.hasOwnProperty.call(this.dataInfo, key)) { formData.append(key, this.dataInfo[key]); } } let para = { headers: {'content-type':

angularJS file-up-load上传图片

<div class="form-group">                            <label class="col-xs-2 control-label col-xs-offset-1">系统图片</label>                            <div class="col-xs-7">                                 

php 上传图片

public function Upload_上传图片() { $path = '/Upload/HuaHua/'.date("Ymd"); Lee::mkFolder($_SESSION["APP_ROOT"].$path); $img = $_REQUEST['question_pic']; $img = str_replace('data:image/jpeg;base64,', '', $img); $img = str_replace(' ', '+',