Setar OPTION como SELECTED com base em valores do banco de dados – php html mysql

Pergunta:


Estou a preparar um formulário onde estou a setar os valores do campos com os dados do banco de dados.

Estou com dificuldade em setar a opção escolhida como selected para o <select/> no código em baixo:

PHP

<!-- ATENCAO -->
<label>Tipo Beneficiario: </label> <span> <? echo $TipoBeneficiario; ?> </span>
<div class="">
  <select name="tipoBeneficiario">
    <option value="0">Selecione</option>
    <option value="1">Conjugue</option>
    <option value="2">Filho</option>
    <option value="3">Mãe/Pai</option>
    <option value="4">Compannheira(o)</option>
  </select>
</div>

Captura de Tela do formulário

Tela de alteração de dados

Autor da pergunta alexjosesilva

abfurlan

Uma opção também, seria testar o valor para cada option e imprimir selected quando corresponder, exemplo:

<label>Tipo Beneficiario: </label> <span> <?php echo $TipoBeneficiario; ?></span>
<div class="">
  <select name="tipoBeneficiario">
    <option value="0" <?=($TipoBeneficiario == 'Selecione')?'selected':''?> >Selecione</option>
    <option value="1" <?=($TipoBeneficiario == 'Conjugue')?'selected':''?> >Conjugue</option>
    <option value="2" <?=($TipoBeneficiario == 'Filho')?'selected':''?> >Filho</option>
    <option value="3" <?=($TipoBeneficiario == 'Mãe/Pai')? 'selected':''?> >Mãe/Pai</option>
    <option value="4" <?=($TipoBeneficiario == 'Companheira(o)')?'selected':''?> >Compannheira(o)</option>
  </select>
</div>

No exemplo, a condição é testada utilizando if ternário, onde

 <?=($TipoBeneficiario == 'Companheira(o)')? 'selected' : ''?>

é o mesmo que

<?php 
if($TipoBeneficiario == 'Companheira(o)'){
   echo 'selected';
}
?>

Se você não tem a opção de short tags habilitada no servidor ou prefere não utilizar, você pode fazer:

<label>Tipo Beneficiario: </label> <span> <?php echo $TipoBeneficiario; ?></span>
<div class="">
  <select name="tipoBeneficiario">
    <option value="0" <?php echo $TipoBeneficiario=='Selecione'?'selected':'';?> >Selecione</option>
    <option value="1" <?php echo $TipoBeneficiario=='Conjugue'?'selected':'';?> >Conjugue</option>
    <option value="2" <?php echo $TipoBeneficiario=='Filho'?'selected':'';?> >Filho</option>
    <option value="3" <?php echo $TipoBeneficiario=='Mãe/Pai'?'selected':'';?> >Mãe/Pai</option>
    <option value="4" <?php echo $TipoBeneficiario=='Companheira(o)'?'selected':'';?> >Companheira(o)</option>
  </select>
</div>  

Assumindo que o valor da caixa de selecção está contido na variavel $TipoBeneficiario, para que possas marcar determinada opção da caixa de selecção como selected deverás comparar cada uma das opções com o valor presente na variável.

Para o teu caso, parece que estás a guardar a legenda escolhida ao invés do valor da selecção. Assim sendo, podes fazer a comparação da seguinte forma:

Verificar qual está seleccionado

// inicializar variáveis a vazio
$check0 = $check1 = $check2 = $check3 = $check4 = "";

/* verificar qual o valor contido na variável $TipoBeneficiario
 * e preencher a variável de marcação com o atributo "selected"
 */
switch ($TipoBeneficiario) {
  case "Selecione": {
    $check0 = "selected";
    break;
  }
  case "Conjugue": {
    $check1 = "selected";
    break;
  }
  case "Filho": {
    $check2 = "selected";
    break;
  }
  case "Mãe/Pai": {
    $check3 = "selected";
    break;
  }
  case "Compannheira(o)": {
    $check4 = "selected";
    break;
  }
}

Fazer output

