Ir para conteúdo

POWERED BY:

Arquivado

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

kamin

Lógica de paginação em cordova/phonegap usando Jquery Mobile

Recommended Posts

Olá a todos, estou desenvolvendo um APP MOBILE usando cordova/phonegap com Jquery Mobile, porém estou a 2 dias quebrando a cabeça com a lógica e estruturação de páginas e transições.
 
em todo lugar eu vejo a mesma coisa:
 
<body>

   <div data-role="page" id="home">
       <div role="main" class="ui-content">
           <a href="#login" data-transition="slide">FAZER LOGIN</a>
       </div>
   </div>


   <div data-role="page" id="login">
       <div role="main" class="ui-content">
           <a href="#home" data-transition="slide">Voltar para Home</a>
       </div>
   </div>
  
</body>
 
Só que desta maneira, se o App tiver muitas páginas, ex. 100 páginas, todas as 100 páginas ficariam apenas no index.html?! oque iria dificultar muito o entendimento do código e seria uma home page extremamente pesada...
 
Se eu organizar as páginas em outro diretório, ex:
/view/ ->
home.html
login.html
cadastro.html
etc.html
 
e na index.html,
 
<a href="view/login.html" data-transition="slide">FAZER LOGIN</a>

 

ficaria aceitável e legível, porém as transições entre uma página e outra fica horrível quando compilado para ADNROID OU IOS), fica horrível porque está chamando outro HTML e não carregando conteúdo da mesma página, ou seja, tem um atraso no carregamento do HTML...
 
Eu gostaria de uma lógica de paginação onde eu pudesse organizar os arquivos HTML em uma pasta separada (ou algo do tipo) e quando necessário chama-los com uma transições fluidas e não quebradas...
 
Alguém me da uma luz?

Compartilhar este post


Link para o post
Compartilhar em outros sites

 

3 horas atrás, kamin disse:

quando necessário chama-los com uma transições fluidas e não quebradas...

ué o carregamento vai ocorrer mesmo (Saltar da pagina x, para y, etc)

 

Essas transição bonita que você vê é feita com AJAX, normalmente apoiado por algum framework JS.

 

O Cordova é igual você abrir uma pagina HTML via FileSystem do seu S.O. (ficou confuso? abre esse link):

https://raw.githubusercontent.com/gabrieldarezzo/helpjs-ravi/master/img-readme/4.png

 

Será q o mustache não pode te ajudar?

https://github.com/janl/mustache.js

 

 

Já vou deixar o aviso pra ti, caso alguém de a resposta padrão: (use Angular2/React/VueJs).

O uso de framework deveria ser após você ter uma familiaridade com a linguagem.

 

No caso o cordova por si só já é uma abstração.

 

Recomendo você estudar na ordem abaixo:

 

1 - JavaScript (Puro sem Framework)

2- Como funciona uma chamada HTTP

3- Ajax (Puro)

 

O Rodrigo tem uma serie bem legal de JS, 

https://www.youtube.com/watch?v=093dIOCNeIc&list=PLQCmSnNFVYnT1-oeDOSBnt164802rkegc

 

Compartilhar este post


Link para o post
Compartilhar em outros sites
9 minutos atrás, gabrieldarezzo disse:

 

ué o carregamento vai ocorrer mesmo (Saltar da pagina x, para y, etc)

 

Essas transição bonita que você vê é feita com AJAX, normalmente apoiado por algum framework JS.

 

O Cordova é igual você abrir uma pagina HTML via FileSystem do seu S.O. (ficou confuso? abre esse link):

https://raw.githubusercontent.com/gabrieldarezzo/helpjs-ravi/master/img-readme/4.png

 

Será q o mustache não pode te ajudar?

https://github.com/janl/mustache.js

 

 

Já vou deixar o aviso pra ti, caso alguém de a resposta padrão: (use Angular2/React/VueJs).

O uso de framework deveria ser após você ter uma familiaridade com a linguagem.

 

No caso o cordova por si só já é uma abstração.

 

Recomendo você estudar na ordem abaixo:

 

1 - JavaScript (Puro sem Framework)

2- Como funciona uma chamada HTTP

3- Ajax (Puro)

 

O Rodrigo tem uma serie bem legal de JS, 

https://www.youtube.com/watch?v=093dIOCNeIc&list=PLQCmSnNFVYnT1-oeDOSBnt164802rkegc

 

 

 

Olá Gabriel, obrigado por responder.

"ué o carregamento vai ocorrer mesmo (Saltar da pagina x, para y, etc)"


