Tutorial

Tilda Hacks: Π‘ΠΎΠ·Π΄Π°Π΅ΠΌ кастомныС Ρ‚Π°Π±Ρ‹ Π² Zero Block с ΠΏΠΎΠΌΠΎΡ‰ΡŒΡŽ Autolayout ΠΈ JS

НазваниС: Π“ΠΈΠ±ΠΊΠΈΠ΅ Ρ‚Π°Π±Ρ‹ Π² Tilda: БвязываСм Zero Block ΠΈ ΠΊΠΎΠ½Ρ‚Π΅Π½Ρ‚Π½Ρ‹Π΅ Π±Π»ΠΎΠΊΠΈ Ρ‡Π΅Ρ€Π΅Π· Autolayout

Π’ этом Π³Π°ΠΉΠ΄Π΅:

  • Пошаговая настройка ΠΊΠ½ΠΎΠΏΠΎΠΊ-Π³Ρ€ΡƒΠΏΠΏ Π² Zero Block.
  • Π“ΠΎΡ‚ΠΎΠ²Ρ‹ΠΉ JS-скрипт для ΠΏΠ΅Ρ€Π΅ΠΊΠ»ΡŽΡ‡Π΅Π½ΠΈΡ Π±Π»ΠΎΠΊΠΎΠ² ΠΏΠΎ ID.
  • Π›Π°ΠΉΡ„Ρ…Π°ΠΊΠΈ ΠΏΠΎ стилизации Π°ΠΊΡ‚ΠΈΠ²Π½Ρ‹Ρ… Π²ΠΊΠ»Π°Π΄ΠΎΠΊ (скруглСниС, Ρ†Π²Π΅Ρ‚, ΡˆΡ€ΠΈΡ„Ρ‚Ρ‹).
  • ΠžΠΏΡ‚ΠΈΠΌΠΈΠ·Π°Ρ†ΠΈΡ ΠΏΠΎΠ΄ ΠΌΠΎΠ±ΠΈΠ»ΡŒΠ½Ρ‹Π΅ устройства ΠΈ Lazy Load.
МногиС Π΄ΠΈΠ·Π°ΠΉΠ½Π΅Ρ€Ρ‹ ΡΡ‚Π°Π»ΠΊΠΈΠ²Π°ΡŽΡ‚ΡΡ с Ρ‚Π΅ΠΌ, Ρ‡Ρ‚ΠΎ стандартный Π±Π»ΠΎΠΊ Π²ΠΊΠ»Π°Π΄ΠΎΠΊ (ME602) ΠΎΠ³Ρ€Π°Π½ΠΈΡ‡ΠΈΠ²Π°Π΅Ρ‚ Π΄ΠΈΠ·Π°ΠΉΠ½. ΠœΡ‹ Ρ…ΠΎΡ‚ΠΈΠΌ, Ρ‡Ρ‚ΠΎΠ±Ρ‹ ΠΊΠ½ΠΎΠΏΠΊΠΈ Π±Ρ‹Π»ΠΈ ΡƒΠ½ΠΈΠΊΠ°Π»ΡŒΠ½Ρ‹ΠΌΠΈ, Π½Π°Ρ…ΠΎΠ΄ΠΈΠ»ΠΈΡΡŒ Π² Zero Block ΠΈ управляли ΠΊΠΎΠ½Ρ‚Π΅Π½Ρ‚ΠΎΠΌ ΠΏΠΎ всСй страницС. Π’ этом Π³Π°ΠΉΠ΄Π΅ я ΠΏΠΎΠΊΠ°ΠΆΡƒ, ΠΊΠ°ΠΊ это Ρ€Π΅Π°Π»ΠΈΠ·ΠΎΠ²Π°Ρ‚ΡŒ с ΠΏΠΎΠΌΠΎΡ‰ΡŒΡŽ Autolayout ΠΈ нСбольшого скрипта.

Π¨Π°Π³ 1. ΠŸΠΎΠ΄Π³ΠΎΡ‚ΠΎΠ²ΠΊΠ° ΠΊΠΎΠ½Ρ‚Π΅Π½Ρ‚Π°

