В целях оптимизации времени выхода постов небольшой опрос.
В какой временной зоне вы находитесь?
В какой временной зоне вы находитесь?
Anonymous Poll
1%
GMT+1
8%
GMT+2
55%
GMT+3
2%
GMT+4
1%
GMT+4
18%
GMT+5
2%
GMT+6
5%
GMT+7
1%
Другая
6%
Не сплю
Мы уже писали про инициативу jsr.io, продвигаемую
Бывший создатель
Нам очень важны платформы и инструменты для разработчиков, поэтому мы так много времени уделяем этому направлению. Однако экосистема управления пакетами стагнирует, и это открывает широкие возможности для инноваций. Наша миссия всегда заключалась в улучшении опыта разработчиков, и мы рады снова работать вместе над этим.
Заявленные проблемы
- манифест пакета npm публикуется независимо от его тарбола
- манифесты никогда полностью не проверяются на соответствие содержимому тарбола
- в экосистеме принято считать, что содержимое манифеста и тарбола совпадает
- любые инструменты или идеи, использующие публичный реестр, восприимчивы к эксплоитам/возможно неточны
- злоумышленники могут скрывать вредоносное ПО и скрипты в прямых или транзитивных зависимостях, которые остаются незамеченными
Выпустили пока только общее коммюнике, никакой конкретики, ходя идее уже почти год
Примечательно, что Evan You в
#jsr #evanyou #vlt
Deno
, создатель которого Ryan Dahl был также создателем Node.js
Бывший создатель
NPM
, разработчик Node.js
, а также CEO компании npm Inc.
Darcy Clarke и другие известные люди начали еще одну похожую инициативу - vlt, который называют новым домом для open source:Нам очень важны платформы и инструменты для разработчиков, поэтому мы так много времени уделяем этому направлению. Однако экосистема управления пакетами стагнирует, и это открывает широкие возможности для инноваций. Наша миссия всегда заключалась в улучшении опыта разработчиков, и мы рады снова работать вместе над этим.
Заявленные проблемы
NPM
:- манифест пакета npm публикуется независимо от его тарбола
- манифесты никогда полностью не проверяются на соответствие содержимому тарбола
- в экосистеме принято считать, что содержимое манифеста и тарбола совпадает
- любые инструменты или идеи, использующие публичный реестр, восприимчивы к эксплоитам/возможно неточны
- злоумышленники могут скрывать вредоносное ПО и скрипты в прямых или транзитивных зависимостях, которые остаются незамеченными
Выпустили пока только общее коммюнике, никакой конкретики, ходя идее уже почти год
Примечательно, что Evan You в
vlt
выступает в качестве инвестора#jsr #evanyou #vlt
Telegram
Vue-FAQ
Deno запустило в open-source 5 дней назад и продвигает свой реестр для JavaScript и TypeScript пакетов - jsr.io
Основные отличия:
- Суперсет для npm
- Поддержка Node, Bun, Deno, Cloudflare Workers и других сред выполнения js
- Автоматическое создание документации…
Основные отличия:
- Суперсет для npm
- Поддержка Node, Bun, Deno, Cloudflare Workers и других сред выполнения js
- Автоматическое создание документации…
Обнаружил Telegram канал с глубоким и интересным аналитическим разбором различных фронтендных тем - @frontend_almanac_ru
#tg
#tg
👍9
Добрый человек сделал перевод на русский язык документации
Чтобы его PR приняли, нужно сделать ревью.
Документация немаленькая, предлагаю разделить нескольким добровольцам и проверить по частям.
#vitepress #translation
VitePress
Чтобы его PR приняли, нужно сделать ревью.
Документация немаленькая, предлагаю разделить нескольким добровольцам и проверить по частям.
#vitepress #translation
GitHub
docs(ru): add Russian translation by dragomano · Pull Request #3709 · vuejs/vitepress
Vite & Vue powered static site generator. Contribute to vuejs/vitepress development by creating an account on GitHub.
🔥12
Использование функций на массивах, типа
1. Выделения и потом уничтожения промежуточных массивов
2. Cоздавания циклов в циклах ( сложность
Например, код 1. ниже выполняется в 2-3 раза дольше, чем код 2.
#js #optimization
filter
, map
и других, очень удобно и даёт красивый код, но может создавать проблемы в производительности из-за:1. Выделения и потом уничтожения промежуточных массивов
2. Cоздавания циклов в циклах ( сложность
O(N^2)
), хотя весь код можно разместить в одном цикле ( O(N)
)Например, код 1. ниже выполняется в 2-3 раза дольше, чем код 2.
// setup:
const numbers = Array.from({ length: 10000 }).map(() => Math.random())
// 1. functional
const result =
numbers
.map(n => Math.round(n * 10))
.filter(n => n % 2 === 0)
.reduce((a, n) => a + n, 0)
// 2. imperative
let result = 0
for (let i = 0; i < numbers.length; i++) {
let n = Math.round(numbers[i] * 10)
if (n % 2 !== 0) continue
result = result + n
}
#js #optimization
👍21
Интересно, если у такой конторы как VueSchool месяцами висит объявление о найме Vue/Nuxt мидл-левел фронтендера, то это что значит?
#vueschool
#vueschool
🤔3😁1
Толстосумы тоже решили подкинуть немножко на
Интересно, сколько денег они потратили на свою заброшенную реализацию?
#jetbrains #webstorm #volar
Volar
.Интересно, сколько денег они потратили на свою заброшенную реализацию?
#jetbrains #webstorm #volar
👍6😁2
Рейтинг фронтенд фреймворков по количеству набранных в 2023 году GitHub звезд
Забавно, что Vue 2 набрал не сильно меньше Vue 3. По общему числу звезд Vue 2 уже отстал от React.
Также интересно, что у Svelte и Vue примерно одинаковое количество звезд каждый месяц (что может коррелировать с вливанием новых разработчиков в фреймворк), но число реальных проектов в коммерческой сфере отличается на порядок (или порядки)
#rating #benchmark #framework
Забавно, что Vue 2 набрал не сильно меньше Vue 3. По общему числу звезд Vue 2 уже отстал от React.
Также интересно, что у Svelte и Vue примерно одинаковое количество звезд каждый месяц (что может коррелировать с вливанием новых разработчиков в фреймворк), но число реальных проектов в коммерческой сфере отличается на порядок (или порядки)
#rating #benchmark #framework
🤔3
Забавный генератор типовой документации произвольного пакета - tsdocs.dev
Наверно написан на Node.js - очень сложно поймать момент, когда сайт не лежит или не перегружен. Но возможно.
#tsdoc #ts #docs
Наверно написан на Node.js - очень сложно поймать момент, когда сайт не лежит или не перегружен. Но возможно.
#tsdoc #ts #docs
tsdocs.dev
TS Docs | Reference docs for npm packages
Generate type documentation for npm libraries
👍2👎1
Использовать <script setup> во Vue 3 можно вместе с обычным блоком <script>
Это работает потому, что блок
Есть несколько причин, по которым вы можете захотеть сделать это:
- Использование Options API - не всё имеет эквивалент в Composition API, например
- Выполнить код один раз - поскольку
- Именованный экспорт - иногда удобно экспортировать несколько объектов из одного файла, но это можно сделать только с помощью обычного блока
#tip
<script setup>
// Composition API
import { ref } from 'vue';
console.log('Setting up new component instance');
const count = ref(0);
</script>
<script>
// ...and the options API too!
export default {
name: 'DoubleScript',
};
</script>
Это работает потому, что блок
<script setup>
компилируется в функцию setup()
компонента.Есть несколько причин, по которым вы можете захотеть сделать это:
- Использование Options API - не всё имеет эквивалент в Composition API, например
inheritAttrs
. Для этого можно использовать defineOptions
.- Выполнить код один раз - поскольку
setup()
выполняется для каждого компонента, если у вас есть код, который должен быть выполнен только один раз, вы не можете включать его в <script setup>
. Однако вы можете поместить его в обычный блок <script>
- Именованный экспорт - иногда удобно экспортировать несколько объектов из одного файла, но это можно сделать только с помощью обычного блока
<script>
.#tip
👍7
Развитие в GitHub звездах Vue экосистемы за 2023 год.
#ecosystem #rating
Vue Element Admin
- китайский продукт на Vue 2.6#ecosystem #rating
🆒1
Документалка, как создавался Vue.js, довольно интересно.
Есть русские субтитры
https://youtu.be/OrxmtDw4pVI
#vuejs #evanyou
Есть русские субтитры
https://youtu.be/OrxmtDw4pVI
#vuejs #evanyou
YouTube
Vue.js: The Documentary
by honeypot.io | What began as a side project of a Google developer
now shares the JS leaderboard with #React and #Angular...
With the help of Sarah Drasner, Taylor Otwell, Thorsten Lünborg and many others from the Vue.js community, Evan You tells the story…
now shares the JS leaderboard with #React and #Angular...
With the help of Sarah Drasner, Taylor Otwell, Thorsten Lünborg and many others from the Vue.js community, Evan You tells the story…
❤6🐳1
Правильная конференция правильных фронтендеров
Смотрим на число спонсоров, делаем выводы
#conference #humor #elysia
Смотрим на число спонсоров, делаем выводы
#conference #humor #elysia
💩11🥴4🦄2
Сегодня опубликован перевод официальной документации
https://vitepress.dev/ru/
Перевод выполнен @dragomano
#vitepress #translation
VitePress
на русский языкhttps://vitepress.dev/ru/
Перевод выполнен @dragomano
#vitepress #translation
👍23
Не так давно
Отметим, как работает эта утилита для просмотра
Это хороший способ создать лёгкое мультиплатформенное приложение с графическим веб интерфейсом, без необходимости засовывать его в
#antfu #eslint
Antony Fu
создал eslint-flat-config-viewer
, который официально теперь часть ESLint 9
- ESlint Config InspectorОтметим, как работает эта утилита для просмотра
ESLint
конфига - запускается небольшой локальный вебсервер, и затем открывается окно с веб-приложением непосредственно утилиты. Так работает немало как встроенных (админки аппаратных роутеров), так и обычных компьютерных программ (Syncthing
, например). Это хороший способ создать лёгкое мультиплатформенное приложение с графическим веб интерфейсом, без необходимости засовывать его в
Electron
. Правда, подходит этот метод больше для продвинутых пользователей.#antfu #eslint
eslint.org
Introducing ESLint Config Inspector - ESLint - Pluggable JavaScript Linter
A pluggable and configurable linter tool for identifying and reporting on patterns in JavaScript. Maintain your code quality with ease.
👍1