Ir para conteúdo

POWERED BY:

Arquivado

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

mbmesquita

Não consigo acrescentar INPUT text no meu formulário

Recommended Posts

Bom dia amigos, estou com o seguinte problema:

Já tenho um form que está funcionando perfeitamente, envia todos os dados para o banco e tudo mais, só que preciso acrescentar um INPUT de text (para as pessoas escreverem comentários) nesse mesmo form, e quando coloco esse input e faço o envio pela página php, ele me informar um erro na parte das checkbox, gostaria de saber como fazer sem dar o erro.

 

a parte do código que já funciona é essa:

<?php
$id_usuario 		= $_SESSION['id_usuario'];
$cidade 			= $_POST['cidade2'];
$saloes 			= $_POST['saloes_ava'];
$valorapx 			= $_POST['valorapx'];
$atendimento	 	= $_POST['atendimento'];
$servico 			= $_POST['servico1'];
$tde 				= $_POST['tde'];
$ambiente 			= $_POST['ambiente'];


		$opcao='';
		for($i=0; $i <= count($_POST['servicosava']); $i++){
		$opcao+= $_POST['servicosava'][$i]. ' ';
		}

    $sql = " INSERT INTO feedback_recebido3 (id_usuario, cidade2, saloes_ava, servicosava, valorapx, atendimento, servico1, tde, ambiente)values($id_usuario,'$cidade', '$saloes', '".$opcao."', '$valorapx', '$atendimento', '$servico', '$tde', '$ambiente') ";


if(mysqli_query($conexao, $sql)){
	header('Location: feedsucesso.php') ;
} else {
echo 'Erro ao tentar inserir o registro';
}

?>

 

 

E outra questão, tenho essas checkbox que são nomes, que são enviadas e só recebo os values delas no banco de dados, na verdade só recebo as somas desses values.

Gostaria de saber se tem como eu receber além dessa soma, os nomes das checkbox que foram selecionadas?

 

Desde já agradeço.

Compartilhar este post


Link para o post
Compartilhar em outros sites

essa é a parte do input que quer adicionar:

 

<label for="comentario">Comentários</label>
	<input type="text" name="comentario" id="comentario" placeholder="Opcional"><br>

já havia criado a coluna na mesma tabela do banco e tudo mais, mas ao inserir esse input no arquivo de envio php, ele dá erro na parte da soma das checkbox, e retirando a parte do envio desse comentario, o form envia tudo correto.

 

Na parte das checkbox eu já tenho o value, que estão em valores númerais, mas queria receber além desses valores, os nomes, também. no html as checkbox estão assim:

<label for="servicosava1" >Serviços</label>
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="3" />Corte <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="4" />Escova <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="3" />Chapinha <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="5" />Pintura <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="5" />Hidratação <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="9" />Progressiva <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="10" />Outra Química <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="3" />Unha <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="4" />Depilação <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="10" />Penteado <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="10" />Maquiagem <br />
		<input type="checkbox" name="servicosava[]" onclick="verificar()" value="3" />Sombrancelha <br />

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

tu tem vários checkbox com mesmos values aí dá conflito e não vi a parte do POST onde pega o comentario

Compartilhar este post


Link para o post
Compartilhar em outros sites
25 minutos atrás, marsolim disse:

tu tem vários checkbox com mesmos values aí dá conflito e não vi a parte do POST onde pega o comentario

 

Sim, mas elas não geram conflito não, após selecionadas elas simplesmente se somam e cai no banco de dados somadas, até então está tudo ok.

 

Eu preciso é adicionar os comentários sem que dê erro na soma das checkbox, porque do jeito que tá, o form funciona perfeitamente.

 

com o POST dos comentários fica assim:

