Skip to content

O night-proxy simplifica a aplicação de templates com o Proxy Recursivo, uma técnica inteligente que utiliza proxies do JavaScript para controle total sobre operações em objetos de modelo, oferecendo resultados impressionantes. Experimente e descubra uma nova abordagem intuitiva e poderosa para lidar com templates.

israel-nogueira/night-proxy

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

35 Commits
 
 
 
 
 
 

Repository files navigation

Javascript Proxy template HTML

Simplifique a aplicação de templates em seus dados com o Proxy Recursivo. Esta técnica inteligente utiliza proxies do JavaScript para aplicar templates de forma eficiente e flexível, garantindo controle total sobre cada operação em seus objetos de modelo. Desde a validação de dados até a execução de lógica personalizada, o Proxy Recursivo simplifica seu fluxo de trabalho e oferece resultados impressionantes. Experimente hoje e descubra uma nova maneira de lidar com templates de forma intuitiva e poderosa.

Instalação

Inserimos o arquivo no HTML

<script type="text/javascript" src="./assets/js/night-proxy.js"></script>

Montamos o template, que é o elemento onde está sua estrutura de layout:

<script proxy-template="coxinha" type="x-tmpl">
	<h1>{{ titulo }}</h1>
</script>

Montamos o Target, que receberá o seu template:

<div proxy-target="coxinha">
	carregando...
</div>

Iniciamos o Proxy:

proxy.initProxy();

Setando valor em um nó simples

Quando alterarmos o objeto "titulo", o HTML será alterado em realtime em seu HTML.

proxy.initProxy();

// Primeiro setamos um valor

proxy.template.coxinha.titulo = "Titulo original";

//Depois caso queira alterar o valor:

proxy.template.coxinha.titulo = "Titulo alterado";

Listas

Caso tiver uma lista de ítens, basta envelopar por uma hastag e fecha com uma barra:

<script proxy-template="coxinha" type="x-tmpl">
	{{ #lista }}
		<li>{{ titulo }}</li>
	{{ /lista }}
</script>

TAGS de template

Caso não queira utilizar {{ }} e tenha que trocar, basta setar ANTES de iniciar o proxy:

proxy.tags = ['<%', '%>']
proxy.initProxy();

//ou ainda
proxy.tags = ['[', ']']
proxy.initProxy();

Setando ou inserindo um ou mais item na lista

// setando um objeto inteiro, substituindo o atual caso já exista
proxy.template.coxinha.lista = [
	{titulo:"Com catupiry"},
	{titulo:"Com bacon"},
	{titulo:"Com queijo e presunto"}
]

// adicionando um ítem
proxy.template.coxinha.lista.add({"titulo":"Com camarão"})

// Adicionando vários itens:
proxy.template.coxinha.lista.add([
	{"titulo":"Sabor1"},
	{"titulo":"Sabor2"},
	{"titulo":"Sabor3"}
])

Alterando um item na lista

proxy.template.coxinha.lista[2].titulo="Com costela";

Excluindo um item na lista

proxy.template.coxinha.lista[2].delete();

Requisição Ajax

Pode-se trabalhar diretamente na requisição ajax para setar novos conteudos; Se por exemplo seu retorno for:

[
	{"titulo":"Sabor1"},
	{"titulo":"Sabor2"},
	{"titulo":"Sabor3"}
]

Então você poderá inserir os novos sabores dessa forma:

$.ajax({
	url: "/api/sabores-de-coxinha",
	method: "GET",
	dataType: "json",
	success: function(response) {

		// Caso seja dar um UPDATE geral
		proxy.template.coxinha.lista = response;

		// Ou usamos o método "add()" para inserir
		proxy.template.coxinha.lista.add(response);

	},
	error: function(xhr, status, error) {
		console.error("Erro na requisição:", error);
	}
});

About

O night-proxy simplifica a aplicação de templates com o Proxy Recursivo, uma técnica inteligente que utiliza proxies do JavaScript para controle total sobre operações em objetos de modelo, oferecendo resultados impressionantes. Experimente e descubra uma nova abordagem intuitiva e poderosa para lidar com templates.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published