Tengo un elemento div que contiene un elemento ul que comienza vacío cuando la página se carga por primera vez. El usuario puede arrastrar elementos li en este cuadro div que poblará el elemento ul. Necesito poder retener los elementos li que se han agregado al contenedor ul para que pueda mostrar los elementos li después de una publicación posterior. ¿Cómo puedo conseguir esto?guardar cambios html del cliente
<div class="sidebar-drop-box">
<p class="dropTitle"><strong>Drop Box</strong><br />
Drag and drop tracks here temporarily if you’re working with a long playlist.</p>
<ul class="admin-song-list"></ul>
</div>
arrastrar y soltar se hace con javascript y jquery. Todo esto se encuentra en una página asp.net. cuando se ha completado el arrastre este es el código que se ejecuta
function AddToDropBox(obj) {
$(obj).children(".handle").animate({ width: "20px" }).children("strong").fadeOut();
$(obj).children("span:not(.track,.play,.handle,:has(.btn-edit))").fadeOut('fast');
$(obj).children(".play").css("margin-right", "8px");
$(obj).css({ "opacity": "0.0", "width": "284px" }).animate({ opacity: "1.0" });
if ($(".sidebar-drop-box ul").children(".admin-song").length > 0) {
$(".dropTitle").fadeOut("fast");
$(".sidebar-drop-box ul.admin-song-list").css("min-height", "0");
}
if (typeof SetLinks == 'function') {
SetLinks();
}
así que intenté el código de abajo para ir a través y obtener todos los elementos que se supone que debe estar en el cuadro desplegable y ponerlos de nuevo. pero que aún no ha añadirlos al cuadro desplegable que realizó los cambios en la lista maestra
//repopulate drop box
if(document.getElementById("ctl00_cphBody_hfRemoveMedia").value!="")
{
var localRemoveMedias=document.getElementById("ctl00_cphBody_hfRemoveMedia").value.split(",");
$(".admin-left li.admin-song").each(function(){
// alert("inEach");//WORKS
for(x in localRemoveMedias)
{
if($(this).attr("mediaid")==localRemoveMedias[x])
{
AddToDropBox($(this));
}
}//end for
});//function(){
}
Es posible que desee proporcionar más información sobre el marco en particular que está utilizando para realizar la operación de arrastrar/soltar. Cada una de esas herramientas tiene diferentes formas de lograr lo que quieres. – NotMe
¿No haría una solicitud de AJAX al servidor cuando el lanzamiento se realiza en el lado del cliente para almacenar el estado que le da la capacidad de hacer lo que quiere? Podría estar confundido No estoy seguro de dónde está haciendo la devolución de datos la actualización al servidor ... – gbvb
¿Intentó enviar la propiedad '.innerHtml' de su control como cadena al servidor? Tal vez también esa configuración 'runat = server' en su control, puede obtener automáticamente el contenido actualizado al enviar toda la página. – BertuPG