<?php
$id_usuario 		= $_SESSION['id_usuario'];
$cidade 			= $_POST['cidade2'];
$saloes 			= $_POST['saloes_ava'];
$valorapx 			= $_POST['valorapx'];
$atendimento	 	= $_POST['atendimento'];
$servico 			= $_POST['servico1'];
$tde 				= $_POST['tde'];
$ambiente 			= $_POST['ambiente'];
$coment				= $_POST['comentarios'];


		$opcao='';
		for($i=0; $i <= count($_POST['servicosava']); $i++){
		$opcao+= $_POST['servicosava'][$i]. ' ';
		}

    $sql = " INSERT INTO feedback_recebido3 (id_usuario, cidade2, saloes_ava, servicosava, valorapx, atendimento, servico1, tde, ambiente, comentarios)values($id_usuario,'$cidade', '$saloes', '".$opcao."', '$valorapx', '$atendimento', '$servico', '$tde', '$ambiente', '$coment') ";


if(mysqli_query($conexao, $sql)){
	header('Location: feedsucesso.php') ;
} else {
echo 'Erro ao tentar inserir o registro';
}

?>

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

tenta trocar $opcao = ''; por $opcao = 0;

Compartilhar este post


Link para o post
Compartilhar em outros sites
23 minutos atrás, marsolim disse:

tenta trocar $opcao = '' por $opcao = 0

 

teste desse jeito e me retorna esse erro:

 

Notice: Undefined index: comentarios in C:\xampp\htdocs\aa_beauty_feedback_at\inclui_feed.php on line 34

Notice: Undefined offset: 3 in C:\xampp\htdocs\aa_beauty_feedback_at\inclui_feed.php on line 42
Erro ao tentar inserir o registro

Compartilhar este post


Link para o post
Compartilhar em outros sites

e onde é que tá esse campo atendimento? no seu for tem um com nome comentario e não atendimento

Compartilhar este post


Link para o post
Compartilhar em outros sites

O operador deveria ser .= invés de += .

Não seria isso?

 

		$opcao='';
		for($i=0; $i <= count($_POST['servicosava']); $i++){
		$opcao .= $_POST['servicosava'][$i]. ' ';
		}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
23 minutos atrás, marsolim disse:

e onde é que tá esse campo atendimento? no seu for tem um com nome comentario e não atendimento

 

tem um com atendimento sim, são campos diferentes, mas existe os 2.

 

17 minutos atrás, Prog disse:

O operador deveria ser .= invés de += .

Não seria isso?

 


		$opcao='';
		for($i=0; $i <= count($_POST['servicosava']); $i++){
		$opcao .= $_POST['servicosava'][$i]. ' ';
		}

 

 

Obrigado pela resposta Prog, antes eu estava fazendo com .= mas ele caia no banco sem a soma, por exemplo: caia 3 9 10

ai troquei para += e agora ta caindo corretamente, 22 , pois eu retorno esses dados já somados para um painel de usuário.

 

Eu só não estou entendendo porque dá erro quando adiciono o campo comentário, sendo que sem esse campo o form funciona corretamente e envia tudo correto para o banco de dados..

Compartilhar este post


Link para o post
Compartilhar em outros sites

e o nome do campo é comentario ou comentarios? verifica se não tá fazendo confusão com os nomes, e só pra desencargo, esse campo tá dentro do das tags <form> e </form>?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Olha só...

 

Se você precisa somar valores numéricos, esta linha esta errada:

 

$opcao+= $_POST['servicosava'][$i]. ' ';

 

Tente:

 

$opcao=0;
for($i=0; $i <= count($_POST['servicosava']); $i++){
$opcao += (int)$_POST['servicosava'][$i];
}

 

Qual erro dá no seu código?

Compartilhar este post


Link para o post
Compartilhar em outros sites
8 minutos atrás, marsolim disse:

e o nome do campo é comentario ou comentarios? verifica se não tá fazendo confusão com os nomes, e só pra desencargo, esse campo tá dentro do das tags <form> e </form>?

 

Isso faz sentido, no código que ele postou está "comentario" e "comentarios".

Compartilhar este post


Link para o post
Compartilhar em outros sites
1 hora atrás, marsolim disse:

e o nome do campo é comentario ou comentarios? verifica se não tá fazendo confusão com os nomes, e só pra desencargo, esse campo tá dentro do das tags <form> e </form>?

 

Sim, está tudo dentro do form e realmente tinha confundido os nomes mas já arrumei e continua dando o mesmo erro.

 

59 minutos atrás, Prog disse:

Olha só...

 

Se você precisa somar valores numéricos, esta linha esta errada:

 


