const rand = (max, min = 0) =>
Math.floor(Math.random() * (max - min)) + min;
const createArr = ({
length,
digit,
digitCount,
max = Number.MAX_SAFE_INTEGER,
}) =>
Array.from({ length }, function() {
const digits = `${rand(max, 10 ** (digitCount - !!digit))}`
.replace(RegExp(digit, 'g'), (_, i) => this[rand(this.length, +!(i || digit))])
.split('');
const index = [...digits.keys()].slice(+!digit);
for (let i = 0; i < digitCount; i++) {
digits.splice(index.splice(rand(index.length), 1)[0], 1, digit);
}
return +digits.join('');
}, [...Array(10).keys()].filter(n => n !== digit));const arr = createArr({
length: 5,
digit: 1,
digitCount: 2,
max: 10 ** 5,
});
const tbody = document.querySelector('#test tbody');
const keys = [ 'name.firstName', 'name.lastName', 'about', 'eyeColor' ].map(n => n.split('.'));
const getVal = (obj, keys) => keys.reduce((p, c) => p != null ? p[c] : p, obj);for (const n of data) {
keys.forEach(function(k) {
this.insertCell().textContent = getVal(n, k);
}, tbody.insertRow());
}
// или
tbody.insertAdjacentHTML('beforeend', data
.map(n => `
<tr>${keys.map(k => `
<td>${getVal(n, k)}</td>`).join('')}
</tr>`)
.join('')
);
AutoNumeric.multiple('.numeric', {
decimalCharacter : '.',
digitGroupSeparator : ' ',
})
<div id="images">
<img src="https://placehold.co/200x200/FF0000/FFFFFF/png">
<img src="https://placehold.co/200x200/00FF00/000000/png">
<img src="https://placehold.co/200x200/0000FF/FFFFFF/png">
</div>#images img {
transition: transform 0.7s;
}.rotate {
transform: rotateY(180deg);
}const toggleRotate = el => el.classList.toggle('rotate');
document.querySelectorAll('#images img').forEach((n, i) => {
setTimeout(setInterval, 300 * i, toggleRotate, 2000, n);
});#images img {
animation: rotate 4s infinite;
}
#images img:nth-child(1) { animation-delay: 0s; }
#images img:nth-child(2) { animation-delay: 0.3s; }
#images img:nth-child(3) { animation-delay: 0.6s; }
@keyframes rotate {
0%, 75%, 100% {
transform: rotateY(0deg);
}
25%, 50% {
transform: rotateY(180deg);
}
}
messages.sort((a, b) => {
[ a, b ] = [ a, b ].map(n => sortableLanguages.indexOf(n.language));
return a === -1 ? 1 : b === -1 ? -1 : a - b;
});const sorted = (arr, key) => arr
.map(n => [ n, key(n) ])
.sort((a, b) => a[1] - b[1])
.map(n => n[0]);
const order = Object.fromEntries(sortableLanguages.map((n, i) => [ n, i + 1 ]));
const sortedMessages = sorted(messages, n => order[n.language] || Number.MAX_SAFE_INTEGER);function sorted(arr, order, key) {
const ordered = new Map(order.map(n => [ n, [] ]));
const unordered = [];
arr.forEach(n => (ordered.get(key(n)) || unordered).push(n));
return [].concat(...ordered.values(), unordered);
}
const sortedMessages = sorted(messages, sortableLanguages, n => n.language);
const buttonSelector = '.one';
const contentSelector = '.two';
const className = 'three';document.querySelector(buttonSelector).addEventListener('click', () => {
document.querySelector(contentSelector).classList.toggle(className);
});document.addEventListener('click', e => {
const button = e.target.closest(buttonSelector);
if (button) {
const index = [...document.querySelectorAll(buttonSelector)].indexOf(button);
document.querySelectorAll(contentSelector)[index].classList.toggle(className);
}
});
// или
const buttons = document.querySelectorAll(buttonSelector);
const contents = document.querySelectorAll(contentSelector);
buttons.forEach(n => n.addEventListener('click', onClick));
function onClick(e) {
const index = Array.prototype.indexOf.call(buttons, e.currentTarget);
contents[index].classList.toggle(className);
}
function App() {
const [ text, setText ] = React.useState('');
const append = e => setText(text + e.target.textContent);
const clear = () => setText('');
return (<>
<div className="row">
<textarea value={text} readOnly />
</div>
<div className="row">
{Array.from({ length: 10 }, (_, i) => (
<button onClick={append}>{i}</button>
))}
</div>
<div className="row">
<button onClick={clear}>clear</button>
</div>
</>);
}.row {
display: flex;
justify-content: center;
padding: 5px;
gap: 5px;
}
for (let i = 0; i < password.length; i + 1) {если запустить код то страница крашнется, codesandbox на счет этого говорит что циклов слишком много
i + 1 - счётчик не меняет своего значения, цикл получается бесконечным.i += 1 или i++.return pass;return text.
const mustStay = arr => arr.some(n => n !== '');for (let i = 0; i < arr.length; i++) {
if (!mustStay(arr[i])) {
for (let j = i--; ++j < arr.length; arr[j - 1] = arr[j]) ;
arr.pop();
}
}
// или
arr.reduceRight((_, n, i, a) => mustStay(n) || a.splice(i, 1), null);
// или
arr.splice(0, arr.length, ...arr.filter(mustStay));
// или
arr.length -= arr.reduce((acc, n, i, a) => (
a[i - acc] = n,
acc + !mustStay(n)
), 0);
usort($variants, function($a, $b) {
return strcmp($a->name, $b->name);
});
[...divs.keys()].forEach(i => console.log(i));
// или
console.log(Array.from(divs.keys(), i => i * 100));
// или
for (const i of divs.keys()) {
console.log(i);
}
$unique = array_values(array_combine(array_column($arr, 'name'), $arr));