Actualmente estoy trabajando con las pestañas de jquery ui y ajax/post submit sin actualización de la página. Con un poco de guía he podido enviar el div #wmd-preview
enviado al hacer clic en el siguiente botón. El problema es que también tengo otros campos que me gustaría enviar al mismo tiempo cuando se hace clic en el siguiente botón en varias pestañas.Ajax envíe varios valores de entrada con la interfaz de usuario de jquery, haga clic en el botón siguiente
¿Cómo puedo enviar los valores de entrada de varios campos de entrada en diferentes pestañas al hacer clic en el siguiente botón? EXAMPLE
(para algunas pruebas que actualmente tienen los otros campos de entrada se someten con keyup y configuración del temporizador)
JS-Botón NEXT/Anterior se fusionó con enviar/ajax
<script>
var currentTab = 0;
$(function() {
var $tabs = $('#tabs').tabs({
disabled: [0, 1, 2]
, select: function() {
if (currentTab == 0) {
$.ajax({
type: "POST",
url: "test1.php",
data: { "wmdVal": $("#wmd-preview").html() },
success: function(result) {
$('#wmd_result').html($('#resultval', result).html());
}
});
}
}
, show: function(event, ui) {
currentTab = ui.index;
}
});
$(".ui-tabs-panel").each(function(i) {
var totalSize = $(".ui-tabs-panel").size() - 1;
if (i != totalSize) {
next = i + 2;
$(this).append("<a href='#' class='next-tab mover' rel='" + next + "'>Next Page »</a>");
}
if (i != 0) {
prev = i;
$(this).append("<a href='#' class='prev-tab mover' rel='" + prev + "'>« Prev Page</a>");
}
});
$('.next-tab, .prev-tab').click(function() {
var tabIndex = $(this).attr("rel");
$tabs.tabs('enable', tabIndex)
.tabs('select', tabIndex)
.tabs("option","disabled", [0, 1]);
return false;
});
});
</script>
HTML
<div id="tab-1" class="ui-tabs-panel ui-tabs-hide">
<label for="title">Title</label>
<input type="text" id="title" name="title" size="60" autocomplete="off" value="<? $title ?>"/>
<div id="wmd-editor" class="wmd-panel">
<div id="wmd-button-bar"></div>
<textarea id="wmd-input" name="wmd-input"></textarea>
</div>
<div id="wmd-preview" class="wmd-panel"></div>
<div id="wmd_result"></div>
<div id="title_input"style="padding:20px;"></div>
</div>
<div id="tab-2" class="ui-tabs-panel ui-tabs-hide">
<label for="name">Name</label>
<input type="text" id="name" name="name" size="60" autocomplete="off" value="<? $name ?>"/>
<div id="name_input"></div>
</div>
PHP
<?
if (isset($_POST['title'])){
$wmdVal = $_POST['title'];
echo ('<div id="title_input"><span id="resultval"><h2>Title Echo result:</h2>'.$wmdVal.'</span></div>');
}
if (isset($_POST['wmdVal'])){
$wmdVal = $_POST['wmdVal'];
echo ('<div id="wmd_result"><span id="resultval"><h2>Description Echo result:</h2>'.$wmdVal.'</span></div>');
}
if (isset($_POST['name'])){
$name = $_POST['name'];
echo ('<div id="name_input"><span id="resultval"><h2>Description Echo result:</h2>'.$name.'</span></div>');
}
?>
Supongo que sus pestañas ya están cargadas (si están cargadas por demanda, habrá problemas, obviamente). ¿Está tratando de hacer algo en su propiedad de datos como: datos: {"wmdVal": $ ("# wmd-preview"). html(), 'nameYourField': $ ('# name'). val()}? –
Por favor vuelva a sangrar su código JS – tucuxi