Je suis nouveau à Ajax. Je veux soumettre un formulaire via Ajax et enregistrer les données envoyées à la base de données. Quelque chose comme la mise à jour de statut de Facebook - où la zone de texte est désactivée, puis soumise. Une fois enregistré dans la base de données, il revient et met à jour le message d'état en haut. et encore une fois la zone de texte est activée.Ajax formulaire soumettre
ceci est ma forme
<?php echo $form->create('StatusMessage', array('type' => 'post', 'url' => '/account/updateStatus', 'id' => 'updateStatus')); ?>
<?php echo $this->Form->input('id', array('value' => $user['User']['id'],'type' => 'hidden')); ?>
<?php echo $this->Form->textarea('message', array('value' => 'What have you been eating ?')); ?>
Modifié: Modifié comme suggéré par 0 RioTera
CakePHP action
function updateStatus() {
$this->autoRender = false;
if($this->RequestHandler->isAjax()) {
$this->layout = 'ajax'; //THIS LINE NEWLY ADDED
$this->data['StatusMessage']['pid'] = 0;
$this->data['StatusMessage']['commenters_item_id'] = $this->data['StatusMessage']['item_id'] = $this->User->Item->itemId('1', $this->data['StatusMessage']['id']);
unset($this->data['StatusMessage']['id']);
//debug($this->data);
if($this->User->Item->StatusMessage->save($this->data)) {
return true;
} else {
echo 'not saved';
}
} else {
echo 'no';
}
}
code Javascript
$(document).ready(function() {
var options = {
target: '#output2',
// target element(s) to be updated with server response
beforeSubmit: showRequest,
// pre-submit callback
success: showResponse, // post-submit callback
// other available options:
//url: url // override for form's 'action' attribute
//type: type // 'get' or 'post', override for form's 'method' attribute
//dataType: null // 'xml', 'script', or 'json' (expected server response type)
clearForm: true // clear all form fields after successful submit
//resetForm: true // reset the form after successful submit
// $.ajax options can be used here too, for example:
//timeout: 3000
};
$('#updateStatus').submit(function() {
// make your ajax call
$(this).ajaxSubmit(options);
return false; // prevent a new request
});
function showRequest(formData, jqForm, options) {
$('#StatusMessageMessage').attr('disabled', true);
}
function showResponse(responseText, statusText, xhr, $form) {
$('#StatusMessageMessage').attr('disabled', false);
alert('shdsd');
}
});
J'ai un code similaire. mais showRequest ne prend rien. Pourquoi avons-nous besoin de showRequest (formData, jqForm, options)? –
et les travaux de désactivation. mais permettant doesnt après soumission. comment récupérer certaines données de l'action à laquelle je me soumets. comme depuis je veux afficher le nom des utilisateurs et la photo et le message et l'heure. dans le mur –
Vous avez besoin de la fonction showRequest pour désactiver la zone de texte lorsque vous cliquez sur le bouton Subimit. Vous devez maintenant renvoyer certaines données de l'action update_status à partir des comptes de contrôleur. L'action dans ce cas n'a pas à rendre toute la page, seulement les données dont vous avez besoin (html, json) ($ this-> autoRender = false). Prenez le temps d'expliquer tout le processus. Vous devez lire le manuel cakephp maintenant. – riotera