tutoriais mais recente desenvolvimento web
 

AppML Forms


Este capítulo demonstra como construir um formulário de entrada contra um banco de dados.


Os exemplos nesta página usar um banco de dados SQL local.
não bancos de dados SQL locais não funciona no IE ou Firefox. Use Chrome ou Safari.

Criar um modelo de formulário

model_customersform.js

{
"database" : {
    "connection" : "localmysql",
    "maintable" : "Customers",
    "keyfield" : "CustomerID",
    "sql" : "SELECT * FROM Customers"},
"updateItems" : [
    {"item" : "CustomerName"},
    {"item" : "Address"},
    {"item" : "PostalCode"},
    {"item" : "City"},
    {"item" : "Country"}]
}

Criar um formulário HTML

No capítulo anterior, você criou um aplicativo para listar registros de um banco de dados.

Agora adicione um aplicativo de formulário para a página:

Formulário HTML

<div id="Form01" appml-data="local?model=model_customersform"
class="jumbotron">

<div class="form-group">
  <label for="customername">Customer:</label>
  <input id="customername" class="form-control">
</div>

<div class="form-group">
  <label for="address">Address:</label>
  <input id="address" class="form-control">
</div>

<div class="form-group">
  <label for="city">City:</label>
  <input id="city" class="form-control">
</div>

<div class="form-group">
  <label for="postalcode">Postal Code:</label>
  <input id="postalcode" class="form-control">
</div>

<div class="form-group">
  <label for="country">Country:</label>
  <input id="country" class="form-control">
</div>

</div>
Tente você mesmo "

Formulário HTML explicado

appml-data = "local? model = model_customersform" define a aplicação AppML para o formulário.


Criar comandos de formulário HTML

Use sua folha de estilo favorito (we use bootstrap) , e criar seus comandos de formulário queria:

inc_formcommands.htm

<button type="button" class="close" onclick="document.getElementById('Form01').style.display='none';">X</button>

<button type="button" class="close">X</button>

<div class="btn-toolbar" style="margin-bottom:20px;">
<div class="btn-group">

<button type="button" class="btn btn-default" onclick="appml('Form01').newRecord();">
<span class="glyphicon glyphicon-new-window"></span> New</button>

<button type="button" class="btn btn-primary" onclick="appml('Form01').saveRecord();">
<span class="glyphicon glyphicon-floppy-disk"></span> Save</button>

<button type="button" class="btn btn-default" onclick="appml('Form01').deleteRecord();">
<span class="glyphicon glyphicon-trash"></span> Delete</button>

</div>
</div>

<div id="appmlmessage" class="alert alert-warning" style="display:none;">
<button type="button" class="close"
onclick="this.parentNode.style.display='none';">X</button>
<div id="message"></div>

</div>

Inclua os comandos Form

Incluir os comandos de forma na sua forma :.

Formulário HTML

<div id="Form01" appml-data="local?model=model_customersform"
class="jumbotron">

<div appml-include-html="inc_formcommands.htm"></div>

<div class="form-group">
<label for="customername">Customer:</label>
<input id="customername" class="form-control">
</div>

<label for="address">Address:</label>
<input id="address" class="form-control">
</div>

<div class="form-group">
<label for="city">City:</label>
<input id="city" class="form-control">
</div>

<div class="form-group">
<label for="postalcode">Postal Code:</label>
<input id="postalcode" class="form-control">
</div>

<div class="form-group">
<label for="country">Country:</label>
<input id="country" class="form-control">
</div>

</div>
Tente você mesmo "

Adicione Clickable coluna à tabela

No capítulo anterior, você criou um aplicativo para listar registros de um banco de dados.

Agora adicione uma nova coluna à tabela:

Fonte HTML

<div appml-data="local?model=model_customerslist">

<h1>Customers</h1>
<div appml-include-html="inc_listcommands.htm"></div>
<div appml-include-html="inc_filter.htm"></div>

<table class="table table-striped table-bordered">
  <tr>
    <th></th>
    <th>Customer</th>
    <th>City</th>
    <th>Country</th>
  </tr>
  <tr appml-repeat="records">
    <td style="cursor:pointer;width:34px;"
        onclick="appml('Form01').run({{CustomerID}})">
        <span class="glyphicon glyphicon-edit"></span></td>

    <td>{{CustomerName}}</td>
    <td>{{City}}</td>
    <td>{{Country}}</td>
  </tr>
</table>

</div>
Tente você mesmo "

O evento onclick (in the new column) dispara uma chamada para executar um aplicativo AppML localizado no elemento HTML com id = "Form01":

  • appml('Form01') retorna a aplicação AppML
  • run({{CustomerID}}) executa os aplicativos com CustomerID como parâmetro.

Finalmente, ocultar o formulário

Adicionar um estilo para o formulário para torná-lo invisível:

HTML

<div id="Form01" appml-data="local?model=model_customersform"
appml-controller="myFormController"
class="jumbotron" style="display:none" >

Adicionar um controlador para a forma, para apresentar o formulário apenas quando ele é carregado e pronto para exibir dados:

Controlador

<script>
function myFormController($appml) {
    if ($appml.message == "ready") {return -1;}
    if ($appml.message == "loaded") {
        document.getElementById("Form01").style.display="";
    }
}
</script>
Tente você mesmo "