$opcao+= $_POST['servicosava'][$i]. ' ';

 

Tente:

 


$opcao=0;
for($i=0; $i <= count($_POST['servicosava']); $i++){
$opcao += (int)$_POST['servicosava'][$i];
}

 

Qual erro dá no seu código?

 

Obrigado pelo toque Prog, arrumei e funcionou da mesma forma que antes, mas acredito que assim seja mais correto mesmo.

 

Mas fiz tudo certo e ajustei os nomes do comentario, e continua dando o mesmo erro, esse aqui:

 


Notice: Undefined offset: 3 in C:\xampp\htdocs\aa_beauty_feedback_at\inclui_feed.php on line 42
Erro ao tentar inserir o registro

Compartilhar este post


Link para o post
Compartilhar em outros sites

e quem é line 42? o que ela carrega? quais suas aspirações, seus anseios, seus desejos? 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Simples. Basta você olhar para o seu for, você pede para ele somar enquanto for menor ou igual.

Troque para menor apenas.

 

Motivo do erro: Digamos que você tenha 3 retornado pelo count

o for vai contar de 0 - 2 (o que é 3), caso você coloque menor ou igual ele vai somar de 0 - 3, ou seja ele vai tentar receber um quadro inexistente.

Até mais.

 

11 minutos atrás, mbmesquita disse:

for($i=0; $i < count($_POST['servicosava']); $i++)
{

 $opcao += (int)$_POST['servicosava'][$i];
}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
30 minutos atrás, marsolim disse:

e quem é line 42? o que ela carrega? quais suas aspirações, seus anseios, seus desejos? 

 

essa é a linha 42:

$opcao += (int)$_POST['servicosava'][$i];

eu só quero simplesmente que o meu form continue funcionando e que eu consiga enviar para o banco de dados com o input de comentarios, só isso.

 

27 minutos atrás, jamesbond disse:

Simples. Basta você olhar para o seu for, você pede para ele somar enquanto for menor ou igual.

Troque para menor apenas.

 

Motivo do erro: Digamos que você tenha 3 retornado pelo count

o for vai contar de 0 - 2 (o que é 3), caso você coloque menor ou igual ele vai somar de 0 - 3, ou seja ele vai tentar receber um quadro inexistente.

Até mais.

 

 

 

beleza, tirei o = e deixei só o menor < mas ele passou a parte do código e retornou o erro

 

Erro ao tentar inserir registro, caiu no else

 

if(mysqli_query($conexao, $sql)){
	header('Location: feedsucesso.php') ;
} else {
echo 'Erro ao tentar inserir o registro';
}

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

Tu pode dar um print no comando de INSERT e colar aqui pra gente ver?

Ou... Tirar o mysqli_query() do IF e colar a mensagem de erro que está aparecendo.

Compartilhar este post


Link para o post
Compartilhar em outros sites

 

1 minuto atrás, Prog disse:

Tu pode dar um print no comando de INSERT e colar aqui pra gente ver?

ai Prog

$sql = " INSERT INTO feedback_recebido3 (id_usuario, cidade2, saloes_ava, servicosava, valorapx, atendimento, servico1, tde, ambiente, comentarios)values($id_usuario,'$cidade', '$saloes', '".$opcao."', '$valorapx', '$atendimento', '$servico', '$tde', '$ambiente', '$coment') ";


if(mysqli_query($conexao, $sql)){
	header('Location: feedsucesso.php') ;
} else {
echo 'Erro ao tentar inserir o registro';
}

agora ele passa direto e para no else.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Tire todo o IF e rode apenas mysqli_query(); faça um print no $sql também.

 

Exemplo:

 

$sql = " INSERT INTO feedback_recebido3 (id_usuario, cidade2, saloes_ava, servicosava, valorapx, atendimento, servico1, tde, ambiente, comentarios)values($id_usuario,'$cidade', '$saloes', '".$opcao."', '$valorapx', '$atendimento', '$servico', '$tde', '$ambiente', '$coment') ";

print $sql;
mysqli_query($conexao, $sql);