Π‘ΠΎΠ·Π΄Π°ΠΉΡ‚Π΅ Π½Π° страницС Π±Π»ΠΎΠΊΠΈ, ΠΊΠΎΡ‚ΠΎΡ€Ρ‹Π΅ Π΄ΠΎΠ»ΠΆΠ½Ρ‹ ΠΏΠ΅Ρ€Π΅ΠΊΠ»ΡŽΡ‡Π°Ρ‚ΡŒΡΡ. Π­Ρ‚ΠΎ ΠΌΠΎΠ³ΡƒΡ‚ Π±Ρ‹Ρ‚ΡŒ ΠΊΠ°ΠΊ Zero Block, Ρ‚Π°ΠΊ ΠΈ стандартныС Π±Π»ΠΎΠΊΠΈ.

  • Π—Π°ΠΉΠ΄ΠΈΡ‚Π΅ Π² Настройки ΠΊΠ°ΠΆΠ΄ΠΎΠ³ΠΎ Π±Π»ΠΎΠΊΠ° ΠΈ скопируйтС Π΅Π³ΠΎ ID (Π½Π°ΠΏΡ€ΠΈΠΌΠ΅Ρ€, #rec123456789).
  • Π’Ρ‹ΠΏΠΈΡˆΠΈΡ‚Π΅ эти ID, сгруппировав ΠΈΡ… ΠΏΠΎ Π²ΠΊΠ»Π°Π΄ΠΊΠ°ΠΌ.

Π¨Π°Π³ 2. Π‘ΠΎΠ·Π΄Π°Π½ΠΈΠ΅ ΠΊΠ½ΠΎΠΏΠΎΠΊ Π² Zero Block (настройка Π²ΠΊΠ»Π°Π΄ΠΎΠΊ)

  1. Π‘ΠΎΠ·Π΄Π°ΠΉΡ‚Π΅ тСкстовый элСмСнт для названия Π²ΠΊΠ»Π°Π΄ΠΊΠΈ.
  2. Π’Ρ‹Π΄Π΅Π»ΠΈΡ‚Π΅ тСкст ΠΈ ΠΏΡ€Π΅Π²Ρ€Π°Ρ‚ΠΈΡ‚Π΅ Π΅Π³ΠΎ Π² Π³Ρ€ΡƒΠΏΠΏΡƒ (Right Click -> Group).
  3. Π’ ΠΏΡ€Π°Π²ΠΎΠΉ ΠΏΠ°Π½Π΅Π»ΠΈ настроСк Π²ΠΊΠ»ΡŽΡ‡ΠΈΡ‚Π΅ Autolayout. НастройтС Ρ†Π²Π΅Ρ‚ Π³Ρ€ΡƒΠΏΠΏΡ‹, отступы, ΠΎΠ±Π²ΠΎΠ΄ΠΊΡƒ ΠΈ скруглСниС (Π½Π°ΠΏΡ€ΠΈΠΌΠ΅Ρ€, 30px).
  4. Π’Π°ΠΆΠ½ΠΎ: Π’ ΠΏΠΎΠ»Π΅ CSS Class Name для ΠΊΠ°ΠΆΠ΄ΠΎΠΉ Ρ‚Π°ΠΊΠΎΠΉ Π³Ρ€ΡƒΠΏΠΏΡ‹ ΠΏΡ€ΠΎΠΏΠΈΡˆΠΈΡ‚Π΅ my-tab-btn.
  5. Π’ ΠΏΠΎΠ»Π΅ URL (ссылка) ΠΏΡ€ΠΎΠΏΠΈΡˆΠΈΡ‚Π΅ якоря: #tab1 для ΠΏΠ΅Ρ€Π²ΠΎΠΉ ΠΊΠ½ΠΎΠΏΠΊΠΈ, #tab2 для Π²Ρ‚ΠΎΡ€ΠΎΠΉ ΠΈ Ρ‚Π°ΠΊ Π΄Π°Π»Π΅Π΅.

Π¨Π°Π³ 3.Установка Β«ΠΌΠΎΠ·Π³ΠΎΠ²Β»: ДобавляСм Π±Π»ΠΎΠΊ Π’123

Π§Ρ‚ΠΎΠ±Ρ‹ магия Π·Π°Ρ€Π°Π±ΠΎΡ‚Π°Π»Π°, Π½Π°ΠΌ Π½ΡƒΠΆΠ΅Π½ скрипт. Он сдСлаСт Ρ‚Ρ€ΠΈ Π²Π΅Ρ‰ΠΈ: скроСт лишнСС, подсвСтит Π°ΠΊΡ‚ΠΈΠ²Π½ΡƒΡŽ ΠΊΠ½ΠΎΠΏΠΊΡƒ ΠΈ ΠΏΠΎΠΊΠ°ΠΆΠ΅Ρ‚ Π½ΡƒΠΆΠ½Ρ‹ΠΉ ΠΊΠΎΠ½Ρ‚Π΅Π½Ρ‚.

  • Π”ΠΎΠ±Π°Π²ΡŒΡ‚Π΅ Π±Π»ΠΎΠΊ Π’123 Π² самый Π½ΠΈΠ· страницы.
  • Π‘ΠΊΠΎΠΏΠΈΡ€ΡƒΠΉΡ‚Π΅ ΠΈ Π²ΡΡ‚Π°Π²ΡŒΡ‚Π΅ ΠΊΠΎΠ΄ (ΠΊΠΎΠ΄ Π±Π΅Ρ€Π΅ΠΌ ΠΈΠ· нашСй пСрСписки Π²Ρ‹ΡˆΠ΅).
  • Π’ Π½Π°Ρ‡Π°Π»Π΅ ΠΊΠΎΠ΄Π° Π½Π΅ Π·Π°Π±ΡƒΠ΄ΡŒΡ‚Π΅ ΠΏΠ΅Ρ€Π΅Ρ‡ΠΈΡΠ»ΠΈΡ‚ΡŒ ID Π²Π°ΡˆΠΈΡ… Π±Π»ΠΎΠΊΠΎΠ² Π² ΡΠΎΠΎΡ‚Π²Π΅Ρ‚ΡΡ‚Π²ΡƒΡŽΡ‰ΠΈΡ… Π³Ρ€ΡƒΠΏΠΏΠ°Ρ….
<style>
/* Π‘ΠΊΡ€Ρ‹Π²Π°Π΅ΠΌ ΠΊΠΎΠ½Ρ‚Π΅Π½Ρ‚Π½Ρ‹Π΅ Π±Π»ΠΎΠΊΠΈ (ΠΊΡ€ΠΎΠΌΠ΅ ΠΏΠ΅Ρ€Π²ΠΎΠ³ΠΎ Ρ‚Π°Π±Π°) ΠΏΡ€ΠΈ Π·Π°Π³Ρ€ΡƒΠ·ΠΊΠ΅ страницы */
/* ΠŸΠ΅Ρ€Π΅Ρ‡ΠΈΡΠ»ΠΈΡ‚Π΅ здСсь ID всСх Π±Π»ΠΎΠΊΠΎΠ² ΠΈΠ· Ρ‚Π°Π±ΠΎΠ² 2, 3 ΠΈ Ρ‚.Π΄. Ρ‡Π΅Ρ€Π΅Π· Π·Π°ΠΏΡΡ‚ΡƒΡŽ */
#123456789, #rec123456789, #123456789, #r123456789 {
display: none !important;
}

