Skip to content

Заметки, решения, подходы

Notifications You must be signed in to change notification settings

alexshink/tricks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 

Repository files navigation

VUE

Переменные окружения NPM+VUE+WEBPACK

Для прокидывания перменных при запуске/билде приложения, необходимо в файле vue.config.js описать конфигурацию Webpack:

const webpack = require('webpack');
configureWebpack: {
  plugins: [
    new webpack.DefinePlugin({
      'process.env': {
        CUSTOM_VAR: JSON.stringify(process.env.CUSTOM_VAR) || 'default value'
      }
    })
  ]
}

Установка кастомного значения перменной в терминале: set CUSTOM_VAR=value && npm run serve

Работа с переменной в приложении: console.log(process.env.CUSTOM_VAR)

Загрузка ресурсов из папок вне Vue-проекта

внешние компоненты

Автоимпорт компонентов

Плагин для избавления от ручного импорта не базовых компонентов:
vue-cli-plugin-import-components

Убирает необходимость в Import и components: {}, при этом импортирует непосредственно используемые в файле компоненты, саппорт Vue 2 + 3.

SVG-анимация

атрибут id

Все значения атрибутов id у тегов анимации (<animate>, <animateTransform> и др.) должны быть написаны без символа -. Иначе это может привести к некорректной работе анимации в некоторых браузерах. Например, в случае с Firefox:

<animate id="eye-close" attributeName="d" values="..." dur="150ms" fill="freeze" begin="1000ms" />
<animate id="eye-open" attributeName="d" values="..." dur="150ms" fill="freeze" begin="eye-close.end+500ms" />
  • первая анимация (id="eye-close") запускается по прошествии одной секунды (begin="1000ms")
  • вторая анимация (id="eye-open") запускается через пол секунды после завершения первой анимации (begin="eye-close.end+500ms")

В данном случае вторая анимация вообще не сработает, потому что Firefox воспринимает символ - в качестве оператора вычитания, что ломает всю логику написанного выражения. Поэтому необходимо избегать символ - в значении атрибута id и использовать вместо него нижнее подчёркивание или CamelCase, либо любой другой разрешённый синтаксис.

морфинг <path>

Для анимации атрибута <d> начальная, конечная и любые промежуточные фигуры должны иметь одинаковое количество координат и параметров. Следовательно, SMIL-анимация прямой линии в кривую Безье невозможна, потому что преобразование в кривую меняет количество параметров в атрибуте <d>. Чтобы задействовать SMIL-анимацию для такого преобразования, необходимо изначально преобразовать все прямые линии фигуры в кривые Безье, это можно сделать незаметно, изменив уровень выпуклости или вогнутости прямой линии на 0,1%, что визуально не будет заметно.

Пример простой анимации:

<path d="m 53.73,85.903863 a 3.73,3.73 0 1 0 -3.73,-3.73 3.74,3.74 0 0 0 3.73,3.73 z">
  <animate attributeName="d" values="m 53.73,85.903863 a 3.73,3.73 0 1 0 -3.73,-3.73 3.74,3.74 0 0 0 3.73,3.73 z;m 53.73,91.660547 a 3.73,3.73 0 1 0 -3.73,-3.73 3.74,3.74 0 0 0 3.73,3.73 z;m 53.73,85.903863 a 3.73,3.73 0 1 0 -3.73,-3.73 3.74,3.74 0 0 0 3.73,3.73 z" dur="200ms" begin="600ms" />
</path>

информация по основной анимации: https://css-tricks.com/guide-svg-animations-smil/

Flexbox

Если ребёнку flexbox-блока необходимо задать размер по главной оси (main axis), то для корректного кросс-браузерного отображения необходимо это делать через свойство flex, указав три соответствующих значения (flex-grow, flex-shrink, flex-basis), а не через свойство width. Самая проблемная в данном случае ситуация возникает с тегом изображения и его стандартным атрибутом width. Например:

