2011-11-09 7 views
7

Próbuję przesłać niektóre obrazy i wyświetlić je wewnątrz pustego DIV, a po przesłaniu, gdy kliknę myszą na obrazie, powinienem otrzymać ikonę usuwania, aby użytkownicy powinien być w stanie usunąć go za pomocą animacji i przenieść następny obraz do pozycji usuniętego obrazu.Jak dołączyć obraz/ikonę usuwania do obrazu wewnątrz div przy użyciu jquery

Jak to osiągnąć?

ten sposób mam przesłać i dołączanie do kontenera div:

<script type="text/javascript"> 
$(function() { 
    document.getElementById('Nextbutton').style.visibility = "hidden"; // show 
    $("#uploader").plupload({ 
     // General settings 
     runtimes: 'gears,flash,silverlight,browserplus,html5', 
     url: 'Test.aspx', 
     max_file_size: '10mb', 
     max_file_count: 20, 
     chunk_size: '1mb', 
     unique_names: true, 

     filters: [ 
      { title: "Image files", extensions: "jpg,gif,png" }, 
      { title: "Zip files", extensions: "zip" } 
     ], 


     flash_swf_url: 'js/plupload.flash.swf', 


     silverlight_xap_url: 'js/plupload.silverlight.xap' 
    }); 



    $('form').submit(function (e) { 
     var uploader = $('#uploader').plupload('getUploader'); 

     if (uploader.files.length > 0) { 

      uploader.bind('StateChanged', function() { 
       if (uploader.files.length === (uploader.total.uploaded + uploader.total.failed)) { 
        $('form')[0].submit(); 
       } 
      }); 

      uploader.start(); 

     } 
     else 
     //alert('You must at least upload one file.'); 

      return false; 
    }); 
    var uploader = $('#uploader').plupload('getUploader'); 

    uploader.bind('FilesAdded', function (up, files) { 
     //    jQuery('#container a').html(''); 
     $('#container > *').remove(); 
     var i = 0; 
     while (i++ < up.files.length) { 
      var ii = i; 
      while (ii < up.files.length) { 
       if (up.files[i - 1].name == up.files[ii].name) { 
        $.msgBox({ 
         title: "Ooops", 
         content: "There is already an image with the same filename and cannot be added.", 
         type: "error", 
         showButtons: true, 
         opacity: 0.9, 
         autoClose: false 
        }); 
        uploader.removeFile(up.files[ii]); 
       } else { 
        ii++; 
       } 
      } 
     } 
     if (i > 20) { 
      $.msgBox({ 
       title: "Info", 
       content: "Uuh! Please don't put me any more files.<br>Maximum Upload limit is only 20 Images.<br>Rest of the Images will be removed.", 
       type: "info", 
       showButtons: true, 
       opacity: 0.9, 
       autoClose: false 
      }); 
      $('#uploader_browse').hide(); 
     } 
    }); 
    uploader.bind('FilesRemoved', function (up, files) { 
     if (up.files.length < 20) { 
      $('#uploader_browse').fadeIn("slow"); 
     } 
    }); 


    uploader.bind('FileUploaded', function (up, file, res) { 
     $('#container').append("<div class='container a'><a href='uploads/" + document.getElementById("currentDirectory").value + "/" + file.name + "' rel='prettyPhoto' target='blank'><img src='uploads/" + document.getElementById("currentDirectory").value + "/" + file.name + "' width='64' height='64'/></a></div>"); 



     var $imageContainers = $('#container a'); 

     $imageContainers.each(function (index) { 
      $(this).delay(index * 50).fadeTo(400, 0.5); 
     }); 

     $imageContainers.mouseover(function() { 
      $(this).css('opacity', 1); 
      $(this).find('span.del').show(); 
     }); 
     $imageContainers.mouseout(function() { 
      $(this).css('opacity', 0.5); 
      $(this).find('span.del').hide(); 
     }); 



     if (uploader.files.length === (uploader.total.uploaded + uploader.total.failed)) { 
      document.getElementById('Nextbutton').style.visibility = "visible"; // show 
      showStickySuccessToast(); 
     } 
     uploader.removeFile(file); 
    }); 

}); 


    function randomString(length) { 
     var chars = 'ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz'.split(''); 

     if (!length) { 
      length = Math.floor(Math.random() * chars.length); 
     } 

     var str = ''; 
     for (var i = 0; i < length; i++) { 
      str += chars[Math.floor(Math.random() * chars.length)]; 
     } 
     return str; 
    } 

    </script> 

Oto mój div gdzie jestem przedstawiający obrazów:

<div id="container"> 
</div> 
+1

Kod ten zawiera błędy składniowe - trzeba zamykający okrągły uchwyt na wezwanie do ' .append' –

+0

Powinieneś również powiedzieć nam, co nie działa. – maxedison

+0

tak po prostu nie umieściłem całego kodu tylko po to, aby wiedzieć, gdzie muszę dodać obraz – coder

Odpowiedz

11

Demo jest dostępne na stronie: http://jsfiddle.net/CWaHL/1/

HTML

<div id="container"> 
    <div class="image" id="image1" style="background-image:url(http://lorempixel.com/100/100/abstract);"> 
    <a href="#" class="delete">Delete</a> 
    </div> 
    <div class="image" id="image2" style="background-image:url(http://lorempixel.com/100/100/food);"> 
    <a href="#" class="delete">Delete</a> 
    </div> 
    <div class="image" id="image3" style="background-image:url(http://lorempixel.com/100/100/people);"> 
    <a href="#" class="delete">Delete</a> 
    </div> 
    <div class="image" id="image4" style="background-image:url(http://lorempixel.com/100/100/technics);"> 
    <a href="#" class="delete">Delete</a> 
    </div> 