/* Π‘Ρ‚ΠΈΠ»ΠΈ для ΠΠšΠ’Π˜Π’ΠΠžΠ™ ΠΊΠ½ΠΎΠΏΠΊΠΈ */
.my-tab-active .tn-group__item,
.my-tab-active {
background-color: #1C3964 !important; /* Π¦Π²Π΅Ρ‚ Ρ„ΠΎΠ½Π° Π°ΠΊΡ‚ΠΈΠ²Π½ΠΎΠ³ΠΎ Ρ‚Π°Π±Π° */
border-color: #1C3964 !important;
border-radius: 30px !important;
transition: all 0.3s ease;
}

/* Π¦Π²Π΅Ρ‚ тСкста Π² Π°ΠΊΡ‚ΠΈΠ²Π½ΠΎΠΉ ΠΊΠ½ΠΎΠΏΠΊΠ΅ */
.my-tab-active .tn-atom,
.my-tab-active div,
.my-tab-active span {
color: #ffffff !important;
}
</style>

<script>
(function() {
// ΠΠΠ‘Π’Π ΠžΠ™ΠšΠ˜: ΠŸΡ€ΠΈΠ²ΡΠΆΠΈΡ‚Π΅ ID Π±Π»ΠΎΠΊΠΎΠ² ΠΊ ссылкам ΠΊΠ½ΠΎΠΏΠΎΠΊ
const tabGroups = {
'#tab1': ['123456789', '123456789'], // Π‘Π»ΠΎΠΊΠΈ ΠΏΠ΅Ρ€Π²ΠΎΠΉ Π²ΠΊΠ»Π°Π΄ΠΊΠΈ
'#tab2': ['123456789', '123456789'], // Π‘Π»ΠΎΠΊΠΈ Π²Ρ‚ΠΎΡ€ΠΎΠΉ Π²ΠΊΠ»Π°Π΄ΠΊΠΈ
'#tab3': ['123456789', '123456789'] // И Ρ‚Π°ΠΊ Π΄Π°Π»Π΅Π΅...
};

const allBlocks = Object.values(tabGroups).flat();

function updateTabs(hash) {
if (!tabGroups[hash]) return;

// Π‘ΠΊΡ€Ρ‹Π²Π°Π΅ΠΌ всС Π±Π»ΠΎΠΊΠΈ ΠΈΠ· списка
allBlocks.forEach(id => {
const el = document.querySelector(id);
if (el) el.style.setProperty('display', 'none', 'important');
});

// ΠŸΠΎΠΊΠ°Π·Ρ‹Π²Π°Π΅ΠΌ Π±Π»ΠΎΠΊΠΈ Π°ΠΊΡ‚ΠΈΠ²Π½ΠΎΠΉ Π²ΠΊΠ»Π°Π΄ΠΊΠΈ
tabGroups[hash].forEach(id => {
const el = document.querySelector(id);
if (el) el.style.setProperty('display', 'block', 'important');
});

// ОбновляСм Π²ΠΈΠ·ΡƒΠ°Π»ΡŒΠ½ΠΎΠ΅ состояниС ΠΊΠ½ΠΎΠΏΠΎΠΊ
document.querySelectorAll('.my-tab-btn').forEach(btn => {
btn.classList.remove('my-tab-active');
const linkInBtn = btn.querySelector('a');
const href = linkInBtn ? linkInBtn.getAttribute('href') : btn.getAttribute('href');
if (href === hash) btn.classList.add('my-tab-active');
});

// ОбновляСм Tilda (Π°Π½ΠΈΠΌΠ°Ρ†ΠΈΠΈ ΠΈ lazy load)
window.dispatchEvent(new Event('resize'));
if (typeof t_lazyload_update === 'function') t_lazyload_update();
}

// Π‘Π»ΡƒΡˆΠ°Ρ‚Π΅Π»ΡŒ ΠΊΠ»ΠΈΠΊΠΎΠ²
document.addEventListener('click', function(e) {
const btn = e.target.closest('.my-tab-btn');
if (!btn) return;

const link = btn.querySelector('a') || (btn.tagName === 'A' ? btn : null);
if (link) {
const href = link.getAttribute('href');
if (href && href.startsWith('#tab')) {
e.preventDefault();
updateTabs(href);
}
}
}, true);

// Активация ΠΏΠ΅Ρ€Π²ΠΎΠΉ Π²ΠΊΠ»Π°Π΄ΠΊΠΈ ΠΏΡ€ΠΈ Π·Π°Π³Ρ€ΡƒΠ·ΠΊΠ΅
window.addEventListener('load', () => updateTabs('#tab1'));
})();
</script>
ΠŸΠΎΡ‡Π΅ΠΌΡƒ это Ρ€Π΅ΡˆΠ΅Π½ΠΈΠ΅ Π»ΡƒΡ‡ΡˆΠ΅ стандартного?
  • Π“ΠΈΠ±ΠΊΠΎΡΡ‚ΡŒ: МоТно ΠΈΡΠΏΠΎΠ»ΡŒΠ·ΠΎΠ²Π°Ρ‚ΡŒ Autolayout, Π³Ρ€ΡƒΠΏΠΏΠΈΡ€ΠΎΠ²ΠΊΡƒ ΠΈ Π»ΡŽΠ±Ρ‹Π΅ элСмСнты Π²Π½ΡƒΡ‚Ρ€ΠΈ ΠΊΠ½ΠΎΠΏΠΎΠΊ.
  • Π‘ΠΊΠΎΡ€ΠΎΡΡ‚ΡŒ: Код написан Π½Π° чистом JavaScript (Π±Π΅Π· jQuery), Ρ‡Ρ‚ΠΎ обСспСчиваСт ΠΌΠ³Π½ΠΎΠ²Π΅Π½Π½ΡƒΡŽ Ρ€Π°Π±ΠΎΡ‚Ρƒ.
  • SEO ΠΈ Π°Π΄Π°ΠΏΡ‚ΠΈΠ²: Π‘Π»ΠΎΠΊΠΈ физичСски ΠΏΡ€ΠΈΡΡƒΡ‚ΡΡ‚Π²ΡƒΡŽΡ‚ Π½Π° страницС, Ρ‡Ρ‚ΠΎ ΠΏΠΎΠ»Π΅Π·Π½ΠΎ для поисковиков, Π° ΠΏΠ΅Ρ€Π΅ΠΊΠ»ΡŽΡ‡Π΅Π½ΠΈΠ΅ Ρ€Π°Π±ΠΎΡ‚Π°Π΅Ρ‚ ΠΊΠΎΡ€Ρ€Π΅ΠΊΡ‚Π½ΠΎ Π½Π° ΠΌΠΎΠ±ΠΈΠ»ΡŒΠ½Ρ‹Ρ… устройствах.

