Skip to content

JS library that helps you create Web Components / Handle DOM / Events / Webworkers / Websockets / Encrypt/deCrypt / Storage / Fetch / AJAX

License

Notifications You must be signed in to change notification settings

arturo21/generaljs

Repository files navigation

general.js

JS library to do high performance solutions

JS Library that handles DOM / Events - DOM / AJAX - FETCH / WebSockets-Webworkers / Watch - UnWatch / Crypto / expansible

Import library from NPM

	npm i gnrl.js

Import library from CDN

	<script src="https://cdn.underdevelopment.work/generaljs/general.min.js">

How to init the library

	genrl.run(function(){
		//write code below
	});

Create a Web Component

	component=genrl.components;
	component.addcomponent("my-counter","template.html", function(template,data){
		class MyCounter extends HTMLElement {
			constructor() {
				super();
				this.count = 0;
				this.attachShadow({ mode: 'open' });
			}
			connectedCallback() {
				this.shadowRoot.appendChild(template.content.cloneNode(true));
				this.shadowRoot.getElementById('inc').onclick = () => this.inc();
				this.shadowRoot.getElementById('dec').onclick = () => this.dec();
				this.update(this.count);
			}
			inc() {
				this.update(++this.count);
			}
			dec() {
				this.update(--this.count);
			}
			update(count) {
				this.shadowRoot.getElementById('count').innerHTML = count;
			}
		}
		component.register("my-counter",MyCounter);
	});

Call Web Component created

	<my-counter></my-counter>

How to getElement Object

	g("#element").getEl();
	g(".element").getEl();

How to select a DOMElement

	g("#element");
	g(".element");

Create a Toggle Button to change classname

	g("#campoeval").on('change',function(){
		if(g("#campoconclase").hasClass("is-hidden")==true){
			g("#campoconclase").removeClass("is-hidden");
		}
		else{
			g("#campoconclase").addClass("is-hidden")
		}
	});

Working with data-values

setData

	g("#campoeval").on('change',function(){
		g("#campoeval").setData("idproducto",idproducto);
	});

getData

	g("#campoeval").on('change',function(){
		let idprod=g("#campoeval").getData("idproducto");
	});

rmData

	g("#campoeval").on('change',function(){
		g("#campoeval").rmData("idproducto");
	});

How to read an object

genrl.each(h,function(x,index){
	genrl.log("RESULTADO");
	genrl.log(x.nombre);
	genrl.log(index);
})

How to set CSS attributes

g("#element").css({
	'height': '400px',
	'width': '200px',
	'opacity': '1'
});

Bind an event

g("#btnmover").click(function(){
	g("#div_A").animate('bounce',5000,function(){
		genrl.log("Se ha activado el callBack");
	});
});

How to get an attribute of a DOMElement

	idelement=g("#element").getAttrb("id");

How to set an attribute of a DOMElement

	g("#element").setAttrb("attribRandom","test");

Get element children

	g("#element").children();

Get element child number N

	g("#element").child(N);

Evaluates a Function

	genrl.eval(function(){
		alert("Hola Mundo!");
	});

Evaluates a Text as JS Function

	data='<script id="scripttag">alert("HOLA");</script>';
	g("#scripttag").eval(data);

URL ROUTES

	genrl.path.map("#/prueba").to(function(){
		g("#cargadiv").load("README.md",function(){
			genrl.log("Módulo cargado.");
		});
	});
	genrl.path.listen();

Get fileList from file input when it changes

archivo is a file input

	g('#archivo').change(function(e){
		genrl.log("Cambió el campo");
		dataf=g('#archivo').getFiles();
	});

AJAX Calls

GET + Callback

	let ajaxobj=genrl.ajaxapi;
	g("#getbtn").click(function(){
		ajaxobj
		.get("general.js/README.md")
		.then(function(data){
			genrl.log("DATA: " + data);
			g("#titulo_widget").html("RESULTADO:");
			g("#mensajes").html(data);
		})
		.catch(function(e){	
			genrl.log("ERROR:" + e);
		})
	});

GET JSON + Callback

	let ajaxobj=genrl.ajaxapi;
	g("#getjbtn").click(function(){
		ajaxobj
		.getJSON("http://localhost/general.js/config.json")
		.then(function(data){
			genrl.log("DATA: " + data);
			g("#titulo_widget").html("RESULTADO:");
			g("#mensajesb").html(data);
		})
		.catch(function(e){	
			genrl.log("ERROR:" + e);
		})
	});

