Skip to content

Collection of personal sets of functions to speed up web development.

License

Notifications You must be signed in to change notification settings

c3r38r170/c3tools

Repository files navigation

c3tools

Collection of personal sets of functions to speed up web development.

To install just <script src="https://unpkg.com/@c3r38r170/c3tools" type="module"></script>.

Specifying a version is recommended. More info about unpkg.

By default, c3tools-min.js will be loaded (non-module version). You must specify /c3tools-min.m.js after the version, for the module version:

<script src="https://unpkg.com/@c3r38r170/[email protected]/c3tools-min.m.js" type="module"></script>

Main Features:

SuperQuerySelector (SqS)

One Element selecting method to rule them all. Encapsulates all getElement... methods, querySelector and querySelectorAll, and uses the apropriate one depending on the selector.

SqS('#id'); // Actually uses document.getElementById.
SqS('.class',{n:true}); // Actually uses document.getElementsByClassName. Returns all results.
SqS('button',{from:gEt('modal')}); // Actually uses from.getElementsByTagName. Returns first result.
// gEt is short for getElementById btw.
SqS('#id span, #id b',{n:true}); // Actually uses querySelectorAll. Returns all results.

DOM building using JS objects

c3tools Resulting HTML
createElement('DIV',{
  children:[
    ['H2',{
      innerText:'Fito Paez'
    }]
    ,['P',{
      innerText:'Él fue un gran cantautor'
    }]
  ]
  ,class:'cantante'
  ,dataset:{
    value:2
  }
});
<div
  class="cantante"
  data-value="2"
>
  <h2>Fito Paez</h2>
  <p>Él fue un gran cantautor</p>
</div>

This is the main point of the library, so it has some interesting stuff you may want to check out in the wiki.

A very simple and fun to use wrapper around fetch.

An enumeration of data types called Types, and a couple fine functions:

  • is(smt:any,type:Types):boolean
  • whatIs(smt:any):Types

This is actually for internal use, but is available anyways.

TO DO

  • Make the module version the default.
  • Document functions here (with examples).
  • Better README.
  • The "Soon!" stuff.

download function.

Group functions and variables in logical modules.

Easy way to add functions to the 'DOMContentLoaded' event.

Create .js.map files.

Modal messages with premises.

Reacting to DOM changes.


Any suggestion or feedback is welcome.

About

Collection of personal sets of functions to speed up web development.

Resources

License

Stars

Watchers

Forks

Packages

No packages published