vai acontecer, mas vai acontecendo travando, de forma lenta, etc... porque como você disse:

"é igual você abrir uma pagina HTML via FileSystem do seu S.O."

 

mustache vai me ajudar MUITOOOOOOO em meu projeto, eu não conhecia, muito obrigado.

 

porém o problema ainda persiste, não tenho uma lógica de paginação com jquery mobile, não quero usar angular e sei bastante sobre Ajax (eu acho), porém com um ajax comum, não é possível fazer uma transição semelhante aos app nativos, apenas fadein, fadeout, slow, etc..

 

as opções que tenho até o momento é

1. usar um index.html com todas as páginas do app (oq deixaria muito pesado)

2. linkar para paginas de outro diretorio "view/home.html" (obter transações ruins, travadas)

3. usar ajax puro, mas eu não teria o efeito de transição do nativo, necessito dos efeitos de transições para parar um app nativo android

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por Thiago Duarte
      Oi, gostaria de arrastar imagem e ao soltar formar bloco html, meu bloco de html ficaria com nome, content-1.html, content-2.html, etc
       
      Alguem pode me ajudar?
    • Por ILR master
      Salve galera.
       
      Vou publicar um evento e quero colocar um Cronômetro regressivo que mostre em tempo real os dias, horas e minutos que faltam para determinada data, tipo:.
      Faltam 5 dias, 12:30:00 para inauguração.
       
      Qdo chegar no dia, quero que apenas apareça uma mensagem.
       
      Alguém pode me ajudar?
    • 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 joeythai
      Boa tarde pessoal,
       
      eu criei uma página da qual tenho diversos checkbox para marcar, se tiver alguma caixinha marcada eu habilito um botão para fazer o envio ao servidor, porém, está acontecendo um problema que não consegui identificar, o que está acontecendo é o seguinte:
       
      Quando eu marco um checkbox apenas, o botão é liberado, eu clico nele e aparece um modal para preencher os dados, e nesse modal tem um combobox com opções criadas em javascript, como tem somente uma caixinha marcada as informações no combobox aparecem perfeitamente, porém, se eu marco 2 checkbox ou mais as opções do combobox se repetem, como se eu tivesse fazendo isso dentro de um looping, o que não é verdade, eis o codigo abaixo:
       
      <code>
        <!DOCTYPE html>    <html lang="en">  
         <head>   <meta charset="UTF-8">   <meta http-equiv="X-UA-Compatible" content="IE=edge">   <meta name="viewport" content="width=device-width, initial-scale=1.0">   <title>Document</title>   </head>  
        <body>   <input id="check-belongings" class="custom-control-input check-belongings" name="" type="checkbox" value="">   <label for="" class="custom-control-label"></label>   <div class="col-12">   <div class="md-form mt-0 mb-0 pt-0 pb-0">   <label for="reason">Motivo</label><br><br>  
        <select class="form-control md-select2" style="width: 100%; text-transform: uppercase"   id="reason_all_belongings" name="reason_all_belongings" required>   </select>   </div>   </div>
       
        <script>  
         $('.check-belongings').click(function () {    let belongingsIds = [];    let listaMarcados;  
         let optionsReason = [];   let option = null;  
        let movementsSelect = document.getElementById("reason_all_belongings");  
        optionsReason = ['Conferencia', 'Desobstrução', 'Entrega ao Cliente/Propr','  Inspeção', 'Manobra', 'Venda'  ];  
        optionsReason.forEach((reason) => {   option = new Option(reason, reason.toLowerCase());   movementsSelect.options[movementsSelect.options.length] = option;   });  
        listaMarcados = document.getElementsByClassName("check-belongings");   for (let loop = 0; loop < listaMarcados.length; loop++) {   var item = listaMarcados[loop];  
         if (item.type == "checkbox" && item.checked) {    $('.drop-all-belongings').removeAttr('disabled');    belongingsIds.push(item.value);    } else { // $('.drop-all-belongings').attr('disabled', 'disabled');   }   }   });   </script>   </body>  
        </html> </code>
    • Por Carcleo
      Pessoal,  tenho uma janela popup que vai cobrar toda a tela.
      <div id="personal" class="personal">     <label>Quantas pedras deseja adquirir?</label>          <input type="number" name="rocks" id="rocks" required placeholder="1" max="200">     <a href="<?php echo route('client.buy.raffle',[1]); ?> "><h3>RESERVAR</h3></a> </div> onde tem [1] , no <a href
       
      preciso alterar via JavaScript para o valor colocado no input no momento do clique
       
      Será que tem jeito?
×

Informação importante

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