Download the PHP package ucscode/uss-element without Composer

On this page you can find all versions of the php package ucscode/uss-element. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package uss-element

Uss Element

A simple, lightweight, standalone PHP library for programmatically creating and manipulating HTML elements. It simplifies the process of working with HTML structures and DOM elements, offering functionality similar to DOMDocument but with reduced boilerplate and enhanced ease of use.

With UssElement, you can effortlessly create DOM nodes, set attributes, set innerHtml, use querySelector, modify element classlist etc, and generate (or render) HTML strings with ease.

Why Uss Element?

UssElement is designed to simplify and streamline the process of working with HTML elements in PHP. If (like me) you've ever been frustrated by the complexity of PHP's DOMDocument or found yourself writing repetitive, cumbersome code just to manipulate HTML structures, UssElement is the solution you’ve been waiting for.

This standalone library takes care of the heavy lifting, reducing boilerplate code and eliminates the need for complex XPath queries, offering a simple, intuitive API for tasks like creating elements, setting inner HTML, and selecting elements using CSS selectors.

The library is lightweight, fast, and easy to integrate into any project, making it perfect for both small and large-scale applications.

Key Features:

Prerequisite

Installation (Composer)

You can include UssElement library in your project using Composer:

Getting Started:

Creating Elements

You can create elements by instantiating the type of node

If you prefer, you can use the NodeNameEnum enum

You can also create an element and set their attributes at the point of instantiation:

You can use many available methods to manipulate the DOM.

A summary of these methods are provided in the following sections:

Traversing Elements

Use the querySelector() or querySelectorAll() method to select elements based on CSS selectors:

You can also retrieve an element by other methods such as:

Inner HTML

Loading HTML

You can convert an HTML string to NodeList containing all elements using the HtmlLoader class:

You can also load framents

Basic Example

Render HTML

You can get or render the ElementNode as HTML using the render() method.

Output

If you want to indent the rendered output, pass an unsigned integer (initially zero) to the render() method

Output

Element Render Visibility

To keep an element in the DOM tree but exclude it from the rendered output, set its visibility to false.

Setting Void Item

Some HTML elements, like <br> and <img>, do not have closing tags.

The setVoid() method marks an element as void, ensuring that it is rendered without a closing tag. This is especially helpful when defining custom elements.


Encoding and Decoding Nodes

This library provides methods for encoding a node into JSON format and decoding it back to its original structure.\ This is useful for transferring nodes between systems or storing them in a format that can be easily reconstructed.

Encoding a Node

To encode a node into JSON format, the toJson() method is used.

The toJson() method internally uses an instance of the NodeJsonEncoder, which is the actual encoder responsible for serializing the node.

Decoding a Node

To decode a JSON string back into a node, use the NodeJsonDecoder class.

The decoding process restores the full structure of the original node, including its attributes, child nodes, and content.

Normalization

Both the NodeJsonEncoder and NodeJsonDecoder provide a normalize method to convert the input into an array.

NodeInterface methods