Load asinchronous + Callback

	let ajaxobj=genrl.ajaxapi;
	g("#loadbtn").click(function(){
		ajaxobj
		.load("http://localhost/general.js/README.md")
		.then(function(data){
			genrl.log("DATA: " + data);
			g("#titulo_widget").html("RESULTADO:");
			g("#mensajesa").html(data);
		})
		.catch(function(e){	
			genrl.log("ERROR:" + e);
		})
	});

Asynchronous POST for General.JS

Client Side

	let ajaxobj=genrl.ajaxapi;
	g("#namebtn").click(function(){
		let strdata={'nombre':'arturo'};
		datos=strdata;
		ajaxobj
		.post("socketd.php",datos)
		.then(function(data){
			genrl.log("DATA RECIBIDA: ");
			genrl.log(data);
			g("#titulo_widget").html("RESULTADO:");
			g("#mensajesa").html(data);
		})
		.catch(function(e){	
			genrl.log("ERROR:" + e);
		})
	});

Asynchronous Files UPLOAD for General.JS

Client Side

	let ajaxobj=genrl.ajaxapi;
	g('#archivo').change(function(e){
		genrl.log("Cambió el campo");
		dataf=g('#archivo').getFiles();
	});
	g("#filebtn").click(function(){
		let fdata = new FormData();
		fdata.append("file", dataf[0]);
		ajaxobj
		.upload("uploadfile.php",fdata)
		.then(function(data){
			g("#titulo_widget").html("RESULTADO:");
			g("#mensajesb").html(data);
		})
		.catch(function(e){	
			genrl.log("ERROR:" + e);
		})
	});

Server Side

<?php
	session_start();
    if (move_uploaded_file($_FILES["file"]["tmp_name"], "uploads/".$_FILES['file']['name'])) {
        //more code here...
        echo("uploads/".$_FILES['file']['name']);
    }
?>

Smooth scrolling

	g("#holap").click(function(){
		g("#holap").smooth("#adiosp",{
			duration:'10000',
			offset: 0,
			callback: function(){
				g.log("Scroll finalizado");
			}
		});
	});

Asynchronous JS FETCH API

	genrl.log("*****FETCH API*****");
	var fapi=genrl.fetchapi.getFetch();
	if(fapi){
		g.log("FETCH API ha sido cargada exitosamente!");
		g.log("***************************************");
		var dataSrc={};
		dataSrc={
			method:'fetch',
			name:"arturo",
			lastname:"vasquez"
		}
		fapi.post(
			"socket_fetch.php",
			dataSrc,
			function(data){
				genrl.log("DATA FETCH");
				genrl.log(data);
			}
		);
		fapi.get(
			"example.json",
			function(data){
				var datappal;
				var datos;
				genrl.log("DATA FETCH GET");
				genrl.log(data);
				datappal=data.data;
				genrl.log("PERSONA");
				genrl.log(datappal.persona);
				var datos=datappal.persona;
				genrl.log(datos.ciudad);
				genrl.log("**************");
				genrl.log(datos.nombre);
				genrl.log("**************");
				genrl.log(datos.apellido);
			}
		);
	}

How to extend the library

Creates a new function

	genrl.extend({
		myfunction:function(options){
			//write code below
		});
	});

Use new function

	genrl.myfunction(options);

Creates a new function

	g("#MyContent").extend({
		myfunction:function(options){
			//write code below
		});
	});

Use new function

	g("#MyContent").myfunction(options);

How to extend the library (private functions)

Creates a new function

	genrl.fn.extend({
		myfunction:function(options){
			//write code below
		});
	});

Use new function

	genrl.fn.myfunction(options);

Log something to JS console

	genrl.log("Hello World");

Warning something to JS console

	genrl.warn("Hello World");

Info something to JS console

	genrl.info("Hello World");

Error something to JS console

	genrl.error("Hello World");

Use the Source...

The Source be with you...

Si deseas colaborar, haz clic en el enlace abajo:

if do you like to to collab, you can do it by clicking the link below:

--Paypal--

paypal-btn-image-pay

About

JS library that helps you create Web Components / Handle DOM / Events / Webworkers / Websockets / Encrypt/deCrypt / Storage / Fetch / AJAX

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published