Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

manolegal

Envio de valor summernote do formulário para o PHP via ajax

Recommended Posts

Bom dia

Estou gravando dados do form através de ajax, porém o valor de um campo textarea não está sendo enviado.

Neste campo estou utilizando editor de texto SUMMERNOTE, sendo que o valor do campo somente é enviado após o formulário ser submetido ao menos 1 vez. Quando não utilizo o SUMMERNOTE, o valor do campo é enviado normalmente antes de submeter o formulário.

<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css">      
<link rel="stylesheet" href="css/summernote.min.css">

    <form id="e_par_so" method="post" class="form_cad" action="<?php echo $_SERVER['PHP_SELF']; ?>" enctype="multipart/form-data">

      <div class=row>
        <div class="form-group col-md-offset-2">
          <label>Meu Campo</label>
          <textarea class="form-control form_input_recebe_foco" id="tx_par_soc" name="tx_par_soc" placeholder="" title=""><?php echo $_POST ["tx_par_soc"];?></textarea>
        </div>
      </div> <!-- /row -->

    </form>

<script type="text/javascript" src="js/summernote.min.js"></script>


<script>
$(document).ready(function() {
  $('#tx_par_soc').summernote();
});
</script>

No arquivo que grava os dados no BD, estou recebendo da seguinte forma:

$tx_par_soc = $_POST["tx_par_soc"];

O que estou fazendo de errado?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Esse seu código não tem nada semelhante a um Ajax. rs

Mas então, dando uma pesquisada aqui achei uma possível solução:

<link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css">      
<link rel="stylesheet" href="css/summernote.min.css">

    <form id="e_par_so" method="post" class="form_cad" action="<?php echo $_SERVER['PHP_SELF']; ?>" enctype="multipart/form-data" onSubmit="return postForm()">

      <div class=row>
        <div class="form-group col-md-offset-2">
          <label>Meu Campo</label>
          <textarea class="form-control form_input_recebe_foco" id="tx_par_soc" name="tx_par_soc" placeholder="" title=""><?php echo $_POST ["tx_par_soc"];?></textarea>
        </div>
      </div> <!-- /row -->

    </form>

<script type="text/javascript" src="js/summernote.min.js"></script>


<script>
$(document).ready(function() {
  $('#tx_par_soc').summernote();
});

// Parte abaixo inserida:   
var postForm = function() {
	var content = $('textarea[name="tx_par_soc"]').html($('#tx_par_soc').code());
}
</script>

 

Teste e poste o resultado, caso tenha solucionado poderá ajudar outros usuários com problemas semelhantes, e se for possível mude o título do tópico para: "Envio de valor summernote do formulário para o PHP."

 

 

Fonte: https://gist.github.com/soomtong/6635053

Compartilhar este post


Link para o post
Compartilhar em outros sites

Opa Edgard, obrigado pelo retorno.

Tentei desta maneira, porém não funcionou.

Meu código ajax

<script type="text/javascript">
$(document).ready(function(){

    $("#sr_rasc").click(function(){
	     
                var serialize_dados = $('#e_par_so').serialize();

		$.ajax({
			type: "POST",
			url: "ajx_as_par_soc_sr_rasc.php",
			data: serialize_dados,                
                        dataType: 'json',
                        encode: true,
                        cache: false,

                    }).done(function(retorno){
                                if (retorno.inserido == true) {
                                    $("#f_msg_erro").html("<center><b><font color=blue>Rascunho salvo com sucesso!</font></b></center>");
                                }
                                else{
                                    if (retorno.erros){
                                        $('#f_msg_erro').html("");
                                        for(var i=0;i<retorno.erros.length;i++) {
                                            $('#f_msg_erro').append(retorno.erros[i] + "<br>");
                                        }
                                    }
                                    else{
                                        $("#f_msg_erro").html("<center><b>Não foi possível completar o lançamento. Tente novamente!</b></center>");
                                    }
                                }
                                
                    });
		 
                return false;
    });
	 
});
</script>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

A requisição ajax chega a ser feita ao servidor? Se sim, tente esse código.

<script>
  $(document).ready(function(){

    $("#sr_rasc").click(function(){
	     
        var serialize_dados = $('#e_par_so').serialize();
      
      	// Adicione essa linha vvv
        serialize_dados += "&tx_par_soc=" + $("[name='tx_par_soc']").code());
      	

		$.ajax({
          type: "POST",
          url: "ajx_as_par_soc_sr_rasc.php",
          data: serialize_dados,                
          dataType: 'json',
          encode: true,
          cache: false,

        }).done(function(retorno){
          if (retorno.inserido == true) {
            $("#f_msg_erro").html("<center><b><font color=blue>Rascunho salvo com sucesso!</font></b></center>");
          }
          else{
            if (retorno.erros){
              $('#f_msg_erro').html("");
              for(var i=0;i<retorno.erros.length;i++) {
                $('#f_msg_erro').append(retorno.erros[i] + "<br>");
              }
            }
            else{
              $("#f_msg_erro").html("<center><b>Não foi possível completar o lançamento. Tente novamente!</b></center>");
            }
          }

        });

      return false;
    });
	 
});
</script>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

