Jump to content
dutopfave

Carrinho de Compras PHP

Recommended Posts

Boa Tarde, estou criando uma loja virtual, e a questão é voltado para o carrinho de compras, ate agora ta tudo certo, funcionando normal, porém tem produtos que tem vários tamanho, exemplo eu tenho um tênis, e eu posso escolhe se quero tamanho 41 ou 42, blz ate ai ele registra certinho no banco, porém, se por a caso eu também queira compra o do tamanho 41, e dps volto la e compro o 42, invés de cria 2 produto no carrinho ele acaba atualizando o mesmo, pegando o ultimo tamanho q escolhi e na quantidade aumentando pra 2, vou manda o código aki, pq o ideal seria aparece 2 produto no carrinho, pq são 2 tamanho diferente, e isso ta quebrando a cabeça:

Código:

if($_GET['acao'] == 'adds'){
  $qtds = $_POST['qtds'];
  $cart_tamanho = $_POST['cart_tamanho'];

  if(!isset($_SESSION['carrinho'][$id]) && $_SESSION['carrinho'][$id] < $Verifica_qtd_row2){
      $_SESSION['carrinho'][$id] = $qtds;
      $_SESSION['cart_tamanho'][$id] = $cart_tamanho;
    }elseif($_SESSION['carrinho'][$id] < $Verifica_qtd_row2){
      $_SESSION['carrinho'][$id] += $qtds;
      $_SESSION['cart_tamanho'][$id] = $cart_tamanho;
    }else{
      $_SESSION['carrinho'][$id] = 1;
      $_SESSION['cart_tamanho'][$id] = $cart_tamanho;
  }
}

 

Share this post


Link to post
Share on other sites

Pelo o que entendi a variável $id é o id do produto.

 

Para diferenciar por tamanho pode ser feito outro índice para o tamanho do tênis

 

$_SESSION['carrinho'][$id][$tamanho] = $produto;

 

Share this post


Link to post
Share on other sites

Eu recomendo criar um array de itens no carrinho de acordo com o tipo de produto, porque se você tiver o $id repetido porque ele é o $id do tipo de produto e não do produto em si, você sempre sofrerá com essas substituições e além disso facilitará demais a "mão de obra" para incluir, alterar ou excluir item do carrinho.

 

 

 

Share this post


Link to post
Share on other sites

dutopfave,

Como você tem variações de um mesmo produto, o ID do produto sempre será igual.

 

Nesse caso, você precisará fazer dupla verificação.

Verificar se o ID já consta no carrinho, se constar e o tamanho for igual, aumenta UM na quantidade.

Se constar e o tamanho for diferente, adiciona o produto.

Se não constar, simplesmente adiciona.

 

Detalhe é que pra isso, você não pode usar o ID do produto como posição do array no carrinho.

 

1. Ou você usa índices sequenciais e atribui em cada índice as características do produto;

2. Ou se a única variação que você tiver, for tamanho, pra facilitar você pode usar "id-tam", como índice do array.

 

Segue exemplo para primeira opção:

<?php
$produtoId = 10;
$produtoTam = 41;

$existe = false;
foreach ($_SESSION['carrinho'] as $key => $carrinho) {
  // SE JA EXISTIR NO CARRINHO
  if ($carrinho['id'] === $produtoId) {
    // SE O TAMANHO FOR IGUAL, ADICIONA UM NA QUANTIDADE
    if ($carrinho['tamanho'] === $produtoTam) {
      $_SESSION['carrinho'][$key]['quantidade'] += 1;
      $existe = true;
      break;
    }
    // SE O TAMANHO FOR DIFERENTE, INSERE UMA NOVA POSICAO NO ARRAY
    else {
      $_SESSION['carrinho'][] = ['id' => $produtoId, 'tamanho' => $produtoTam, 'quantidade' => 1];
      $existe = true;
    }
  }
}

// DEPOIS DE PERCORRER TODO O CARRINHO, SE NAO EXISTIR
if (!$existe) {
  $_SESSION['carrinho'][] = ['id' => $produtoId, 'tamanho' => $produtoTam, 'quantidade' => 1];
}
?>

 