4. Бтилизация Π°ΠΊΡ‚ΠΈΠ²Π½ΠΎΠ³ΠΎ состояния

Π§Ρ‚ΠΎΠ±Ρ‹ ΠΏΠΎΠ»ΡŒΠ·ΠΎΠ²Π°Ρ‚Π΅Π»ΡŒ ΠΏΠΎΠ½ΠΈΠΌΠ°Π», какая Π²ΠΊΠ»Π°Π΄ΠΊΠ° Π²Ρ‹Π±Ρ€Π°Π½Π°, ΠΌΡ‹ Π΄ΠΎΠ±Π°Π²ΠΈΠ»ΠΈ Π² ΠΊΠΎΠ΄ CSS-стили. Они автоматичСски ΠΌΠ΅Π½ΡΡŽΡ‚ Ρ„ΠΎΠ½ ΠΊΠ½ΠΎΠΏΠΊΠΈ Π½Π° #1C3964, тСкст Π½Π° Π±Π΅Π»Ρ‹ΠΉ ΠΈ ΡΠΎΡ…Ρ€Π°Π½ΡΡŽΡ‚ скруглСниС Π² 30px ΠΏΡ€ΠΈ ΠΊΠ»ΠΈΠΊΠ΅.

5. ΠŸΡ€ΠΎΠ²Π΅Ρ€ΠΊΠ° ΠΈ тСсты

