Jump to content
ricardonews

despois do cadastro redirecionar para index.php

Recommended Posts

olá pessoal, eu não estou conseguindo fazer o redirecionamento apos o cadastro para index, eu estou perdido entre os ifs e else, eu acho que só pode ser isso,  quando eu coloco meu código trava, e não faz nada. vou postar o print.

COMO COLOCAR INDEX.png

Share this post


Link to post
Share on other sites

Suponho que pela função json_encode () você deve estar

usando AJAX...

 

Pois bem, caso esteja usando o mesmo, creio eu que o

redirect deverá ser executado no próprio AJAX e não

no PHP.

Share this post


Link to post
Share on other sites

agora entendi, será que é esse o motivo que o código não vai nem pra frente e nem pra traz? porque eu ja fiz um projeto com php e dava certo de depois do cadastro ele ir para a index.php eu vou postar aqui o print, precisa por alguma coisa nesta pájina então que está com jquery  e ajax?

vai o codigo pra voce ver.

$(function(){
	var atual_fs, next_fs, prev_fs;
    var formulario = $('form[name=formulario]');
	
	function next(elem){
		atual_fs = $(elem).parent();
		next_fs = $(elem).parent().next();

		$('#progress li').eq($('fieldset').index(next_fs)).addClass('ativo');
		atual_fs.hide(800);
		next_fs.show(800);
	}

	$('.prev').click(function(){
		atual_fs = $(this).parent();
		prev_fs = $(this).parent().prev();

		$('#progress li').eq($('fieldset').index(atual_fs)).removeClass('ativo');
		atual_fs.hide(800);
		prev_fs.show(800);
	});
    
    $('input[name=next1]').click(function(){
        var array= formulario.serializeArray();
        if(array[0].value =='' || array[1].value =='' || array[2].value==''){
            
            $('.resp').html('<div class ="erros"><p>preencha todos os campos para avançar</p></div>');
        }else{
           $('.resp').html('');
           next($(this));
        }
    });
    
    $('input[name=next2]').click(function(){
        var array = formulario.serializeArray();
        if(array[3].value =='' || array[4].value =='' || array[5].value==''){
            
            $('.resp').html('<div class ="erros"><p>informe seus perfis sociais para avançar</p></div>');
        }else{
           $('.resp').html('');
           next($(this));
        }
    });
    
    $('input[type=submit]').click(function(evento){
        var array = formulario.serializeArray();
        if(array[6].value == '' || array[7].value == '' || array[8].value == ''){
            
            $('.resp').html('<div class ="erros"><p>informe suas informaçoes pessoais para ser efetuado o cadastro</p></div>');
        }else{
            $.ajax({
                type:'post',
                url:'cadastrar.php',
                dataType:'json',
                data: {cadastrar:'sim', campos: array},
                beforeSend: function(){
                    $('.resp').html('<div class="erros"><p>Aguarde enquanto processamos seus dados...</p></div>');
                },
                success: function(valor){
                    if(valor.erro == 'sim'){
                        $('.resp').html('<div class="erros"><p>'+valor.getErro+'</p></div>');
                    }else{
                        $('.resp').html('<div class="ok">'+valor.msg+'</div');
                    }
                } 
            });
        }
        evento.preventDefault();
    });
});


	

 

forunimaster.png

Share this post


Link to post
Share on other sites

Segue código:

 

CÓDIGO

// ...
} else {
	//$('.resp').html('<div class="ok">'+valor.msg+'</div');
	window.location.href = "index.php";
}
// ...

 

Share this post


Link to post
Share on other sites

eu não sei oque houve mas não funcionou, apenas cadastrou e não direcionou para index.php, vou colocar o link nos inputs de cadastar  para direcionar para index. obrigado pela ajuda.

Share this post


Link to post
Share on other sites

O problema é que sua mensagem não vai aparecer, pelo fato que o script vai redirecionar assim que executado.

Enfim...

 

Alí onde você marcou a linha de vermelho:

header('index.php');

 

Ou sando javascript que dar no mesmo resultado:

echo ("<script>window.location.href = 'index.php';</script>");

 

 

Share this post


Link to post
Share on other sites
Em 18/06/2019 at 17:00, Omar~ disse:

header('index.php');

Corrigindo quando usando o PHP, porque esqueci de escrever

O correto é usar a realocação 

header('Location: index.php');

 

23 horas atrás, ricardonews disse:

 tem rasão é isso mesmo.

Uma solução quando usando javascript

// A linha de vermelho que você marcou seria aqui
?>
<div id="resultado"></div>
<script>
  document.getElementById('resultado').innerHTML = "O texto ou uma formatação HTML que preferir";
  setTimeout(function () {
    window.location.href = 'index.php';
  }, 2000); // 2000 equivale a 2 segundos
<script>
<?php

Quando o script for executado ele vai pegar a tag div#Resultado e vai compor a marcação.

Logo em seguida começa uma contagem de tempo para redirecionar automaticamente.

 

Só não sei se realmente funciona com esse negócio de jQuery pois só uso javascript nativo.

 

Share this post


Link to post
Share on other sites

Estranho acho que deveria funcionar com o ajax da biblioteca jQuery.

Por essas e outras que a muito aboli completamente o uso dessa biblioteca que no meu ponto de vista é desnecessário em qualquer situação.

 

O que posso fazer por você então é lhe ajudar com um script meu mesmo para o uso de ajax.

Segue o exemplo:

Digamos que esse seja o index ou qualquer outro arquivo onde tenho um formulário cujo quero enviar os dados para outro.

