Dynamic Elements
Below are examples of elements injected into the DOM after the
window.DOMContentLoaded
event.
Filled input
window.addEventListener('DOMContentLoaded', () => {
function addFilledInput() {
const filledInputDiv = document.createElement('div');
filledInputDiv.className = 'form-filled';
const filledInput = document.createElement('input');
filledInput.className = 'form-control';
filledInput.id = 'firstNameFilled';
filledInput.type = 'text';
const filledInputLabel = document.createElement('label');
filledInputLabel.textContent = 'First Name';
filledInputLabel.className = 'form-label';
filledInputLabel.setAttribute('for', 'firstNameFilled');
const filledInputHelper = document.createElement('span');
filledInputHelper.textContent = 'Example helper text';
filledInputHelper.className = 'form-helper';
filledInputDiv.append(filledInput, filledInputLabel, filledInputHelper);
document.getElementById('insert-filled-input').append(filledInputDiv);
}
addFilledInput();
});
Selects
window.addEventListener('DOMContentLoaded', () => {
async function getUsers() {
try {
const response = await fetch(
'https://jsonplaceholder.typicode.com/users',
);
const data = await response.json();
return data;
} catch (error) {
console.error(error);
}
}
function addFilledSelect() {
const newFilledSelectTemplateString = `
<select class="select-filled" id="inserted-filled">
<option value="1">Option 1</option>
<option value="2">Option 2</option>
<option value="3">Option 3</option>
</select>
<label class="form-label select-label" for="inserted-filled">Inserted select</label>
`;
document.getElementById('insert-filled-select').innerHTML =
newFilledSelectTemplateString;
}
addFilledSelect();
function addSelect() {
const newSelect = document.createElement('select');
newSelect.classList.add('select');
newSelect.id = 'newSelect';
const newSelectLabel = document.createElement('label');
newSelectLabel.textContent = 'Select';
newSelectLabel.classList.add('form-label', 'select-label');
newSelectLabel.setAttribute('for', 'newSelect');
const initialOption = document.createElement('option', {
value: '',
});
initialOption.textContent = 'Select one:';
newSelect.append(initialOption);
document
.getElementById('insert-select')
.append(newSelect, newSelectLabel);
}
addSelect();
getUsers()
.then((users) => {
users.forEach((element) => {
const option = document.createElement('option');
option.value = element.username;
option.textContent = element.name;
document.getElementById('newSelect').append(option);
});
})
.catch((err) => console.error(err));
});
Drawer
Add drawer here
window.addEventListener('DOMContentLoaded', () => {
const newDrawerTemplateString = `
<button
type="button"
class="btn btn-primary"
data-mdb-toggle="drawer"
data-mdb-target="#slide-out"
>
Open Drawer
</button>
<aside id="slide-out" class="drawer">
<div class="drawer-container">
<header class="drawer-header">
<h2 class="drawer-header-title h4">Drawer</h2>
<div class="drawer-header-content">
<button
aria-label="Close drawer"
class="btn btn-floating btn-flat"
data-mdb-target="#slide-out"
data-mdb-toggle="drawer"
type="button"
>
<span class="material-icons">close</i>
</button>
</div>
</header>
<div class="drawer-content">
<div key="content">
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Vestibulum
vel varius erat, et iaculis magna. Donec maximus mauris ut ipsum
lobortis sagittis. Nunc fringilla est ac sapien commodo porttitor. Sed
leo ipsum, fringilla sit amet ultricies a, mattis nec ex. In metus
ante, ultrices sit amet tempus non, rhoncus non dui. Vestibulum
sollicitudin nec tortor ut accumsan. Suspendisse a bibendum nunc.
Praesent ultrices lorem posuere sollicitudin posuere.
</p>
</div>
</div>
</div>
</aside>
`;
document.getElementById('addDrawer').innerHTML = newDrawerTemplateString;
});