Method Description Returns
getNodeName Return the name of the current node string
getNodeType Return the node identifier integer
setVisible Set the visibility state of a node when rendered static
isVisible Verify the visibility state of a node when rendered boolean
render Convert the node to string (OuterHTML) string
getParentElement Returns an Element that is the parent of the current node ElementInterface|null
getParentNode Returns a Node that is the parent of the current node NodeInterface|null
getChildNodes Returns a NodeList containing all the children of the current node NodeList
clearChildNodes Remove all the child Nodes from the current element static
appendChild Adds the specified Node argument as the last child to the current node static
prependChild Adds the specified Node argument as the first child to the current node static
getFirstChild Returns a Node representing the last direct child node of the current node NodeInterface|null
getLastChild Returns a Node representing the last direct child node of the node NodeInterface|null
getNextSibling Returns a Node representing the next node in the tree NodeInterface|null
getPreviousSibling Returns a Node representing the previous node in the tree NodeInterface|null
insertBefore Inserts a Node before the reference node as a child of a specified parent node static
insertAfter Inserts a Node after the reference node as a child of a specified parent node static
insertAdjacentNode Inserts a Node at a specific position relative to other child nodes static
hasChild Verify that a node has the provided child node boolean
getChild Get a child node from the Nodelist NodeInterface|null
removeChild Removes a child node from the current element static
replaceChild Replaces one child Node of the current one with the second one given in parameter static
cloneNode Clone a Node, and optionally, all of its contents NodeInterface
sortChildNodes Reorder the child nodes of a specified parent node static
moveBefore Move the current node before a sibling node within the same parent node static
moveAfter Move the current node after a sibling node within the same parent node static
moveToFirst Move the current node to the first position of its relative sibling nodes static
moveToLast Move the current node to the last position of its relative sibling nodes static
moveToIndex Move the current node to a specific position within its sibling nodes static
toJson Converts the node and its descendants into a JSON-encoded string string

ElementInterface methods

Includes:

Method Description Returns
getTagName Return the tag name of the current element string
setInnerHtml Set the inner HTML of the element static
getInnerHtml Get the inner HTML of the element string
setVoid Set whether the element is void (no closing tag) static
isVoid Verify if the element is void, meaning it has no closing tag boolean
getOpenTag Get the opening tag of the element string
getCloseTag Get the closing tag of the element (if any) string|null
getChildren Get a collection of the element's children ElementList
getAttribute Get the value of a specific attribute by name string|null
getAttributes Get a collection of all attributes of the element Attributes
getAttributeNames Get a list of all attribute names of the element array
hasAttribute Check if the element has a specific attribute boolean
hasAttributes Check if the element has any attributes boolean
setAttribute Set the value of a specific attribute static
removeAttribute Remove a specific attribute from the element static
querySelector Find and return the first matching element by the given CSS selector ElementInterface|null
querySelectorAll Find and return all matching elements by the given CSS selector ElementList
getClassList Get a collection of classes of the element ClassList
matches Check if the current element matches the given CSS selector boolean
getElementsByClassName Get all elements with the specified class name ElementList
getElementsByTagName Get all elements with the specified tag name ElementList

TextNode methods

Includes:

Method Description Returns
getData Get the text data string
length The length of the text data integer
isContentWhiteSpace Check if the content of the text node is empty or contains only whitespace boolean

Collection Objects

PHP Class Description
Attributes Manages attributes of an element.
ClassList Handles class names for an element.
ElementList A collection of ElementInterface types.
NodeList A collection of any node types.

Node Objects

PHP Class Description
CommentNode Represents HTML comments.
DocumentTypeNode Represents the <!DOCTYPE> declaration.
ElementNode Represents HTML elements.
TextNode Represents textual content.

Parser Objects

PHP Class Description
HtmlLoader Parses an HTML string into nodes.
Matcher Matches nodes against CSS selectors.
Tokenizer Breaks down CSS selectors into tokens.
Transformer Encodes and decodes CSS selectors.
NodeSelector Finds descendants matching CSS selectors.
NodeJsonEncoder Encodes a node and its descendants into JSON format
NodeJsonDecoder Decodes a node JSON back into a node instance.

Providing Support For:

Contributing

Feel free to open issues or submit pull requests. We welcome contributions to improve the library.

How to Contribute

  1. Fork the repository.
  2. Create a new branch (git checkout -b feature-xyz).
  3. Commit your changes (git commit -am 'Add feature xyz').
  4. Push to the branch (git push origin feature-xyz).
  5. Create a new pull request.

License

This project is licensed under the MIT License - see the LICENSE file for details.


All versions of uss-element with dependencies

PHP Build Version
Package Version
Requires php Version >=8.2
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package ucscode/uss-element contains the following files

Loading the files please wait ....