Segue exemplo para segunda opção:

<?php
$produtoId = 10;
$produtoTam = 41;

// SE EXISTIR NO CARRINHO
if (!empty($_SESSION['carrinho']["$produtoId-$produtoTam"])) {
  $_SESSION['carrinho']["$produtoId-$produtoTam"] += 1;
}
// SE NAO EXISTIR
else {
  $_SESSION['carrinho']["$produtoId-$produtoTam"] = 1;
}
?>

No caso acima, pra você pegar os produtos e os respectivos tamanhos, bastaria fazer um foreach e dar um explode('-', $array). Na posição 0 você teria o ID, na posição 1 você teria o tamanho.

 

Na minha opinião pessoal, a segunda alternativa só é mais viável, se você tiver somente essa variação no seu sistema. Do contrário, o ideal seria usar a primeira solução, visto que você poderá fazer quantas comparações quiser!

 

Um abraço!

Share this post


Link to post
Share on other sites
Em 06/02/2020 at 11:34, ociceromartins disse:

dutopfave,

Como você tem variações de um mesmo produto, o ID do produto sempre será igual.

 

Nesse caso, você precisará fazer dupla verificação.

Verificar se o ID já consta no carrinho, se constar e o tamanho for igual, aumenta UM na quantidade.

Se constar e o tamanho for diferente, adiciona o produto.

Se não constar, simplesmente adiciona.

 

Detalhe é que pra isso, você não pode usar o ID do produto como posição do array no carrinho.

 

1. Ou você usa índices sequenciais e atribui em cada índice as características do produto;

2. Ou se a única variação que você tiver, for tamanho, pra facilitar você pode usar "id-tam", como índice do array.

 

Segue exemplo para primeira opção:


<?php
$produtoId = 10;
$produtoTam = 41;

$existe = false;
foreach ($_SESSION['carrinho'] as $key => $carrinho) {
  // SE JA EXISTIR NO CARRINHO
  if ($carrinho['id'] === $produtoId) {
    // SE O TAMANHO FOR IGUAL, ADICIONA UM NA QUANTIDADE
    if ($carrinho['tamanho'] === $produtoTam) {
      $_SESSION['carrinho'][$key]['quantidade'] += 1;
      $existe = true;
      break;
    }
    // SE O TAMANHO FOR DIFERENTE, INSERE UMA NOVA POSICAO NO ARRAY
    else {
      $_SESSION['carrinho'][] = ['id' => $produtoId, 'tamanho' => $produtoTam, 'quantidade' => 1];
      $existe = true;
    }
  }
}

// DEPOIS DE PERCORRER TODO O CARRINHO, SE NAO EXISTIR
if (!$existe) {
  $_SESSION['carrinho'][] = ['id' => $produtoId, 'tamanho' => $produtoTam, 'quantidade' => 1];
}
?>

 

Segue exemplo para segunda opção:


<?php
$produtoId = 10;
$produtoTam = 41;

// SE EXISTIR NO CARRINHO
if (!empty($_SESSION['carrinho']["$produtoId-$produtoTam"])) {
  $_SESSION['carrinho']["$produtoId-$produtoTam"] += 1;
}
// SE NAO EXISTIR
else {
  $_SESSION['carrinho']["$produtoId-$produtoTam"] = 1;
}
?>

No caso acima, pra você pegar os produtos e os respectivos tamanhos, bastaria fazer um foreach e dar um explode('-', $array). Na posição 0 você teria o ID, na posição 1 você teria o tamanho.

 

Na minha opinião pessoal, a segunda alternativa só é mais viável, se você tiver somente essa variação no seu sistema. Do contrário, o ideal seria usar a primeira solução, visto que você poderá fazer quantas comparações quiser!

 

Um abraço!

 

Pode ocorrer de um erro caso seja tamanhos inteiros. 