/*if(mysqli_query($conexao, $sql)){
	header('Location: feedsucesso.php') ;
} else {
echo 'Erro ao tentar inserir o registro';
}*/

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos, saudações.
       
      Por favor, me permita tirar uma dúvida com os amigos.

      Tenho um Formulário onde o Usuário digita todos os Dados necessários.

      Minha dúvida:
      --> como faço após o usuário digitar os dados e salvar, o Sistema chamar uma Modal ou mensagem perguntando se deseja imprimir agora ?

      Grato,
       
      Cesar
    • Por Carcleo
      Tenho uma abela de usuarios e uma tabela de administradores e clientes.
      Gostaria de uma ajuda para implementar um cadastro
       
      users -> name, login, passord (pronta) admins -> user_id, registratiom, etc.. client -> user_id, registratiom, etc...
      Queria ajuda para extender de user as classes Admin e Client
      Olhem como estáAdmin
      <?php namespace App\Models; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; class Admin extends User {     use HasFactory;            protected $fillable = [         'name',         'email',         'password',         'registration'     ];      private string $registration;     public function create(         string $name,          string $email,          string $password,         string $registration     )     {         //parent::create(['name'=>$name, 'email'=>$email, 'password'=>$password]);         parent::$name = $name;         parent::$email = $email;         parent::$password = $password;         $this->registration = $registration;     } } User
      <?php namespace App\Models; // use Illuminate\Contracts\Auth\MustVerifyEmail; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; use Illuminate\Database\Eloquent\Relations\BelongsToMany; class User extends Authenticatable {     /** @use HasFactory<\Database\Factories\UserFactory> */     use HasFactory, Notifiable;     static string $name;     static string $email;     static string $password;     /**      * The attributes that are mass assignable.      *      * @var list<string>      */     protected $fillable = [         'name',         'email',         'password',     ];          /**      * The attributes that should be hidden for serialization.      *      * @var list<string>      */     protected $hidden = [         'remember_token',     ];     /**      * Get the attributes that should be cast.      *      * @return array<string, string>      */     protected function casts(): array     {         return [             'email_verified_at' => 'datetime',             'password' => 'hashed',         ];     }          public function roles() : BelongsToMany {         return $this->belongsToMany(Role::class);     }       public function hasHole(Array $roleName): bool     {                 foreach ($this->roles as $role) {             if ($role->name === $roleName) {                 return true;             }         }         return false;     }         public function hasHoles(Array $rolesName): bool     {                 foreach ($this->roles as $role) {             foreach ($rolesName as $rolee) {             if ($role->name === $rolee) {                 return true;             }          }         }         return false;     }         public function hasAbility(string $ability): bool     {         foreach ($this->roles as $role) {             if ($role->abilities->contains('name', $ability)) {                 return true;             }         }         return false;     }     } Como gravar um Admin na tabela admins sendo que ele é um User por extensão?
      Tentei assim mas é claro que está errado...
      public function store(Request $request, Admin $adminModel) {         $dados = $request->validate([             "name" => "required",             "email" => "required|email",             "password" => "required",             "registration" => "required"         ]);         $dados["password"] =  Hash::make($dados["password"]);                  $admin = Admin::where("registration",  $dados["registration"])->first();                  if ($admin)              return                    redirect()->route("admin.new")                             ->withErrors([                                 'fail' => 'Administrador já cadastrados<br>, favor verificar!'                   ]);                            $newAdmin = $adminModel->create(                                    $dados['name'],                                    $dados['email'],                                    $dados['password'],                                    $dados['registration']                                 );         dd($newAdmin);         $adminModel->save();         //$adminModel::create($admin);                  return redirect()->route("admin.new")->with("success",'Cadastrado com sucesso');     }  
    • Por violin101
      Caros amigos, saudações.
       
      Gostaria de tirar uma dúvida com os amigos, referente a PDV.
       
      Estou escrevendo um Sistema com Ponto de Vendas, a minha dúvida é o seguinte, referente ao procedimento mais correto.

      Conforme o caixa vai efetuando a venda, o Sistema de PDV já realiza:
      a baixa direto dos produtos no estoque
      ou
      somente após concretizar a venda o sistema baixa os produtos do estoque ?
       
      Grato,
       
      Cesar
       
    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
×

Informação importante

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