ПослС ΠΏΡƒΠ±Π»ΠΈΠΊΠ°Ρ†ΠΈΠΈ ΠΎΠ±ΡΠ·Π°Ρ‚Π΅Π»ΡŒΠ½ΠΎ ΠΏΡ€ΠΎΠ²Π΅Ρ€ΡŒΡ‚Π΅:

  1. НС Β«ΠΏΡ€Ρ‹Π³Π°Π΅Ρ‚Β» Π»ΠΈ страница ΠΊ ΡΠΊΠΎΡ€ΡŽ (скрипт Π΄ΠΎΠ»ΠΆΠ΅Π½ Π±Π»ΠΎΠΊΠΈΡ€ΠΎΠ²Π°Ρ‚ΡŒ ΠΏΠ΅Ρ€Π΅Ρ…ΠΎΠ΄).
  2. ΠšΠΎΡ€Ρ€Π΅ΠΊΡ‚Π½ΠΎ Π»ΠΈ ΠΎΡ‚ΠΎΠ±Ρ€Π°ΠΆΠ°ΡŽΡ‚ΡΡ Π±Π»ΠΎΠΊΠΈ Π½Π° ΠΌΠΎΠ±ΠΈΠ»ΡŒΠ½Ρ‹Ρ… устройствах.
  3. Π Π°Π±ΠΎΡ‚Π°Π΅Ρ‚ Π»ΠΈ Lazy Load (ΠΏΡ€ΠΎΠ³Ρ€ΡƒΠΆΠ°ΡŽΡ‚ΡΡ Π»ΠΈ ΠΊΠ°Ρ€Ρ‚ΠΈΠ½ΠΊΠΈ Π²Π½ΡƒΡ‚Ρ€ΠΈ Π²ΠΊΠ»Π°Π΄ΠΎΠΊ).
Π˜Ρ‚ΠΎΠ³: Π’Π΅ΠΏΠ΅Ρ€ΡŒ Π²Ρ‹ Π½Π΅ ΠΎΠ³Ρ€Π°Π½ΠΈΡ‡Π΅Π½Ρ‹ стандартными Π±Π»ΠΎΠΊΠ°ΠΌΠΈ Tilda ΠΈ ΠΌΠΎΠΆΠ΅Ρ‚Π΅ ΡΠΎΠ·Π΄Π°Π²Π°Ρ‚ΡŒ интСрфСйсы любого уровня слоТности!
2026-01-26 16:49 Tilda Zero block