echo '
<label>Tipo Beneficiario:  </label>  <span> '.$TipoBeneficiario.'</span>
<div class="">
  <select name="tipoBeneficiario">
    <option value="0" '.$check0.'>Selecione</option>
    <option value="1" '.$check1.'>Conjugue</option>
    <option value="2" '.$check2.'>Filho</option>
    <option value="3" '.$check3.'>Mãe/Pai</option>
    <option value="4" '.$check4.'>Compannheira(o)</option>
  </select>
</div>';

Fonte

Related Posts:

Qual a diferença entre AppCompatActivity e Activity? – android android-activity
Pergunta: Qual a diferença da AppCompatActivity para Activity ? A partir de qual versão a AppCompatActivity foi adicionada ao Android? Autor da pergunta Luhhh A diferença reside ...
Como abreviar palavras em PHP? – php string
Pergunta: Possuo informações comuns como nome de pessoas e endereços, e preciso que elas contenham no máximo 30 caracteres sem cortar palavras. Exemplo: 'Avenida Natalino João Brescansin' ...
Qual é a finalidade de um parêntese vazio numa declaração Lambda? – c# expressões-lambda característica-linguagem
Pergunta: Criei um exemplo de uma declaração Lambda sem argumentos, entretanto, estou com duvidas referente a omissão do parêntese vazio () na declaração. Veja o exemplo: class ...
Boas práticas para URI em API RESTful – api rest restful
Pergunta: Estou com dúvida em relação às URIs de alguns recursos da api que estou desenvolvendo. Tenho os recursos projetos e atividades com relação 1-N, ...
Dúvidas sobre a integração do MySQL com Java – java mysql netbeans
Pergunta: Estou criando um sistema no NetBeans, utilizando a linguagem Java e o banco de dados MySQL. Escrevi o seguinte código para realizar a conexão ...
Qual é a finalidade da pasta Model do framework Inphinit? – php inphinit
Pergunta: No Inphinit micro-framework existe a pasta Model que fica dentro da pasta application, e nela é onde ficam as classes, mas eu estou muito ...
Uso do ‘@’ em variáveis – javascript typescript coffeescript
Pergunta: Vejo em algumas linguagens que compilam para javascript, como TypeScript e CoffeeScript, o uso do @ em variáveis, como também, casos em que o ...
Qual tamanho máximo um arquivo JSON pode ter? – json arquivo
Pergunta: Vou dar um exemplo para conseguir explicar minha duvida: Preciso recuperar informação de imagens vindas de uma API, esse banco de imagens me retorna JSON's ...
O que é Teste de Regressão? – terminologia engenharia-de-software testes
Pergunta: Na matéria de Teste de Software o professor abordou um termo chamado Teste de Regressão, isto dentro da disciplina de teste de software. Sendo ...
O que é um construtor da linguagem? – php característica-linguagem
Pergunta: Em PHP, já li e ouvi várias vezes a respeito dos Construtores da Linguagem. Os casos que sempre ouvi falar deles foi em casos ...
Função intrínseca para converter numérico para string – cobol
Pergunta: Estou a tentar saber se existe alguma função intrínseca do COBOL para converter um data numérico para string sem precisar usar a cláusula REDEFINES: ( ...
Porque usar implements? – java android
Pergunta: Qual a diferença entre usar btn.setOnClickListener(new OnClickListener() { e public class MainActivity extends Activity implements OnClickListener{ Estive fazendo um curso de Android e meu professor falou que ...
O que é XHTML e quando deve ser usado? – html xml xhtml
Pergunta: O que eu sei é que o XHTML precisa ser XML válido. Isso implica, por exemplo, que todas as tags precisam ser fechadas. Por ...
Uma placa aceleradora de vídeo pode melhorar o desempenho não-gráfico? [fechada] – desempenho
Pergunta: Para desenvolver em Ruby on Rails, eu utilizo aqui uma máquina virtual do VirtualBox com Ubuntu Server 14.04 sem interface gráfica instalada. Recentemente descobri uma ...
Concat() VS Union() – c# .net
Pergunta: Qual a diferença entre Concat() e Union() ? Quando usar Concat() e quando usar Union() ? Somente pode ser usado em list ? ...

Deixe uma resposta

O seu endereço de email não será publicado. Campos obrigatórios marcados com *