Skip to content

Latest commit

 

History

History
304 lines (207 loc) · 12.5 KB

Element.md

File metadata and controls

304 lines (207 loc) · 12.5 KB

class Element

class Element represents DOM element and extends Node and so all its methods are available on element.

Properties:

  • element.id

  • element.elementIndex

  • element.tagName

  • element.tag - lower case version of .tagName

  • element.className

  • element.innerHTML

  • element.outerHTML

  • element.innerText


  • element.firstElementChild
  • element.lastElementChild
  • element.nextElementSibling
  • element.previousElementSibling
  • element.childElementCount

  • element.value

  • element.style - returns reference to Element.Style class.

  • element.state - returns reference to Element.State class (Sciter.JS specific).

  • element.classList :

    • element.classList.item(n)
    • element.classList.add(name, ...)
    • element.classList.remove(name, ...)
    • element.classList.toggle(name [,force: bool])
    • element.classList.contains(name)
    • element.classList.length
    • element.classList.entries() - array, list of classes
  • element.children : list of child DOM elements

    • element.children[n] - Nth child element;
    • element.children.item(n) - Nth child element;
    • element.children.length: integer - quantity of children;
    • for(let child of element.children) - iteration of children.
  • element.disabled

  • element.readonly

  • element.src

Methods:

  • element.appendChild(node)

    adds a node to the end of the list of children of the element

  • element.insertBefore(node, refNode)

    adds a node to the end of the list of children of the element

  • element.insertAfter(node, refNode)

    inserts a node before a reference node as a child of the element.

  • element.removeChild(node) : node

    removes a child node from the DOM and returns the removed node.

  • element.replaceChild(newNode,oldNode)

    replaces a child oldNode by the newNode.

  • element.childElement(n) : element

    returns n-th child element; n is in [0, element.childElementCount) range.

  • element.insertAdjacentHTML(where, html)

    See insertAdjacentHTML.

  • element.swapWith(otherElement)

    Swap DOM locations of the element and otherElement.
    Elements should be compatible - it is not possible to swap <td> and <li> for example.


  • element.querySelector(selector)
  • element.$(selector)

  • element.querySelectorAll(selector)
  • element.$$(selector)

  • element.$p(selector) parent element selector
  • element.$o(selector) owner element selector, useful to get owner of menu.

  • element.hasAttribute(attribute)
  • element.getAttribute(attribute)
  • element.getAttributeNames()
  • element.removeAttribute(attribute)
  • element.setAttribute(attribute, value)

  • element.scrollTo(x,y)

    sets scroll position of scrollable.

  • element.scrollTo(options)

sets scroll position of scrollable. options is an object with fields:

  • left - x scroll position;

  • top - y scroll position;

  • behavior : "instant" | "smooth", if smooth performs animated scroll;

  • element.scrollIntoView([toTop:true])

scrolls this element into scrollable view - makes it visible - not occluded.

  • element.scrollIntoView(options)

scrolls this element into scrollable view - makes it visible - not occluded. options is an object with fields:

  • behavior : "instant" | "smooth", if smooth performs animated scroll;
  • block : "start" | "nearest" - defines vertical position;

  • element.click() - generates click event on the element
  • element.focus() - sets input focus to the element

  • element.addEventListener(name, eventHandler [,flags])
  • element.removeEventListener(name, eventHandler)
  • element.dispatchEvent(event)
  • element.postEvent(event) sciter specific, async version of .dispatchEvent()