<img src="picture.jpg" alt="" width="150px">

Если это изображение является ребёнком flexbox-блока и у этого изображения есть соседи, размер которых высчитывается автоматически, то при нехватке места само изображение и его соседи будут неравномерно сжаты. При этом размеры изображения будут высчитываться на основе значения атрибута width, что подразумевает ещё большую путаницу. Поэтому размеры необходимо указывать через свойство flex.

Статистика

Инструмент для анализа глобального веб-трафика. Браузеры, ОСи, девайсы и версии: http://gs.statcounter.com/

User-Agent

Идентификация браузера на основе обнаружения строки агента пользователя (window.navigator.userAgent) является ненадежной и не рекомендуется, так как строка пользовательского агента может быть изменена пользователем.

Почему везде Mozilla/5.0?
Первый «Mozilla» был переименован в «Netscape Navigator», но в User-Agent позиционировался как Mozilla/1.0. Он первым начал поддерживать фреймы и быстро расти в плане функционала. Вебмастеры начали различать браузеры по юзерагенту, чтобы знать, когда использовать определённый функционал. Однажды:

Netscape сказал "давайте посмеемся над Microsoft" и ссылался на Windows как на «плохо отлаженные драйверы устройств»

После этого Microsoft сделали «Internet Explorer», который тоже мог во фреймы, поэтому в юзерагенте они написали Mozilla/1.22 (compatible; MSIE 2.0; Windows 95), чтобы уже имеющиеся сайты могли использовать функционал «Netscape Navigator» в IE. Так User-Agent всех браузеров и превратился в User-Agent «Mozilla»

краткая история войны браузеров: https://habr.com/ru/post/84222/

Технические нюансы

Влияние верхней адресной панели в Chrome Android:

Размер блока, установленный в единицах vh, не изменится в зависимости от того, отображена или скрыта адресная панель. Размер блока будет всегда равен установленному размеру, соответственно всей рабочей области браузера, как если бы панель URL всегда была скрыта. То есть размер блока будет иметь размер области просмотра, не включая размер адресной панели. Это означает, что размер блока в 100vh при отображении адресной панели будет больше видимой высоты браузера.

Подробности: https://developers.google.com/web/updates/2016/12/url-bar-resizing

Стилизация

размытие

При наложении фильтра размытия на какой-либо элемент, при необходимости можно накинуть transform: scale(); для увеличения занимаемой области размытого объекта, что поможет убрать размытые полупрозрачные края, переходящие в фоновый цвет элемента, находящегося позади. На изображении ниже можно увидеть наглядный пример.

Убираем размытые края при эффекте размытия

input

У полей ввода типа text и password есть минимальная ширина, установленная зашитым атрибутом size со значением 20 (примерно 100px). Даже если input будет работать в технологии flex - он не сожмётся меньше, чем его минимальная ширина. Чтобы отключить это поведение, необходимо указать width: ... или min-width: 0.

Sublime Text

экспорт/импорт настроек

Для экспорта настроек на другой компьютер можно юзать пакет PackageSync. После установки пакета:

  1. Вкладка Tools
  2. Экспорт: PackageSync -> Backup/Restore -> Backup packages to zip
  3. Несём zip на комп для импорта
  4. Импорт: PackageSync -> Backup/Restore -> Backup packages from zip

SLICK

Если слайдер находится во flex-блоке, то его ширина высчитывается неправильно, поэтому она бесконечно увеличивается независимо от стандартной ширины родителя. В разных ситуациях фиксится разными методами, чаще всего необходимо задать контейнеру, в котором находится слайдер, следующее правило: overflow: hidden;, либо самому слайдеру: width: 100%;

Другие фиксы, которые могут помочь:

  • min-height: 0;
  • min-height: 0;
  • min-width: 1px;

В ожидании функции свободной прокрутки:
kenwheeler/slick#1665
kenwheeler/slick#3461

РЕСУРСЫ

About

Заметки, решения, подходы

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published