Então no lugar de usar um sinal de - coloque #

 

 

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 k9studio
      Olá Amigos,
      tenho essa tabela abaixo e estou apanhando para listar os dados e fazer validação,
      alguém pode ajudar como chamar os dados e validar mostrar o nome somente se estiver visible=on  

       
      CREATE TABLE `system` (   `namesystem` text COLLATE utf8_unicode_ci NOT NULL,   `setting` text COLLATE utf8_unicode_ci NOT NULL,   `value` text COLLATE utf8_unicode_ci NOT NULL,   `order` int(1) NOT NULL,   KEY `namesystem_setting` (`namesystem`(32),`setting`(32)),   KEY `setting_value` (`setting`(32),`value`(32)) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; como os dados estão na tabela:
       
      namesystem setting   value   order (honda)    (name)   (Honda)   1 (honda)    (xtts)   (ok)      0    (honda)   (visible)  (on)      0    (toyota)    (name)   (Toyota)  2 (toyota)    (xtts)   (ok)      0    (toyota)  (visible)  (on)      0    
    • By iguulima
      É possivel realizar uma consulta SQL em duas colunas da mesma tabela usando outra função que não seja o AND ou OR? Segue o meu Select ate agora:
       
      (SELECT * FROM product WHERE comid = $idcom AND status = 'Ativo' AND categ = $category AND nameprod like'%$search%'  ORDER BY id DESC)  
      Por exemplo se eu colocar um AND após buscar o nameprod, no nome do produto não tiver a palavra chave ele também não irá buscar. Ou se colocar um OR ele anulo as outras condições até onde eu sei.
      Iniciante em programação.
    • By fideles
      Caros,
       
      Venho por uma duvida que esta cruel comigo. Explico-lhes.
       
      Tenho um banco de dados contendo exatas 4 colunas (id, codigo, descricao, quantidade) e criei um relatorio no excel que me separa os codigos, neste caso seria 3 abas pq tenho somente 3 codigos internos (S = Solicitar, F = Forneceder, B = Baixado) e criei uma select com GROUP By codigo
       
      Ai no banco eu posso ter 30 codigos com S, 10 com F e 15 com B,
      SELECT * FROM solicitacoes WHERE n_solicitacao = '".$n_solicitacao."' GROUP BY codigo Acontece que essa instrução acima, lista somente a primeira linha de cada codigo, como que eu faço neste caso para ele listar todos codigos? Exibir no caso os 30 codigos com S, os 10 com F e os 15 com B ? 
       
      Estou comendo algo ou meu raciociono esta totalmente equivocado ?
       
    • By Carlos Longo
      Srs Bom dia,
       
      fiz inumeras tentativas para mostrar a imagem com link em:
       <script type="text/javascript"> var imagens =  new Array( '1.jpg', '2.jpg', '3.jpg','4.jpg', '5.jpg', '6.jpg'); var num_img = 6; var img_atual =0; function ChangeImg() { if (img_atual < (num_img - 1) ) { img_atual = img_atual + 1; } else { img_atual = 0; } document["img_apoio"].src = "http://www.ficasimples.com.br/calcfal/prop/" + imagens[img_atual]; var x = setTimeout ("ChangeImg()", 2000); }   </script>  
      ela posteriormente é chamada assim:
      queria que ao clicar na figura fosse chamado o link da figura especifica conforme valor da variavel  imagens[img_atual]/////
      <img name="img_apoio" src="http://www.ficasimples.com.br/calcfal/prop/1.jpg" alt="" border="0"width="190px" height="210px" align="center">  
       
      poderiam me ajudar??
       
      grato
       
      Carlos
    • By iguulima
      Bom dia a todos, tenho em meu banco de dados uma tabela de pedidos, onde nesse pedidos estão salvos as id's dos produtos que foram selecionados pelo usuário, gostaria de saber se tem alguma forma utilizando um while que possa selecionar os produtos mais pedidos dessa tabela, não tenho ideia por onde começar. Consigo listar todos apenas mas não sei como selecionar os que são mais pedidos.
×

Important Information

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