Methods (Sciter specific):

  • element.on(eventname: string, [selector: string,] handler: function): Element

    jQuery style event subscription:

    • eventname may start with ^ for handling events in capturing phase;
    • eventname may contain namespace part: "click.myns" ;
    • the handler is called with this set to element matching the selector;
    • the method returns element itself allowing to chain on calls;
  • element.off(eventname: string): Element

    Unsubscribe event handlers either by name "click" or by namespace ".myns".

  • element.off(handler: function): Element

    Unsubscribe event handlers by function reference;

  • element.onGlobalEvent(eventname: string, handler: function): Element

    jQuery style event subscription to application wide events:

    • eventname may contain namespace part: "click.myns" ;
    • the handler is called with this set to the element;
    • the method returns element itself allowing to chain onGlobalEvent calls;

    The element gets unsubscribed automatically when it gets disconnected from DOM.

    See global-events for the rationale.

  • element.offGlobalEvent([eventname: string | handler: function]): Element

    Unsubscribe event handlers either by name "click" or by namespace ".myns" or by handler reference. If no parameter provided then the function will unsubscribe this element from any global event.

  • element.timer(milliseconds, callback: function): true | false

    Starts timer on element. If the element already has timer with that callback it first gets removed and new timer started instead. This allows to implement effective throttling. If the callback function returns true value then the timer will keep ticking (like interval timer). The callback is called with this set to the element.

  • element.post(function | event [, avoidDuplicates: true | false] )

    Posts either function or event to event queue.

    element.post(function) conceptually is equivalent to setTimeout(function,0) but with two differences:

    1. The function will be called with this set to the element;
    2. If avoidDuplicates is true (default value) element.post checks input queue before sending and if input queue already contains that element/function pair the function will be called only once.

    element.post(event) is equivalent to element.dispatchEvent() but instead of immediate dispatch execution it will post the event into event queue for later execution.


  • element.checkCommand(command [, params]): flags
  • element.executeCommand(command [, params]): flags

    Support of editing input elements: <htmlarea> (WYSIWYG editor), <plaintext> (multiline text editor), <textarea> and <input|text>. TBD.

  • element.xcall(name:string [, arg0, ..., argN]): any

    Interaction with native behaviors attached to the element. element.xcall("foo") will end up in handle_scripting_call() of native behavior attached to the element.

  • element.paintBackground = function(graphics)
  • element.paintForeground = function(graphics)
  • element.paintContent = function(graphics)
  • element.paintOutline = function(graphics)

    Immediate mode drawing "ports". Functions assigned to these properties will be called when the element is rendered on screen so they can draw anything on top (or below) of default HTML/CSS rendering.

  • element.requestPaint()

    Schedules re-paint of the element. This will trigger element.paintXXXX later calls (if any). On Windows this will end up in InvalidateRect call.

  • element.popup(popup:Element | VNode, params : Object )

    Shows the popup element or VNode (JSX) in out-of-canvas popup window on desktop. Params is an object that may have following fields:

    • anchorAt - 1..9, reference point on anchor border box (see keyboard numpad for the meaning);
    • popupAt - 1..9, reference point on popup's margin box;
    • x, y - optional, explicit window coordinates of popupAt point.

    Engine tries to replace popup so popupAt position is at anchorAt on screen.

  • element.animate(changer:function,params:object)

    various animation effects, where params contains following fields:

    • params.duration - integer, milliseconds - duration of the animation;

    • params.ease - string, name of ease function, one of:

      "linear","ease","ease-in","ease-in-out","ease-out","quad-in","quad-out","quad-in-out","cubic-in","cubic-out","cubic-in-out", "quart-in","quart-out","quart-in-out","quint-in","quint-out","quint-in-out","sine-in","sine-out","sine-in-out", "expo-in","expo-out","expo-in-out","circ-in","circ-out","circ-in-out","elastic-in","elastic-out","elastic-in-out", "back-in","back-out","back-in-out","x-back-in","x-back-out","x-back-in-out","xx-back-in","xx-back-out","xx-back-in-out", "bounce-in","bounce-out","bounce-in-out";

    • params.effect - string, name of transition method, one of:

      • "blend",
      • "blend-atop",
      • "slide-top",
      • "slide-bottom",
      • "slide-left",
      • "slide-right",
      • "slide-over-top",
      • "slide-over-bottom",
      • "slide-over-left",
      • "slide-over-right",
      • "remove-top",
      • "remove-bottom",
      • "remove-left",
      • "remove-right",
      • "scroll-top",
      • "scroll-bottom",
      • "scroll-left",
      • "scroll-right"
  • element.animate(step:function,params:object)

    The method offers "manual" animation support. The step function has following signature function step(progress:0.0 ... 1.0): true | false

    Sciter will call step function with animation frame rate passing current progress value. If the function returns false animation stops.

    params may contain following fields:

    • params.duration - integer, optional, milliseconds - duration of the animation;
    • params.ease - string, optional, name of ease function, see params.ease above. This parameter determines curvature of progress values.
    • params.FPS - integer, times per second - frequency of the step function calls;

  • element.takeOff([params:object])

    Make the element "airborn" - to be replaced outside of host window. params are:

    • params.x,params.y - numeric, element coordinates, screen pixels - new position of DOM element;
    • params.width,params.height - optional, numeric, new dimensions in screen pixels;
    • relativeTo - string, defines meaning of x and y, one of: "screen","document","window","parent" or "self"
    • window - string, defines type of window that will host the element, one of:
      • "attached" - attached window, will move in sync with the host window;
      • "detached" - detached window, position will be independent from the host window;
      • "popup" - same as "detached" window, put also will be placed as topmost - on top of other windows on desktop.
  • element.append( vnode )

    appends element defined by JSX expression:

    list.append(<li>yet another item</li>);
  • element.prepend( vnode )

    insert the element as the first child

  • element.content( vnode )

    replaces element content by the VNode

  • element.patch( vnode [, onlyChildren:true] )

    patches content of the element by vnode using rules of React[or]. If second parameter is provided and is true the function patches only children but not element itself.

  • element.componentUpdate( obj )

    patch properties and enqueue rendering, does roughly the following:

    if(Object.assignIf(element,obj))    // 1. merge properties and if they are different
       element.post( (element) => {     // 2. enqueue update
         var vnode = element.render();  // 3. calls .render() that must return vnode (JSX expression)
         element.patch(vnode);          // 4. reconciliation / patching
       });
  • element.rangeFromPoint(x,y) : Range | null

    Returns collapsed range (caret position) at point x/y. x/a are local coordinates - relative to origin of element's inner box.