</div> 

CSS

#container { overflow:auto; } 
.image { width:100px;height:100px;float:left;position:relative; } 
a.delete { display:none;position:absolute;top:0;right:0;width:30px;height:30px;text-indent:-999px;background:red; } 
.image:hover a.delete { display:block; } 

jQuery/JavaScript

$(document).ready(function(){ 

    $('a.delete').on('click',function(e){ 
    e.preventDefault(); 
    imageID = $(this).closest('.image')[0].id; 
    alert('Now deleting "'+imageID+'"'); 
    $(this).closest('.image') 
     .fadeTo(300,0,function(){ 
     $(this) 
      .animate({width:0},200,function(){ 
      $(this) 
       .remove(); 
      }); 
     }); 
    }); 

}); 
+0

Dzięki Lucanos to jest dokładnie to, czego potrzebuję. – coder

+0

To jest miłe! dzięki – Roylee

+0

Dokładnie to, czego szukałem – Auspex

2

w tym przypadku można ustawić identyfikator jak id, klasy lub nazwy w tagu img lub gdy tag chcesz powiązać zdarzenie mouseover. to skrypt zrobić:

uploader.bind('FileUploaded', function (up, file, res) 
     { 
     $('#container').append("<div class='container a'> 
     <a href='uploads/" + document.getElementById("currentDirectory").value 
     + "/" + file.name + "' rel='prettyPhoto' target='blank'> 
     <img class="img-upload" src='uploads/" + document.getElementById("currentDirectory").value + "/" 
     + file.name + "' width='64' height='64'/> 
     </a> 
     </div>" 
} 
); 

Dodaję class = „img-upload” w tagu img i będzie użycie w następnym step.after tego należy dodać słuchacza do szukania swojej klasie elementu. ponieważ obraz elementu nie jest generowany, gdy przeglądarka wykonuje javascript za pierwszym razem.example w document.ready. element zostanie wygenerowany po przesłaniu obrazu, który nie może spowodować zdarzenia onmouseevent w dokumencie. Ponieważ dom jest niezdefiniowany.

moje rozwiązanie to: 1) dokonać delegata zdarzenia lub na żywo przykład: dodać ten kod w was skrypt

$(".container ").delegate(".img-upload", "mouseover", function() { 
    // show notification delete like icon 
}); 

lub jeśli nie działa, możesz spróbować tej

$(".img-upload").live("mouseover", function(){ alert("get mouse over event"); }); 

i jeśli chcesz używać timeout do wyszukiwania elementu na żywo, czy nie, możesz spróbować tego musisz dodać id in your code tak.

uploader.bind('FileUploaded', function (up, file, res) 
      { 
      $('#container').append("<div class='container a'> 
      <a href='uploads/" + document.getElementById("currentDirectory").value 
      + "/" + file.name + "' rel='prettyPhoto' target='blank'> 
      <img id="img-upload" src='uploads/" + document.getElementById("currentDirectory").value + "/" 
      + file.name + "' width='64' height='64'/> 
      </a> 
      </div>" 
    } 
    ); 


function waitForImg(){ 
var ele = document.getElementById(idImg); 
if(!ele){ 
    window.setTimeout(waitForImg, 100); 
} 
else{ 
    //you can show delete in here 
    $('#img-upload').mouseover(function() { 
    //show image delete 
    alert('show your icon delete'); 
}); 
} 
} 
waitForImg(); 
+0

Dzięki za Twoje sugestie Mohamad :) – coder

+0

serdecznie zapraszamy – viyancs

0

Używam tego kodu i działa bardzo dobrze, po tym masz swoje zdjęcie na dane wejściowe w formularzu i trzeba go odebrać i zapisać. Jeśli masz pytania, daj mi znać.

<div id="preview" class="thumbnail"> 
    <a href="#" id="file-select" class="btn btn-default">Select Photo</a> 
    <img src=""/> 





    <input id="filename" name="filename" type="file" /> 

      </div> 


    <input type="submit" value="Upload Photo" id="file-save" class="btn btn-primary"/> 
    </div> 

to Javascript

<script> 
$('#preview').hover(
    function() { 
     $(this).find('a').fadeIn(); 
    }, function() { 
     $(this).find('a').fadeOut(); 
    } 
) 
$('#file-select').on('click', function(e) { 
    e.preventDefault(); 

    $('#filename').click(); 
}) 

$('input[type=file]').change(function() { 
    var file = (this.files[0].name).toString(); 
    var reader = new FileReader(); 

    $('#file-info').text(''); 
    $('#file-info').text(file); 

    reader.onload = function (e) { 
     $('#preview img').attr('src', e.target.result); 
    } 

    reader.readAsDataURL(this.files[0]); 
}); 
    </script> 

To CSS:

body { 
    width: 300px; 
    margin: 10px auto; 
    text-align:center; 
} 
.thumbnail { 
    width: 120px; 
    margin: 0 auto; 
    margin-bottom: 10px; 
} 
.thumb { 
    width: 120px; 
    margin: 0; 
    margin-bottom: 10px; 


} 
#preview { 
    position: relative; 
} 
#preview a { 
    position: absolute; 
    bottom: 5px; 
    left: 5px; 
    right: 5px; 
    display: none; 
} 
#file-info { 
    text-align: center; 
    display: block; 
} 
input[type=file] { 
    position: absolute; 
    visibility: hidden; 
    width: 0; 
    z-index: -9999; 
} 
#file-save { 
    text-align:center; 
    width: 140px; 
} 
footer { 
    margin: 10px 0; 
} 
Powiązane problemy