Jump to content
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?

Share this post


Link to post
Share on other 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

 

Share this post


Link to post
Share on other 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

 

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 teuzero
      Meu site é :https://xraros.000webhostapp.com/
       
      To com seguinte problema eu adicionei esse código:
       
      jQuery(document).ready(function() { if($(window).width()<=820) { $('#menu').hide(); } }); no arquivo carrega.js com a intenção de ocultar o menu só quando a tela estive com 820px de largurar ou menos, mais isso não esta acontecendo, como podem ver no meu site esse script n esta funcionando ele ta ocultando o menu em todas as resoluções, como faço pra deixar o menu oculto na resolução de 820px pra baixo?
    • By vinihhylian0103
      Estou fazendo um projeto de Delphi escola e nele tenho que gravar dados no SQLITE. Estou usando o seguinte código:
       
      unit UClube; interface uses   System.SysUtils, System.Types, System.UITypes, System.Classes, System.Variants,   FMX.Types, FMX.Controls, FMX.Forms, FMX.Graphics, FMX.Dialogs,   FMX.ListView.Types, FMX.ListView.Appearances, FMX.ListView.Adapters.Base,   FMX.StdCtrls, FMX.ListView, FMX.DateTimeCtrls, FMX.Edit,   FMX.Controls.Presentation, FMX.TabControl, FireDAC.Stan.Intf,   FireDAC.Stan.Option, FireDAC.Stan.Error, FireDAC.UI.Intf, FireDAC.Phys.Intf,   FireDAC.Stan.Def, FireDAC.Stan.Pool, FireDAC.Stan.Async, FireDAC.Phys,   FireDAC.Phys.SQLite, FireDAC.Phys.SQLiteDef, FireDAC.Stan.ExprFuncs,   FireDAC.Stan.Param, FireDAC.DatS, FireDAC.DApt.Intf, FireDAC.DApt,   FireDAC.FMXUI.Wait, System.Rtti, System.Bindings.Outputs, Fmx.Bind.Editors,   Data.Bind.EngExt, Fmx.Bind.DBEngExt, Data.DB, FireDAC.Comp.DataSet,   Data.Bind.Components, Data.Bind.DBScope, FireDAC.Comp.UI, FireDAC.Comp.Client, System.IOUtils; type   TForm1 = class(TForm)     TabControl1: TTabControl;     TabItem2: TTabItem;     tb1: TTabItem;     lvSocio: TListView;     btnSalvar: TButton;     btnCancelar: TButton;     btnEditar: TButton;     btnExcluirr: TButton;     Panel1: TPanel;     edtDataNasc: TDateEdit;     edtCod: TEdit;     edtNome: TEdit;     edtRg: TEdit;     edtCPF: TEdit;     edtEndereco: TEdit;     Label1: TLabel;     Label2: TLabel;     Label3: TLabel;     Label4: TLabel;     Label5: TLabel;     labwl: TLabel;     NOME: TLabel;     Button5: TButton;     Panel2: TPanel;     edtDataA: TDateEdit;     edtCodSocio: TEdit;     Label6: TLabel;     Label10: TLabel;     Label11: TLabel;     Label12: TLabel;     rdbSocio: TRadioButton;     edtNomeA: TEdit;     btnNovoA: TButton;     edtHoraIA: TEdit;     Label7: TLabel;     Edit7: TEdit;     edtHoraFA: TLabel;     edtDescricaoA: TEdit;     Label9: TLabel;     edtValorA: TEdit;     btnCancelarA: TButton;     btnEditarA: TButton;     btnExcluirA: TButton;     btnSalvarA: TButton;     lvAgendamento: TListView;     FDConnPrincipal: TFDConnection;     qrSocio: TFDQuery;     qrAgendamento: TFDQuery;     FDPhysSQLiteDriverLink1: TFDPhysSQLiteDriverLink;     FDGUIxWaitCursor1: TFDGUIxWaitCursor;     BindSourceDB1: TBindSourceDB;     BindingsList1: TBindingsList;     LinkListControlToField1: TLinkListControlToField;     LinkControlToField1: TLinkControlToField;     LinkControlToField2: TLinkControlToField;     LinkControlToField3: TLinkControlToField;     LinkControlToField4: TLinkControlToField;     LinkControlToField5: TLinkControlToField;     LinkControlToField6: TLinkControlToField;     qrSocioID: TFDAutoIncField;     qrSocioNOME: TStringField;     qrSocioRG: TStringField;     qrSocioCPF: TStringField;     qrSocioENDERECO: TStringField;     qrSocioDATA_NASC: TDateField;     qrSocioCODIGO: TIntegerField;     qrAgendamentoID: TFDAutoIncField;     qrAgendamentoNOME: TStringField;     qrAgendamentoCODIGO: TIntegerField;     qrAgendamentoDESCRICAO: TWideMemoField;     qrAgendamentoDATA: TDateField;     qrAgendamentoHORA_INICIO: TStringField;     qrAgendamentoHORARIO_FIM: TStringField;     qrAgendamentoVALOR: TLargeintField;     qrAgendamentoSOCIO: TStringField;     procedure rdbSocioChange(Sender: TObject);     procedure btnSalvarClick(Sender: TObject);     procedure Button5Click(Sender: TObject);     procedure btnCancelarClick(Sender: TObject);     procedure btnEditarClick(Sender: TObject);     procedure btnExcluirrClick(Sender: TObject);     procedure FormShow(Sender: TObject);   private     { Private declarations }   public     { Public declarations }   end; var   Form1: TForm1; implementation {$R *.fmx} procedure TForm1.btnCancelarClick(Sender: TObject); begin qrSocio.Cancel; Panel1.Enabled := False; end; procedure TForm1.btnEditarClick(Sender: TObject); begin if qrSocio.RecordCount > 0 then begin   qrSocio.Edit;   Panel1.Enabled := True;   edtNome.SetFocus; end; end; procedure TForm1.btnExcluirrClick(Sender: TObject); begin if qrSocio.RecordCount = 0 then abort; qrSocio.Delete; ShowMessage('Dados excluídos!'); end; procedure TForm1.btnSalvarClick(Sender: TObject); begin if edtNome.Text = '' then begin ShowMessage('O nome não pode estar vázio!'); edtNome.SetFocus; abort; end; qrSocio.Post; qrSocio.Refresh; Panel1.Enabled := False; end; procedure TForm1.Button5Click(Sender: TObject); begin Panel1.Enabled := True; edtNome.SetFocus; qrSocio.Append; end; procedure TForm1.FormShow(Sender: TObject);   begin   FDConnPrincipal.Connected := True;   try  {$IF DEFINED (IOS) or DEFINED (ANDROID)}   FDConnPrincipal.Params.Values['DATABASE'] := TPath.Combine(TPath.GetDocumentsPath, 'BD_CLUBE.s3db');   {$ENDIF}   except on E: Exception do   ShowMessage(e.Message);   end;   qrSocio.Open(); end; procedure TForm1.rdbSocioChange(Sender: TObject); begin  if rdbSocio.IsChecked = true then  begin  edtCodSocio.Enabled := true;  edtCodSocio.SetFocus;  end; end; end.
      E recebo o seguinte erro: 
    • By Zambi
      Tenho uma aplicação web em php e quero fazer um aplicativo mobile do meu site responsivo. Como fazer e publica-lo na playstore?
    • By Gourmet
      Eu tenho 3 layout diferentes e gostaria de que quando o usuário clicasse no layout desejado aparecesse o modelo do layout
×

Important Information

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