A requisição ajax é feita normalmente ao servidor, sendo que os valores dos demais campos são enviados normalmente. O dado do textarea é enviado normalmente quando não utilizo o summernote.

 

Alterei o código da forma como você sugeriu, porém não envia a requisição ajax dessa forma.

Compartilhar este post


Link para o post
Compartilhar em outros sites

você tem que ler a documentação:

 

https://summernote.org/getting-started/#get--set-code

 

ou seja:

var markupStr = $('#tx_par_soc').summernote('code');

var serialize_dados = $('#e_par_so').serialize(); 
serialize_dados += '&summernote=' + markupStr;

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

William, obrigado pela ajuda.

Tentei da seguinte forma:

<script>
$(document).ready(function() {
  $('#tx_par_soc').summernote();
});
</script>

<script type="text/javascript">
$(document).ready(function(){

    $("#sr_rasc").click(function(){
	     
        var markupStr = $('#tx_par_soc').summernote('code');
        var serialize_dados = $('#e_par_so').serialize(); 
        serialize_dados += '&summernote=' + markupStr;

		$.ajax({
.....

Porém aparece a seguinte mensagem após envio:

summernote	undefined

E continua não enviando o valor do textarea.

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

lá no php, você fez:

 

$tx_par_soc = $_POST["summernote"];

 

?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Willian. Consegui receber o valor do textarea como você sugeriu, juntamente com uma pequena alteração.

Substituí

<script type="text/javascript" src="js/summernote.min.js"></script>

Para

<script type="text/javascript" src="js/summernote.js"></script>

E funcionou, porém os ícones do summernote não estão sendo mostrados corretamente.

 

Após várias pesquisas, realizei alterações com base em

Icones summernote

Localmente funcionou, porém em servidor externo não funcionou. Pode ser algum bloqueio do servidor? Grato.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Creio que não.

Veja no console do browser o que aparece, provavelmente você não subiu as imagens para o servidor, ou o caminho delas está incorreto.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Substituí/atualizei a pasta font no servidor e os ícones apareceram normalmente. Obrigado aos amigos pela ajuda. Tópico resolvido.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por luiz monteiro
      Olá. Tenho 3 formulários em uma mesma pagina, onde cada um tem 1 input type text.
      O que preciso é recuperar o nome desses inputs e o valor correspondente ao formulário submetido.
      =============
      form name="formulario1" id="formulario1"
      input type="text" name="nome1" value="valor1" /form
      form name="formulario2" id="formulario2"
      input type="text" name="nome2" value="valor2" /form
      form name="formulario3" id="formulario3"
      input type="text" name="nome3" value="valor3" /form
      =============
      ..........
      var formulario_submetido = document.getElementById("formulario1"); formulario_submetido.addEventListener('submit', function(e) { e.preventDefault(); //tentei console.log(document.querySelectorAll('#'+this.id + ' input').name); //tentei var formula = new FormData(formulario_submetido); console.log(formula.input['type=text'].name); //tentei console.log(formula.get(input['type=text']).name); ..........
        no console.log(e), ele está nessa hierarquia   form -> srcElement -> input -> attributes -> name 
      Como recupero o valor do name dele e o valor do value?
       
      Agradeço desde já.
    • Por ment0r
      Boa noite pessoal, tudo bem?
       
      Estou desenvolvendo um sistema simples com exibição de formulário via modal. Uma vez cadastrado o serviço (tabela possui apenas dois campos, id e nome), eles são exibidos numa tabela com um ícone que permite a alteração do nome.

       
      Eu clico no ícone e é chamado um modal que é gerado via ajax (pois são vários registros).
       

       
      Nesse modal é mostrado o serviço e uma vez alterado, o botão Salvar chama uma função que atualiza a tabela servico, concluindo a tarefa. Fiz o mesmo processo pra cadastrar o serviço, com a diferença de que o modal está presente na mesma página, ou seja, não é chamado via ajax.
       
      Eis os códigos:
      <a href="#" onclick="modalUpdate(<?= trim($array['id']) ?>)"> <i class='bx bx-edit'></i> </a> // Trecho onde eu chamo a função modalUpdate. Função btAltServico click:
      $('#btAltServico').click(function() { var inpnome = $('#nome'); var inpid = $('#id'); if (inpnome.val() == '') { swal("Atenção", "Por favor, preencha os campos obrigatórios", "warning"); if (inpnome.val() == '') { inpnome.css("border","2px solid #f94545"); } else { inpnome.css("border",""); } alert(inpnome); alert(inpid); } else { $.ajax({ url: '../inc/ajax/altServico.php', type: 'post', dataType: 'json', // pode ser html data: { nome : inpnome.val(), id : inpid.val() }, success: function(resposta){ if (resposta == 1) { inpnome.val(""); inpnome.css("border",""); swal("Sucesso", "Serviço alterado", "success"); } else { if (resposta == 0) { swal("Erro", "Serviço não alterado. Log de erro gerado.", "error"); } else { swal("Atenção", "Serviço já cadastrado", "warning"); } } } }) } });  
      E modalUpdate.php :
       
      <?php /* * altServico.php * * Script responsável pelo update de serviços na tabela servico * * Função chamada pelo arquivo ajax.js */ //if ($_POST) { require'../conn.php'; require'../../class/class.geral.php'; $geral = new Geral(); $nome = $_POST['nome']; $id = $_POST['nome']; $ativo = 1; // Verifica se o servico já foi cadastrado $sqlVer = "select nome from algo68_db_cliente.servico where nome = '".$nome."' and id <> ".$id.""; $queryVer = mysqli_query($conn, $sqlVer); $resultVer = mysqli_num_rows($queryVer); if ($resultVer > 0) { echo json_encode(2); // servico já cadastrado } else { // Update do servico $sql = "update algo68_db_cliente.servico set nome = '".$nome."', ativo = ".$ativo." where id = ".$id; $query = mysqli_query($conn, $sql); $result = mysqli_affected_rows($conn); if ($result > 0) { echo json_encode(1); // alterou o servico } else { $geral->logErro(date('d/m/Y|H:i:s'), @$_SERVER[REQUEST_URI], 'AlterarServico', mysqli_error($conn)); echo json_encode(0); // não alterou o servico } } //} ?> O problema é que quando clico no botão Salvar, não acontece nada - se eu colocar um alert qualquer na função click, só pra saber se está chegando, também não da nada. E está da mesma forma que o cadastro de serviço, que funciona perfeitamente.

      Bom, é isso pessoal, tentei ser o mais breve e especifico possível. Qualquer ajuda é bem vinda, obrigado a todos, desde já.
    • Por Danilo - Jesus voltará!
      Olá pessoal, tenho uma div a qual através de um select categorias eu trago dados de empresas do banco, aí preciso clicar nas listagens das empresas e pegar o ID quando clica no checkbox e gravar pelo ajax novamente na session feita no arquivo php tipo um carrinho de compras, que essa parte já tenho... só não to conseguindo pegar os ids gerados dinamicamente no retorno feito do ajax, eles aparecem com F12 ao inspecionar, mas não aceita eu clicar para pegar o ID, acho que é algo de DOM, mas não to sabendo fazer... alguém aí saberia me ajudar como pegar esses ids ao clicar, já que eles vem dinamicamente?
       
      obrigado
    • Por joao b silva
      <input type="text" class="form-control" id="produto" name="produto"  onblur="BuscaPr()">
       
       
      Ola. eu chamo a função JS a seguir  no onblur do input acima. cikiqyeu is alerts para confirmar a chamada da função. ta chamando. mas alem dos alerts nao acontece mais nada. segue a função JS e o arquivo php que é chamado no ajax:
       
       
      FUNSAO JS
       
          function BuscaPr(){
              var buscaTexto = document.getElementById('produto').value
              alert(buscaTexto) 
              alert(buscaTexto.length) 
              $.ajax({
                  method: 'post',
                  url: 'sistema/produto/buscapr.php',
                  data: {busca: 'sim', texto: buscaTexto},
                  dataType: 'json',
                  success: function(retorno){
                          if(retorno.qtd == 0){
                              alert('q = 0')
                                  $('#resbuscapro').html('<p>Não encontramos resultados para sua busca</p>');
                          }else{
                              alert('q + 0')
                                  $('#resbuscapro').html(retorno.dados);
                          }
                  }
              });
          }

      O ARQUIVO PHP:
       
      <?php
      if (!session_id()):
          session_start();
      endif;
      require_once('_app/Config.inc.php');
      require_once('./Lib.php');
      if (isset($_POST['busca']) && $_POST['busca'] == 'sim'):
          $textoBusca = strip_tags($_POST['texto']);
          $retorno = array();
          $Par = "EM={$_SESSION['userlogin']['emCODIGO']}";
          $Fil = " where emCODIGO = :EM and prDESCRICAO like '%{$textoBusca}%' ";
          $Produto = new Read;
          $Produto->FullRead("select * from produto {$Fil}", $Par);
          if ($Produto->getResult()):
              $retorno['qtd'] = $Produto->getRowCount();
              foreach ($Produto->getResult() as $pro):
                  extract($pro);
                  $retorno['dados'] .= '<a href="#" id='.$prCODIGO.':'.$prVENDA.'">'. utf8_encode($prDESCRICAO).'</a>';
              endforeach;
          endif;
          echo json_encode($retorno);
      endif;
      ?>
    • Por Sapinn
      Estou usando o editor SummerNote em um projeto mas ele não está enviando os dados com o HTML apenas o texto. Eu estou colocando assim:

               
                                        <textarea id="summernote" class="textarea" required name="content">     <script> $('#summernote').summernote({         tabsize: 2,         height: 500,         toolbar: [           ['style', ['style']],           ['font', ['bold', 'underline', 'clear']],           ['color', ['color']],           ['para', ['ul', 'ol', 'paragraph']],           ['table', ['table']],           ['insert', ['link', 'picture', 'video']],           ['view', ['fullscreen', 'codeview', 'help']]         ]       });           </script>  
       
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.