<link href="AjaxRequest.css" rel="stylesheet" type="text/css"/>
<script src="AjaxRequest.js" type="text/javascript"></script>

<div id="resultado"></div>
<form id="exemplo" onsubmit="return ajax.form('exemplo', 'resultado', 'post.php');">
    <input type="text" name="texto-a-enviar" />
    <input type="text" name="texto-a-enviar-b" />
    <button>Executar exemplo</button>
</form>

<script>
    var ajax = new AjaxRequest();
</script>

Logo então nos parâmetros do método são

1 - O ID do formulário

2 - Onde mostrar o resultado

3 - Arquivo ao qual os dados serão enviados

No caso é post.php

<?php
if (!isset($_POST['texto-a-enviar'])) {
    echo ("Algo errado o primeiro input não foi recebido");
} else if (!isset($_POST['texto-a-enviar-b'])) {
    echo ("Algo errado o segundo input não foi recebido");
} else if (empty($_POST['texto-a-enviar'])) {
    echo ("Digite algo no primeiro input");
} else if (empty($_POST['texto-a-enviar-b'])) {
    echo ("Digite algo no segundo input");
} else {
    echo ("<pre>"
              . var_dump($_POST)
          ."</pre>"
          . "<hr />"
          . "Aguarde 2 segundos"
          . "<script>"
          .     "setTimeout(function () {"
          .         "window.location.href = 'index.php';"
          .     "}, 2000);"
          . "</script>");
}

Você pode encontrar essa classe que desenvolvi para ajax tanto para GET quanto para POST através do meu GIT:

https://github.com/Spell-Master/sm-web/tree/master/scripts/AjaxRequest

 

Caso queira mais exemplos de uso dessa classe javascript pois existem outros métodos segue o link de download dos exemplos:

https://drive.google.com/file/d/1vCvakLXwvYRhCW8-B3GpGKucpOINGl-l/view?usp=sharing

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Salvatore
      Então, eu estou gravando uns dados no bancos de dados usando text area, mas quando eu dou espaço ou algo do tipo fica assim
       
      Ex :aaaa\r\naaaaaa\r\n
       
      onde esses \r\n são espaços e outras coisas, e ficam sendo exibidos quando eles retorna para a pagina
      alguém sabe como resolvo isso?
    • By violin101
      Caros amigos, saudações...
       
      Estou usando Codeigniter e estou com uma pequena dúvida.
       
      Tenho um Form com os seguintes campos:
      Data Início..... <input type="date" /> Hora Início.... <input type="time" /> Data Final..... <input type="date" /> Hora Final.... <input type="time" /> até aqui tudo bem
       
      Gostaria de fazer uma VERIFICAÇÃO para impedir que o usuário GRAVE no MySql uma data menor que a data atual.
      ou seja:
      Data Início nunca poderá ser menor que a Data Atual.
      e a
      Data Final só poder ser igual ou maior que a Data Início.
       
      Grato,
       
      Cesar
       
    • By Salvatore
      Galerinha Boa, alguém pode me explicar como eu faço pra editar isso abaixo usando php
       
       
       <div class="nome-vip">
              <p class="text-center"><span>1</span> CASH</p>             <---------------essa parte eu queria saber como eu edito clicando por cima(tentei usando contenteditable), mas n deu do jeito que eu queria,preciso que o valor editado fique em uma variavel PHP
            </div>
            <p class="text-center" style="color: #888; font-size: 15px;">por apenas</p>
            <div class="preco-vip">
              <p class="text-center">R$ 1</p> <------------------- e aqui iria ter a variável preço que ja estaria definida como um, e quando la em cima fosse adicionado um valor int, somasse os 2 e gerasse a variavel valor e exibindo ela
            </div>
       
      Alguém ajuda eu, to caçando em mts sites algo assim mas n consigo
       
    • By drx
      Olá pessoal!
      Estou com um probleminha aqui. Estou me embrenhando pelos ajax e jquery. Muito interessante. 
      Eu peguei um exemplo e é bem simples. Só que não retorna a mensagem para a div.
       
      Eu tenho uma div em pagina1.php onde o usuário entra com um número identificador em um campo textfield.
      Após entrar com o número identificador, solicito a verificação em uma outra página.php onde tenho uma consulta no mysql.
      O echo da consulta é: Existente ou Inexistente. A consulta é feita pelo número identificador. Fiz a verificação e retorna perfeitamente,
      Porém eu quero que ao verificar, a mensagem retorne para minha outra div logo abaixo na pagina1.php
      Vou passar o código para facilitar....
       
      <html>
      <head>
       
      <script src="js/jquery.js"></script>
      <script>
      $(function(){
        $('#form').submit(function(){
           $.ajax({
             url: 'x_consultar_patro.php',
             type: 'POST',
             data: $('#form').serialize(),
             success:function ( data ) {
                 if (data != '') {
                     $('#frm_cadastro').html( data );
                 }
               }
             });
           return false;
         });
      });
      </script>
       
      </head>
       
      <body>

      <div id="frm_cadastro"></div>

      <form id="form" method="post" action="">
        <input type="text" name="codpatro" id="codpatro"/>
        <input type="submit" name="btn_procurar" id="btn_procurar" value="Procurar"/>
      </form>
       
      </body>
      <html>
       
       

    • By Claudia França
      prezados como eu altero de loked para unloked do arro para não carregar o java e seguir com o procedimento. 
       
       
      ?Veja nesse link https://drive.google.com/drive/u/0/folders/1h0EbUoz3UOL8j9orWirUAPILt7cg7q-p 
      minhas imagens não estao subindindo aqui, não sei porque, acho que tenho limitação. 
       
       
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.