Finds one element, via querySelector
.
Finds multiple elements, via querySelectorAll
.
Finds the element that first matches queryParent among the parent elements. If no queryParent is passed it will return the first parent of the element.
Finds multiple elements that matches queryParent among the parent elements.
Wraps classList.add
. The parameter query could be also an array of elements. The parameter classList can be a string or array of strings.
addClass('#target', 'class')
addClass('#target', ['class_one', 'class_two'])
Wraps classList.remove
. The parameter query could be also an array of elements. The parameter classList can be a string or array of strings.
removeClass('#target', 'class')
removeClass('#target', ['class_one', 'class_two'])
Wraps classList.toggle
. The parameter query could be also an array of elements. If the parameter classValue is given, adds or deletes the class depending on this boolean.
Wraps classList.contains
.
Gets/sets query
element attribute. It also accepts an object for multiple assignment. Examples:
// getter
attr('#main_menu', 'class')
// setters
attr('#main_menu', 'class', 'foo')
attr('#form input.name', { class: 'input-large', required: true })
Remove query
element attribute. It also accepts an array of attributes. Examples:
removeAttr('#main_menu', 'remote')
// array of attributes
removeAttr('#main_menu', ['remote', 'url'])
Similar to attr()
, but for dataset
. Examples:
// getters
data('#form')
// { remote: false, url: '/signup' }
data('#form', 'remote')
// "false"
// setters
data('#form', 'remote', true)
data('#form', { remote: true, url: '/signup/free_trial' })
Similar to removeAttr()
, but for dataset
. If no attribute or attributes are passed all dataset attributes will be deleted. Examples:
removeData('form', 'remote')
// all dataset attributes
removeData('form')
// array of dataset attributes
removeData('form', ['remote', 'url'])
Inserts passed html
to the query
element, based on position
. The argument position
accepts the following options: inner (default), prepend, append, begin, end. Examples:
insertHTML('.total', `Total: <b>${totalItems}</b>`)
insertHTML('ul.items', '<li>new item</li>', 'end')
You can also insert Element instances:
insertHTML('body', elem('footer'), 'end')
Creates and returns an HTML element and assigns given attributes
. Example:
elem('input', { type: 'numeric', class: 'input-number' })
// <input type="numeric" class="input-number">
Renders the template
, passing the given data
. Example:
render('itemCard', {
title: item.title,
description: item.description
})
NOTE The templates should be defined as JavaScript Functions and injected into the App
object.
Serializes the given form. Example:
<form id="form">
<input type="text" name="x" value="1">
<input type="text" name="y" value="2">
</form>
serialize("#form")
// "x=1&y=2"
It could also be used for hash elements like the example below:
serialize({ x: "1", y: "2" })
// "x=1&y=2"
If rails_ujs
is provided in new RalixApp()
, submits the form via Rails.fire
, otherwise uses requestSubmit
(if available) or submit
.
Reloads current page.
Navigates to the given url
, uses Turbo.visit
(or Turbolinks.visit
) if possible.
It returns the user to the previous page (via history.back()
). If there is no previous page or the referrer has a different hostname than the current one, it will navigate to the fallback url visit(fallbackUrl)
.
Returns the current location.
Gets param
value from current location. Example (assuming ?a=1&b=2
):
getParam('a')
// '1'
If you don't pass any argument, it will return all current parameters:
getParam()
// { a: '1', b: '2' }
Sets value
to param
and updates browser history (via pushState
). If value
is null
, parameter is deleted. Examples:
setParam('a', 1)
// 'http://localhost:1234/?a=1'
setParam('a')
// 'http://localhost:1234/'
You can also set multiple values at once by passing an object:
setParam({ a: 1, b: 2 })
// 'http://localhost:1234/?a=1&b=2'
Wraps addEventListener
. Example:
on(document, 'click', (e) => {
addClass('.welcome-message', 'hide')
}, { once: true })
Accepts multiple events:
on('.input-submit', 'change keyup', (e) => {
submit('#form')
})
NOTE on
performs preventDefault()
on click
events for interactive elements (links, buttons and inputs).
Returns the element which received the current fired event.
Returns the current event.
Wraps fetch
. Adds the object params
to path
or options.body
depending on options.method
.
The object options
can include the same options as fetch
such as headers, body, credentials, method, etc. with the additional option format. The default options are GET for options.method
and include for options.credentials
.
Returns the response body in text. If the argument options.format
is json the response body will be returned in json format.
Examples:
ajax('/path/resource')
ajax('/path/resource', { params: { id: 1 }, options: { method: 'POST' }})
ajax('/path/resource', { options: { format: 'json' }})
Alias for ajax
method with options.method
as GET. Example:
get('/list').then((result) => {
insertHTML('#list', result)
})
Alias for ajax
method with options.method
as POST. Example:
post('/comment', { params: { message: 'hello!' }}).then((content) => {
insertHTML('#comments', `<p>${content}</p>`, 'end')
})