{"id":340197,"date":"2022-10-25T09:00:07","date_gmt":"2022-10-25T09:00:07","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=340197"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=340197","title":{"rendered":"<span>OpenSource \u043d\u0430 \u0437\u0430\u0432\u0442\u0440\u0430\u043a<\/span>"},"content":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/3e0\/e5b\/019\/3e0e5b0193d9606be045d5a825141f6d.png\" width=\"3120\" height=\"1164\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3e0\/e5b\/019\/3e0e5b0193d9606be045d5a825141f6d.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0414\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u0441\u0432\u043e\u0438\u043c\u0438 \u0438\u0434\u0435\u044f\u043c\u0438 \u0441 \u0441\u043e\u043e\u0431\u0449\u0435\u0441\u0442\u0432\u043e\u043c &#8212; \u0445\u043e\u0440\u043e\u0448\u043e \u0438 \u043f\u043e\u043b\u0435\u0437\u043d\u043e. \u042d\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u0442\u044c\u0441\u044f, \u043f\u0435\u0440\u0435\u043d\u0438\u043c\u0430\u0442\u044c \u043b\u0443\u0447\u0448\u0438\u0435 \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0438, \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u044c \u043d\u043e\u0432\u044b\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b, \u0443\u0447\u0438\u0442\u044c\u0441\u044f \u043e\u0444\u043e\u0440\u043c\u043b\u044f\u0442\u044c \u0441\u0432\u043e\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f. \u041d\u043e \u043a\u0430\u043a\u043e\u0439 \u043a\u043e\u0434 \u0441\u0442\u043e\u0438\u0442 \u0432\u044b\u043d\u043e\u0441\u0438\u0442\u044c \u0432 \u043e\u0431\u0449\u0438\u0439 \u0434\u043e\u0441\u0442\u0443\u043f? \u0418 \u043a\u0430\u043a \u0434\u0435\u043b\u0430\u0442\u044c \u044d\u0442\u043e \u043d\u0430 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e\u0439 \u043e\u0441\u043d\u043e\u0432\u0435? \u0427\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f \u0432 \u044d\u0442\u0438\u0445 \u0432\u043e\u043f\u0440\u043e\u0441\u0430\u0445, \u044f \u0440\u0435\u0448\u0438\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u0432\u043e\u0439 <strong>JavaScript OpenSource Boilerplate <\/strong>&#8212; \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0443\u044e, \u043d\u043e \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u0440\u0430\u0441\u0448\u0438\u0440\u044f\u0435\u043c\u0443\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432. \u042f \u043d\u0430\u0437\u0432\u0430\u043b \u0435\u0451 <a href=\"https:\/\/github.com\/ivliag\/handy-ones\" rel=\"noopener noreferrer nofollow\"><strong>handy-ones<\/strong><\/a>.<\/p>\n<h2>\u0417\u0430\u0434\u0430\u0447\u0430<\/h2>\n<p>\u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u0437\u0430\u0434\u0430\u0447\u0430 \u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0434\u0430\u0436\u0435 \u0448\u0438\u0440\u0435, \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043c\u043e\u0442\u0438\u0432 \u0432 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 &#8212; \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0439. \u041a\u0430\u0436\u0434\u044b\u0439 \u0434\u0435\u043d\u044c \u0432 JavaScript-\u043c\u0438\u0440\u0435 \u043f\u043e\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b \u0438 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438, \u043f\u0440\u043e\u0442\u0438\u0432\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 ui-\u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u043e\u0432 \u0441\u043c\u0435\u043d\u0438\u043b\u043e\u0441\u044c \u0431\u043e\u0440\u044c\u0431\u043e\u0439 js-\u0440\u0430\u043d\u0442\u0430\u0439\u043c\u043e\u0432, \u0431\u0430\u043d\u0434\u043b\u0435\u0440\u043e\u0432, \u0441\u0442\u0435\u0439\u0442-\u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440\u043e\u0432, \u0443\u0442\u0438\u043b\u0438\u0442 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u043c\u043e\u043d\u043e\u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f\u043c\u0438. \u041c\u043d\u0435 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u043b\u0441\u044f \u043f\u0440\u043e\u0435\u043a\u0442, \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044f \u0441\u043c\u043e\u0433\u0443 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0441 \u043d\u043e\u0432\u044b\u043c\u0438 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u044f\u043c\u0438, \u0430 \u0443\u0434\u0430\u0447\u043d\u044b\u0435 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u044b \u043b\u0435\u0433\u043a\u043e \u043e\u0444\u043e\u0440\u043c\u043b\u044f\u0442\u044c \u0438 \u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u0442\u044c. \u042f \u0441\u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u043b \u043a \u043d\u0435\u043c\u0443 \u0442\u0430\u043a\u0438\u0435 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u044f:<\/p>\n<ol>\n<li>\n<p>\u0423\u0434\u043e\u0431\u0441\u0442\u0432\u043e \u0438 \u043a\u043e\u043c\u0444\u043e\u0440\u0442 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438. \u041f\u0440\u043e\u0435\u043a\u0442 \u0434\u043e\u043b\u0436\u0435\u043d \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c\u0441\u044f \u0438 \u0441\u043e\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f \u0431\u044b\u0441\u0442\u0440\u043e, \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b \u0432\u0441\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b: HMR, source-maps \u0438 \u0442\u0434.<\/p>\n<\/li>\n<li>\n<p>\u0423\u0434\u043e\u0431\u0441\u0442\u0432\u043e \u0434\u043b\u044f \u043f\u043e\u0442\u0440\u0435\u0431\u0438\u0442\u0435\u043b\u044f. \u041a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u0432 ES6, d.ts \u0438 source-maps \u0432\u043d\u0443\u0442\u0440\u0438 \u043f\u0430\u043a\u0435\u0442\u043e\u0432. \u041f\u043e\u0441\u0442\u0430\u0432\u043a\u0430 \u0447\u0435\u0440\u0435\u0437 npm.<\/p>\n<\/li>\n<li>\n<p>\u041c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 time-to-market. \u041e\u0442 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u043a\u043e\u0434\u0430 \u0434\u043e \u0434\u0438\u0441\u0442\u0440\u0438\u0431\u0443\u0446\u0438\u0438 \u0434\u043e\u043b\u0436\u043d\u044b \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442\u044c \u043c\u0438\u043d\u0443\u0442\u044b.<\/p>\n<\/li>\n<li>\n<p>\u041d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u0435 \u0441\u0431\u043e\u0440\u043a\u0430, \u043f\u043e\u0441\u0442\u0430\u0432\u043a\u0430, \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0441\u0438\u0441\u0442\u0435\u043c\u044b. \u041a\u0442\u043e \u0437\u043d\u0430\u0435\u0442, \u0447\u0442\u043e \u043d\u043e\u0432\u043e\u0433\u043e \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u044e\u0442 \u0437\u0430\u0432\u0442\u0440\u0430, \u0438 \u0432 \u0447\u0435\u043c \u0437\u0430\u0445\u043e\u0447\u0435\u0442\u0441\u044f \u043f\u043e\u043a\u043e\u0432\u044b\u0440\u044f\u0442\u044c\u0441\u044f?<\/p>\n<\/li>\n<li>\n<p>\u041c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f \u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u0443\u043d\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432.<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f \u0438 demo-\u0441\u0442\u0435\u043d\u0434\u044b &#171;\u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438&#187;.<\/p>\n<\/li>\n<\/ol>\n<h2>\u0418\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b<\/h2>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/9f7\/9b4\/48c\/9f79b448c348ee2618494c949bc12b95.png\" width=\"857\" height=\"82\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/9f7\/9b4\/48c\/9f79b448c348ee2618494c949bc12b95.png\"\/><figcaption><\/figcaption><\/figure>\n<p>\u0422\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0441\u0442\u0435\u043a, \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0432\u0448\u0438\u0439 \u0440\u0435\u0448\u0438\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u044d\u0442\u0438\u0445 \u0437\u0430\u0434\u0430\u0447, \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<ol>\n<li>\n<p><a href=\"https:\/\/docs.npmjs.com\/about-npm\" rel=\"noopener noreferrer nofollow\">npm<\/a> \u0434\u043b\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438 \u0432\u043d\u0435\u0448\u043d\u0438\u0445 \u0438 \u043f\u0435\u0440\u0435\u043b\u0438\u043d\u043a\u043e\u0432\u043a\u0438 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0445 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/turborepo.org\/docs\/core-concepts\/why-turborepo\" rel=\"noopener noreferrer nofollow\">turborepo<\/a> \u0434\u043b\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0432<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.typescriptlang.org\/docs\/handbook\/compiler-options.html\" rel=\"noopener noreferrer nofollow\">tsc<\/a> \u0438 <a href=\"https:\/\/github.com\/postcss\/postcss-cli\" rel=\"noopener noreferrer nofollow\">postcss-cli<\/a> \u0434\u043b\u044f \u0441\u0431\u043e\u0440\u043a\u0438 \u043f\u0430\u043a\u0435\u0442\u043e\u0432<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/vitejs.dev\/guide\/why.html\" rel=\"noopener noreferrer nofollow\">vite<\/a> \u0434\u043b\u044f \u0441\u0431\u043e\u0440\u043a\u0438 \u0441\u0435\u0440\u0432\u0438\u0441\u043d\u044b\u0445 \u0431\u0430\u043d\u0434\u043b\u043e\u0432<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/ladle.dev\/\" rel=\"noopener noreferrer nofollow\">ladle<\/a> \u043a\u0430\u043a \u0434\u0432\u0438\u0436\u043e\u043a \u0434\u043b\u044f \u0434\u0435\u043c\u043e-\u0441\u0442\u0435\u043d\u0434\u0430<\/p>\n<\/li>\n<\/ol>\n<p>\u0427\u0430\u0441\u0442\u044c \u044d\u0442\u0438\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u0441\u0443\u043f\u0435\u0440-\u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435, \u0434\u0440\u0443\u0433\u0438\u0435, \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442, \u043e\u0447\u0435\u043d\u044c \u0441\u0432\u0435\u0436\u0438\u0435. \u041b\u044e\u0431\u043e\u0439 \u0438\u0437 \u043d\u0438\u0445 \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0437\u0432\u0430\u0442\u044c <a href=\"https:\/\/www.urbandictionary.com\/define.php?term=Holy%20War\" rel=\"noopener noreferrer nofollow\">\u0441\u043f\u043e\u0440\u044b<\/a>. \u042f \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u043f\u0440\u043e \u0432\u044b\u0431\u043e\u0440 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0438\u0437 \u043d\u0438\u0445 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435, \u043f\u043e\u043a\u0430 \u0436\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u043a\u0430\u0436\u0443, \u0447\u0442\u043e \u044f \u0438\u043c\u0438 <em>\u0434\u043e\u0432\u043e\u043b\u0435\u043d<\/em>. \u0418 \u043f\u043e\u0434\u0435\u043b\u044e\u0441\u044c \u043f\u0435\u0440\u0432\u044b\u043c\u0438 \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043d\u043d\u044b\u043c\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u043c\u0438 \u043c\u043e\u0435\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438.<\/p>\n<h2>First ones<\/h2>\n<p>\u041f\u0435\u0440\u0432\u044b\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b &#8212; \u0441\u0430\u043c\u044b\u0435 \u043f\u0440\u043e\u0441\u0442\u044b\u0435, \u0431\u0430\u0437\u043e\u0432\u044b\u0435, \u0430\u0442\u043e\u043c\u0430\u0440\u043d\u044b\u0435. \u041d\u043e \u043e\u043d\u0438 \u0436\u0435 \u0438 \u0441\u0430\u043c\u044b\u0435 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0435 \u0438 \u0433\u0438\u0431\u043a\u0438\u0435. \u041e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u0435\u0442 \u0438\u0445 \u0435\u0449\u0435 \u0438 \u0441\u0442\u0440\u0435\u043c\u043b\u0435\u043d\u0438\u0435 \u0440\u0435\u0448\u0438\u0442\u044c \u0437\u0430\u0434\u0430\u0447\u0443 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c: \u0432\u0437\u044f\u0442\u044c \u0432\u0441\u0435 \u043b\u0443\u0447\u0448\u0435\u0435, \u0447\u0442\u043e \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u0435\u0442 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u043e\u0435 API, \u0438 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043f\u043e\u0432\u0435\u0440\u0445 \u043d\u0435\u0433\u043e \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e JavaScript-\u043a\u043e\u0434\u0430.<\/p>\n<p>\u041a\u0430\u0436\u0434\u044b\u0439 \u0438\u0437 \u044d\u0442\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u0447\u0435\u0440\u0435\u0437 npm, \u043d\u043e \u0447\u0430\u0441\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u043c\u044b\u0439 \u043a\u043e\u0434 \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u0431\u0440\u0430\u0442\u044c \u043f\u0440\u044f\u043c\u043e \u0438\u0437 \u0433\u0438\u0442\u0445\u0430\u0431\u0430.<\/p>\n<p>\u0412\u0441\u0435\u0433\u043e \u0442\u0430\u043a\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0447\u0435\u0442\u044b\u0440\u0435:<\/p>\n<ol>\n<li>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-clamp\" rel=\"noopener noreferrer nofollow\"><strong>handy-clamp<\/strong><\/a><strong> <\/strong>&#8212; React-\u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u0443\u043c\u0435\u044e\u0449\u0438\u0439 \u043f\u0440\u044f\u0442\u0430\u0442\u044c \u043b\u0438\u0448\u043d\u0438\u0435 <em>\u0441\u0442\u0440\u043e\u0447\u043a\u0438<\/em> \u0442\u0435\u043a\u0441\u0442\u0430 \u043f\u043e\u0434 &#171;\u043a\u0430\u0442&#187;;<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-range-slider\" rel=\"noopener noreferrer nofollow\"><strong>handy-range-slider<\/strong><\/a> &#8212; \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043a\u0430\u0441\u0442\u043e\u043c\u0438\u0437\u0438\u0440\u0443\u0435\u043c\u044b\u0439, \u043d\u043e \u0432 \u0442\u043e\u0436\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u0432\u044b\u0431\u043e\u0440\u0430 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u0430;<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-scroll-strip\" rel=\"noopener noreferrer nofollow\"><strong>handy-scroll-strip<\/strong><\/a> &#8212; \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u043d\u0430\u0434 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u043c \u0441\u043a\u0440\u043e\u043b\u043b-\u0431\u0430\u0440\u043e\u043c, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0449\u0430\u044f \u0438\u0437\u044f\u0449\u043d\u043e \u0440\u0430\u0437\u043c\u0435\u0449\u0430\u0442\u044c \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435 \u0434\u043b\u0438\u043d\u043d\u044b\u0435 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u0431\u043b\u043e\u043a\u0438 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430;<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-svg\" rel=\"noopener noreferrer nofollow\"><strong>handy-svg<\/strong><\/a><strong> <\/strong>&#8212; \u0441\u0430\u043c\u044b\u0439 \u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0432\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u043d\u0438\u044f <code>SVG<\/code> \u0432 \u0432\u0435\u0431\u0435. \u042f \u0443\u0436\u0435 <a href=\"https:\/\/habr.com\/ru\/post\/672984\/\" rel=\"noopener noreferrer nofollow\">\u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u043b<\/a> \u043e \u043d\u0435\u043c \u043d\u0430 \u0425\u0430\u0431\u0440\u0435.<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u044d\u0442\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u0445 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u044b \u043f\u043e\u0434\u0445\u043e\u0434\u044b, \u043a \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u044f \u043f\u0440\u0438\u0431\u0435\u0433\u0430\u044e \u0433\u043e\u0434\u0430\u043c\u0438. \u0422\u0435\u043f\u0435\u0440\u044c \u0436\u0435, \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442\u0443 \u0432 <strong>handy-ones<\/strong>, \u044f \u0441\u043c\u043e\u0433 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0438\u0445 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u043c\u0438 \u0432\u0441\u0435\u043c. \u0410 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043d\u043e\u0432\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u0438\u043b\u0438 \u0443\u0442\u0438\u043b\u0438\u0442\u0443 \u043c\u043e\u0436\u043d\u043e \u0431\u0443\u043a\u0432\u0430\u043b\u044c\u043d\u043e \u0437\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0438\u043d\u0443\u0442, \u043f\u0440\u044f\u043c\u043e \u0437\u0430 \u0437\u0430\u0432\u0442\u0440\u0430\u043a\u043e\u043c.<\/p>\n<p>\u0420\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u043e \u043f\u0435\u0440\u0432\u043e\u0439 \u043f\u0430\u0447\u043a\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435.<\/p>\n<h2>Handy clamp<\/h2>\n<p><a href=\"https:\/\/ivliag.github.io\/handy-ones\/?story=handy-clamp--basic\" rel=\"noopener noreferrer nofollow\"><strong>\u0414\u0435\u043c\u043e<\/strong><\/a> | <a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-clamp\" rel=\"noopener noreferrer nofollow\"><strong>\u0418\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438<\/strong><\/a><\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/4ad\/a65\/ebc\/4ada65ebc3e5079c1e8328d68fa7fac2.png\" alt=\"handy-clamp \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442 \u043f\u0435\u0440\u0432\u044b\u0435 \u0434\u0432\u0435 \u0441\u0442\u0440\u043e\u0447\u043a\u0438 \u0442\u0435\u043a\u0441\u0442\u0430\" title=\"handy-clamp \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442 \u043f\u0435\u0440\u0432\u044b\u0435 \u0434\u0432\u0435 \u0441\u0442\u0440\u043e\u0447\u043a\u0438 \u0442\u0435\u043a\u0441\u0442\u0430\" width=\"944\" height=\"338\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/4ad\/a65\/ebc\/4ada65ebc3e5079c1e8328d68fa7fac2.png\"\/><figcaption>handy-clamp \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442 \u043f\u0435\u0440\u0432\u044b\u0435 \u0434\u0432\u0435 \u0441\u0442\u0440\u043e\u0447\u043a\u0438 \u0442\u0435\u043a\u0441\u0442\u0430<\/figcaption><\/figure>\n<p>\u0422\u0438\u043f\u043e\u0432\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430 &#8212; \u0441\u043f\u0440\u044f\u0442\u0430\u0442\u044c \u043b\u0438\u0448\u043d\u0438\u0439 \u0442\u0435\u043a\u0441\u0442 \u043f\u043e\u0434 &#171;\u043a\u0430\u0442&#187;. \u041e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u044c <strong>handy-clamp<\/strong> \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u043d \u0443\u043c\u0435\u0435\u0442 \u043e\u0431\u0440\u0435\u0437\u0430\u0442\u044c \u0442\u0435\u043a\u0441\u0442 \u043f\u043e \u0441\u0442\u0440\u043e\u0447\u043a\u0430\u043c, \u0430 \u0435\u0449\u0435 \u043e\u043d \u043e\u0442\u0437\u044b\u0432\u0447\u0438\u0432\u044b\u0439 \u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439. \u0412 \u043e\u0441\u043d\u043e\u0432\u0435 \u0435\u0433\u043e \u0440\u0430\u0431\u043e\u0442\u044b \u0434\u0432\u0435 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438:<\/p>\n<ol>\n<li>\n<p>\u0422\u0430\u043a \u0438 <a href=\"https:\/\/drafts.csswg.org\/css-overflow-3\/#line-clamp\" rel=\"noopener noreferrer nofollow\">\u043d\u0435 \u0441\u0442\u0430\u0432\u0448\u0435\u0435 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043e\u043c<\/a>, \u043d\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0430\u043d\u043d\u043e\u0435 <a href=\"https:\/\/caniuse.com\/css-line-clamp\" rel=\"noopener noreferrer nofollow\">\u0432\u0441\u0435\u043c\u0438 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u043c\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u043c\u0438<\/a> css-\u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <code>line-clamp<\/code><\/p>\n<\/li>\n<li>\n<p><code>ResizeObserver<\/code> &#8212; \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u043e\u0435 API \u0434\u043b\u044f \u043e\u0442\u0441\u043b\u0435\u0436\u0438\u0432\u0430\u043d\u0438\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439 \u0440\u0430\u0437\u043c\u0435\u0440\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430.<\/p>\n<\/li>\n<\/ol>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u0432\u0441\u0435 \u043f\u0440\u043e\u0441\u0442\u043e &#8212; \u0441\u043b\u0435\u0434\u0438\u043c \u0437\u0430 \u0440\u0430\u0437\u043c\u0435\u0440\u0430\u043c\u0438 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0441 \u0442\u0435\u043a\u0441\u0442\u043e\u043c, \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u0442\u0441\u044f \u043b\u0438 \u043e\u043d \u0432 \u0441\u0432\u043e\u0435\u0433\u043e \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044f:<\/p>\n<pre><code class=\"javascript\">const isOverflowing = el.scrollHeight > el.clientHeight<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u043d\u0435 \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u0442\u0441\u044f &#8212; \u0440\u0438\u0441\u0443\u0435\u043c \u043a\u043d\u043e\u043f\u043a\u0443 &#171;\u041f\u043e\u043a\u0430\u0437\u0430\u0442\u044c \u0435\u0449\u0435&#187;, \u0435\u0441\u043b\u0438 \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u0442\u0441\u044f &#8212; \u0441\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u044d\u0442\u0443 \u0436\u0435 \u043a\u043d\u043e\u043f\u043a\u0443. \u0417\u0430\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u043c \u0438\u0434\u0435\u044e \u0432 React-\u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u043f\u0440\u0438\u0434\u0443\u043c\u044b\u0432\u0430\u0435\u043c \u043d\u0435\u0437\u0430\u043c\u044b\u0441\u043b\u043e\u0432\u0430\u0442\u043e\u0435 API.<\/p>\n<pre><code class=\"xml\">import {HandyClamp} from '@handy-ones\/handy-clamp';  &lt;HandyClamp lines={2}>    \u0414\u043b\u0438\u043d\u043d\u044b\u0439-\u0434\u043b\u0438\u043d\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u0432 \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u0441\u0442\u0440\u043e\u0447\u0435\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430\u0434\u043e \u0441\u043f\u0440\u044f\u0442\u0430\u0442\u044c... &lt;\/HandyClamp><\/code><\/pre>\n<p>\u041f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u043c, \u043b\u044e\u0431\u0443\u0435\u043c\u0441\u044f, \u0441\u0442\u0430\u0432\u0438\u043c \u0447\u0430\u0439\u043d\u0438\u043a, \u0434\u0432\u0438\u0433\u0430\u0435\u043c\u0441\u044f \u0434\u0430\u043b\u044c\u0448\u0435.<\/p>\n<h3>Handy range slider<\/h3>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-range-slider\" rel=\"noopener noreferrer nofollow\"><strong>\u0414\u0435\u043c\u043e<\/strong><\/a> | <a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-range-slider\" rel=\"noopener noreferrer nofollow\"><strong>\u0418\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438<\/strong><\/a><\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/7c9\/ccb\/f2c\/7c9ccbf2c1aa8c09a189fbddb2b1246e.png\" alt=\"handy-range-slider \u043c\u043e\u0436\u043d\u043e \u0440\u0430\u0441\u043a\u0440\u0430\u0448\u0438\u0432\u0430\u0442\u044c\" title=\"handy-range-slider \u043c\u043e\u0436\u043d\u043e \u0440\u0430\u0441\u043a\u0440\u0430\u0448\u0438\u0432\u0430\u0442\u044c\" width=\"944\" height=\"338\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/7c9\/ccb\/f2c\/7c9ccbf2c1aa8c09a189fbddb2b1246e.png\"\/><figcaption>handy-range-slider \u043c\u043e\u0436\u043d\u043e \u0440\u0430\u0441\u043a\u0440\u0430\u0448\u0438\u0432\u0430\u0442\u044c<\/figcaption><\/figure>\n<p>\u0415\u0449\u0435 \u0441\u043e \u0432\u0440\u0435\u043c\u0435\u043d jQuery \u044f \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0441\u043e \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e\u043c \u0440\u0430\u0437\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0432\u044b\u0431\u043e\u0440\u0430 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u0430, \u0441\u0440\u0435\u0434\u0438 \u043d\u0438\u0445 <a href=\"https:\/\/jqueryui.com\/slider\/\" rel=\"noopener noreferrer nofollow\">\u0441\u043b\u0430\u0439\u0434\u0435\u0440 \u0438\u0437 jQuery UI<\/a>, \u0437\u0430\u043c\u0435\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0435 standalone-\u0440\u0435\u0448\u0435\u043d\u0438\u0435 <a href=\"https:\/\/refreshless.com\/nouislider\/\" rel=\"noopener noreferrer nofollow\">noUiSlider<\/a>, React-\u043e\u0431\u0435\u0440\u0442\u043a\u0438 \u0432 <a href=\"https:\/\/mui.com\/material-ui\/react-slider\/\" rel=\"noopener noreferrer nofollow\">Material UI<\/a> \u0438 <a href=\"https:\/\/ant.design\/components\/slider\/\" rel=\"noopener noreferrer nofollow\">Ant Design<\/a>. \u0418 \u044f \u0437\u043d\u0430\u044e \u043f\u0440\u043e \u043e\u043f\u044b\u0442 \u0440\u0435\u0431\u044f\u0442 \u0438\u0437 \u0422\u0438\u043d\u044c\u043a\u043e\u0444\u0444 \u0441 \u043a\u0430\u0441\u0442\u043e\u043c\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0430 range-\u0438\u043d\u043f\u0443\u0442\u0430, \u044d\u0442\u043e \u0438 \u043f\u0440\u0430\u0432\u0434\u0430 <a href=\"https:\/\/habr.com\/ru\/company\/tinkoff\/blog\/667254\/\" rel=\"noopener noreferrer nofollow\">\u0432\u043f\u0435\u0447\u0430\u0442\u043b\u044f\u044e\u0449\u0430\u044f<\/a> \u0440\u0430\u0431\u043e\u0442\u0430. \u041d\u043e \u0442\u0430\u0449\u0438\u0442\u044c \u0432 \u043f\u0440\u043e\u0435\u043a\u0442 \u0442\u044f\u0436\u0435\u043b\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0441\u043d\u0430\u0440\u0443\u0436\u0438 \u043d\u0435 \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c, \u0430 \u043f\u043e\u0434\u0445\u043e\u0434 \u0441 css-\u043a\u0430\u0441\u0442\u043e\u043c\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0430 \u043d\u0435 \u0434\u0430\u0435\u0442 \u043f\u043e\u043b\u043d\u043e\u0439 \u0433\u0438\u0431\u043a\u043e\u0441\u0442\u0438. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u043f\u043e\u043a\u0440\u0430\u0441\u0438\u0442\u044c \u0442\u0440\u0435\u043a \u0441\u043b\u0430\u0439\u0434\u0435\u0440\u0430 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043e\u043c. \u041f\u043b\u044e\u0441, css-\u043c\u0430\u0433\u0438\u044f \u0432\u043e\u043a\u0440\u0443\u0433 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u043c\u0435\u043d\u044f \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0443\u0433\u0430\u0435\u0442, \u044f \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043d\u0438\u043c\u0430\u044e, \u043a\u0430\u043a \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c &#171;\u0442\u0440\u0438 \u0441\u043b\u043e\u044f \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u0430&#187; \u0438 \u043f\u0430\u0447\u043a\u0443 \u0432\u0435\u043d\u0434\u043e\u0440\u043d\u044b\u0445 \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043e\u0432.<\/p>\n<p>\u0414\u043b\u044f \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u043b\u0430\u0439\u0434\u0435\u0440\u0430 \u0441 \u043e\u0434\u043d\u0438\u043c \u043f\u043e\u043b\u0437\u0443\u043d\u043a\u043e\u043c \u044f \u0440\u0435\u0448\u0438\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u0430 \u0434\u043b\u044f \u0433\u0438\u0431\u043a\u043e\u0439 \u0441\u0442\u0438\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b, \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0435\u043d\u043d\u044b\u0435 \u0447\u0435\u0440\u0435\u0437 JavaScript. \u0414\u043b\u044f \u043c\u0435\u043d\u044f \u043b\u0443\u0447\u0448\u0435 \u0432\u0441\u0435\u0433\u043e \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u043f\u043e\u0434\u0445\u043e\u0434:<\/p>\n<ol>\n<li>\n<p>\u0420\u0435\u043d\u0434\u0435\u0440\u0438\u043c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u043b\u0430\u0439\u0434\u0435\u0440 \u043d\u0443\u0436\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0430. \u0418 \u0434\u0435\u043b\u0430\u0435\u043c \u0432\u0441\u0435 \u0435\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u044b\u043c\u0438.<\/p>\n<\/li>\n<li>\n<p>\u0420\u0435\u043d\u0434\u0435\u0440\u0438\u043c <em>\u043f\u043e\u0434 \u043d\u0438\u043c <\/em>\u043f\u0441\u0435\u0432\u0434\u043e-\u043a\u043e\u043d\u0442\u0440\u043e\u043b<em>, <\/em>\u043b\u044e\u0431\u0443\u044e \u0443\u0434\u043e\u0431\u043d\u0443\u044e \u043d\u0430\u043c HTML-\u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0431\u0443\u0434\u0435\u0442 \u043e\u0442\u0432\u0435\u0447\u0430\u0442\u044c \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0437\u0430 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435. \u0421\u0442\u0438\u043b\u0438\u0437\u0443\u0435\u043c \u0435\u0435 \u043a\u0430\u043a \u043d\u0430\u043c \u043d\u0440\u0430\u0432\u0438\u0442\u0441\u044f.<\/p>\n<\/li>\n<li>\n<p>\u0421\u0432\u044f\u0437\u044b\u0432\u0430\u0435\u043c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0438 \u043f\u0441\u0435\u0432\u0434\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044b \u0447\u0435\u0440\u0435\u0437 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u0439\u0442. \u0422\u0443\u0442 \u043d\u0443\u0436\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u0447\u0443\u0442\u044c-\u0447\u0443\u0442\u044c \u0430\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u043a\u0438 \u0438 \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432 \u0440\u0430\u0437\u043d\u044b\u0445 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445.<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u0438\u0442\u043e\u0433\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u043c \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043e\u043c, \u0430 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442\u0441\u044f \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0439 \u0441\u043b\u043e\u0435\u043c \u043d\u0438\u0436\u0435 \u043f\u0441\u0435\u0432\u0434\u043e-\u043a\u043e\u043d\u0442\u0440\u043e\u043b, \u043a\u0430\u0441\u0442\u043e\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0438\u043a\u0430\u043a \u043d\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0430. \u0418 \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u0438 \u044d\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e, \u0438 \u044d\u0442\u043e \u043c\u0430\u043b\u043e \u043a\u043e\u0434\u0430, \u0438 \u044d\u0442\u043e mobile-friendly.<\/p>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 &#8212; \u0434\u0435\u043b\u043e \u0442\u0435\u0445\u043d\u0438\u043a\u0438, \u0442\u0435\u0441\u0442\u0438\u0440\u0443\u0435\u043c \u0432 \u0440\u0430\u0437\u043d\u044b\u0445 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445, \u043f\u0440\u0438\u0434\u0443\u043c\u044b\u0432\u0430\u0435\u043c API, \u0441\u043f\u043e\u0441\u043e\u0431 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u043b\u0435\u0439\u0431\u043b\u043e\u0432, \u043e\u0444\u043e\u0440\u043c\u043b\u044f\u0435\u043c \u043a\u043e\u0434:<\/p>\n<pre><code class=\"xml\">import {HandyRangeSlider} from '@handy-ones\/handy-range-slider';  &lt;HandyRangeSlider     min={50}     max={100}     step={2}     value={10}     labels={[         {value: 50, text: '?'},         {value: 75, text: '?'},         {value: 100, text: '\u2764\ufe0f'}     ]}     onChange={(event, parsedValue) => {}} \/><\/code><\/pre>\n<blockquote>\n<p>\u041f\u0440\u043e\u0435\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0410\u041f\u0418 \u0443 \u0438\u043d\u043f\u0443\u0442\u043e\u0432 \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u043e,  <em>\u043b\u044e\u0431\u044b\u0435 <\/em>\u0438\u043d\u043f\u0443\u0442\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u0432\u0441\u0435\u0433\u043e \u0434\u0432\u0443\u043c\u044f \u043f\u0440\u043e\u043f\u0441\u0430\u043c\u0438: <code>value<\/code> \u0438 <code>onChange<\/code>. \u0410 \u043f\u0435\u0440\u0432\u044b\u043c \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u043e\u043c \u0432 <code>onChange<\/code> <em>\u0432\u0441\u0435\u0433\u0434\u0430<\/em> \u0434\u043e\u043b\u0436\u0435\u043d \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u044c \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u044b\u0439 <code>event<\/code>. \u042d\u0442\u043e\u0442 \u043f\u043e\u0434\u0445\u043e\u0434 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 <a href=\"https:\/\/reactjs.org\/docs\/forms.html\" rel=\"noopener noreferrer nofollow\">React<\/a>, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0441\u0430\u043c\u044b\u0435 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0444\u043e\u0440\u043c\u0430\u043c\u0438: <a href=\"https:\/\/formik.org\/docs\/api\/useField#fieldinputpropsvalue\" rel=\"noopener noreferrer nofollow\">Formik<\/a>, <a href=\"https:\/\/react-hook-form.com\/api\/useform\/register\" rel=\"noopener noreferrer nofollow\">React Hook Form<\/a>, <a href=\"https:\/\/final-form.org\/docs\/react-final-form\/api\/Field\" rel=\"noopener noreferrer nofollow\">React Final Form<\/a>.<\/p>\n<\/blockquote>\n<p>\u0422\u0435\u043a\u0443\u0449\u0435\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432\u043e \u0432\u0441\u0435\u0445 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u043d\u044b\u0445 \u0438 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0432 IE 10+, \u0435\u0441\u043b\u0438 \u044d\u0442\u043e \u043f\u043e \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043f\u0440\u0438\u0447\u0438\u043d\u0435 \u0435\u0449\u0435 \u0432\u0430\u0436\u043d\u043e. \u041d\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0430\u0434\u0430\u043f\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c <strong>handy-range-slider<\/strong> \u0434\u043b\u044f \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u043d\u043e Firefox \u0432\u0441\u0435 \u0435\u0449\u0435 <a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/HTML\/Element\/input\/range#browser_compatibility\" rel=\"noopener noreferrer nofollow\">\u043d\u0435 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0435\u0433\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442<\/a>. <\/p>\n<p>\u0422\u0430\u043a \u0447\u0442\u043e \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u043c \u0442\u043e, \u0447\u0442\u043e \u0435\u0441\u0442\u044c, \u0437\u0430\u043a\u0438\u0434\u044b\u0432\u0430\u0435\u043c \u043f\u0430\u0440\u0443 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u043d\u0430 \u0434\u0435\u043c\u043e-\u0441\u0442\u0435\u043d\u0434, \u0447\u0430\u0439\u043d\u0438\u043a \u043a\u0430\u043a \u0440\u0430\u0437 \u0432\u0441\u043a\u0438\u043f\u0435\u043b.<\/p>\n<h2>Handy Scroll Strip<\/h2>\n<p><a href=\"https:\/\/ivliag.github.io\/handy-ones\/?story=handy-scroll-strip--imperative-hanlers\" rel=\"noopener noreferrer nofollow\"><strong>\u0414\u0435\u043c\u043e<\/strong><\/a> | <a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-scroll-strip\" rel=\"noopener noreferrer nofollow\"><strong>\u0418\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438<\/strong><\/a><\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/ec1\/19e\/375\/ec119e375c2d4b5344e606a775acf197.png\" alt=\"handy-scroll-strip \u0438\u0437\u044f\u0449\u043d\u043e \u043f\u0440\u044f\u0447\u0435\u0442 \u043b\u0438\u0448\u043d\u0438\u0439 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0437\u0430 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u043e\u0439\" title=\"handy-scroll-strip \u0438\u0437\u044f\u0449\u043d\u043e \u043f\u0440\u044f\u0447\u0435\u0442 \u043b\u0438\u0448\u043d\u0438\u0439 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0437\u0430 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u043e\u0439\" width=\"944\" height=\"338\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/ec1\/19e\/375\/ec119e375c2d4b5344e606a775acf197.png\"\/><figcaption>handy-scroll-strip \u0438\u0437\u044f\u0449\u043d\u043e \u043f\u0440\u044f\u0447\u0435\u0442 \u043b\u0438\u0448\u043d\u0438\u0439 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0437\u0430 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u043e\u0439<\/figcaption><\/figure>\n<p>\u041f\u0440\u043e\u0441\u0442\u0435\u0439\u0448\u0438\u0439, \u043d\u043e \u0432 \u0442\u043e \u0436\u0435 \u0432\u0440\u0435\u043c\u044f \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0438\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442: \u043f\u043e\u043b\u043e\u0441\u0430 \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0438 \u0431\u0435\u0437 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u0445 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043e\u0432, \u043d\u043e \u0441 \u0444\u0435\u0439\u0434\u043e\u043c \u043f\u043e \u043a\u0440\u0430\u044f\u043c \u0438 \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u044b\u043c API. \u042f \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b \u043d\u0430 \u0435\u0433\u043e \u043e\u0441\u043d\u043e\u0432\u0435 \u0433\u0430\u043b\u0435\u0440\u0435\u0438, \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u0443\u044e \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u044e, \u043f\u0440\u044f\u0442\u0430\u043b \u0432 \u043d\u0435\u0433\u043e \u043e\u0433\u0440\u043e\u043c\u043d\u044b\u0435 multistep-\u0444\u043e\u0440\u043c\u044b \u0438 \u0448\u0438\u0440\u043e\u0447\u0435\u043d\u043d\u044b\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b. \u041e\u043d \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439, \u0432\u0435\u0434\u044c \u0441\u043a\u0440\u043e\u043b\u043b \u0432 \u043d\u0435\u043c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439. \u0425\u043e\u0440\u043e\u0448\u0435\u0439 \u0438\u0434\u0435\u0435\u0439 \u0431\u0443\u0434\u0435\u0442 \u0442\u0430\u043a\u0436\u0435 \u0435\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0441 <a href=\"https:\/\/web.dev\/css-scroll-snap\/\" rel=\"noopener noreferrer nofollow\">css-scroll-step<\/a>.<\/p>\n<p>\u0412 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043e\u043d \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442:<\/p>\n<ol>\n<li>\n<p>\u0421\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u043f\u043e\u043b\u043e\u0441\u044b \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0438<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0431\u043b\u043e\u043a\u0438 \u0441 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043e\u043c \u043f\u043e \u043a\u0440\u0430\u044f\u043c, \u0441\u043b\u0443\u0448\u0430\u0435\u043c \u0441\u043a\u0440\u043e\u043b\u043b, \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u043c \u0438\u0445 \u0438 \u043f\u0440\u044f\u0447\u0435\u043c.<\/p>\n<\/li>\n<li>\n<p>\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u0435 API, \u0441 \u0443\u0436\u0430\u0441\u043e\u043c \u043f\u0440\u043e\u0434\u0438\u0440\u0430\u044f\u0441\u044c \u0447\u0435\u0440\u0435\u0437 <code>useImperativeHandle<\/code> \u0438 \u0432\u0441\u043f\u043e\u043c\u0438\u043d\u0430\u044f, \u043a\u0430\u043a \u0443\u0434\u043e\u0431\u043d\u043e \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043e \u0432 \u043a\u043b\u0430\u0441\u0441\u043e\u0432\u044b\u0445, \u0430 \u043d\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u0445.<\/p>\n<\/li>\n<\/ol>\n<p>\u0421\u043a\u0440\u044b\u0442\u044c \u043f\u043e\u043b\u043e\u0441\u044b \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0438 \u043c\u043e\u0436\u043d\u043e \u0447\u0435\u0440\u0435\u0437 css, \u044d\u0442\u043e \u043a\u0440\u043e\u0441\u0441\u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u043e, \u0445\u043e\u0442\u044f \u0438 \u043c\u043d\u043e\u0433\u043e\u0441\u043b\u043e\u0432\u043d\u043e:<\/p>\n<pre><code class=\"css\">.content {     overflow-x: scroll;     overflow-y: hidden;     -webkit-overflow-scrolling: touch;     -ms-overflow-style: none;  \/* Internet Explorer 10+ *\/     scrollbar-width: none;  \/* Firefox *\/ }  .content::-webkit-scrollbar {     display: none;  \/* Safari and Chrome *\/ }<\/code><\/pre>\n<p>\u0412 \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u043c API \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u0439 <code>Element.scrollTo()<\/code>, \u043e\u043d \u0443\u0436\u0435 \u0434\u0430\u0432\u043d\u043e \u0443\u043c\u0435\u0435\u0442 \u0441\u043a\u0440\u043e\u043b\u043b\u0438\u0442\u044c <em>\u043f\u043b\u0430\u0432\u043d\u043e<\/em>:<\/p>\n<pre><code class=\"javascript\">element.scrollTo({     left: 2000,     behavior: 'smooth' });<\/code><\/pre>\n<p>\u0412\u043e\u0442 \u0438 \u0432\u0441\u0451, \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0442\u0443\u0442 \u0431\u0443\u0434\u0443\u0442 \u0441 \u0442\u0438\u043f\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e API \u0438 <code>forwardRef<\/code>, \u043d\u043e \u0435\u0441\u0442\u044c \u0445\u043e\u0440\u043e\u0448\u0438\u0439 \u043f\u0440\u0438\u043c\u0435\u0440 \u0432 <a href=\"https:\/\/react-typescript-cheatsheet.netlify.app\/docs\/basic\/getting-started\/hooks\/#useimperativehandle\" rel=\"noopener noreferrer nofollow\">React Typescript Cheatsheet<\/a>, \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0442\u0430\u043a\u043e\u0439:<\/p>\n<pre><code class=\"typescript\">interface ImperativeHandlers {     getContainer: () => HTMLDivElement | null;     getScrollLeft: () => number;     scrollTo: (value: number) => void; }<\/code><\/pre>\n<p>\u0420\u0435\u0448\u0438\u0442\u044c \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u043d\u0430\u0448 \u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442. \u0417\u0430\u043a\u0438\u0434\u044b\u0432\u0430\u0435\u043c \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e \u043f\u0430\u043f\u043a\u0443, \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u043c \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u0442\u0430\u043c \u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u0432 \u0445\u043e\u043b\u043e\u0434\u0438\u043b\u044c\u043d\u0438\u043a\u0435.<\/p>\n<h2>Handy SVG<\/h2>\n<p><a href=\"https:\/\/ivliag.github.io\/handy-ones\/?story=handy-svg--colored\" rel=\"noopener noreferrer nofollow\"><strong>\u0414\u0435\u043c\u043e<\/strong><\/a> | <a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-svg\" rel=\"noopener noreferrer nofollow\"><strong>\u0418\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438<\/strong><\/a><\/p>\n<figure class=\"full-width\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/de4\/551\/375\/de4551375d12890447cd6c93e0ebe7c2.png\" alt=\"SVG-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0447\u0435\u0440\u0435\u0437 handy-svg, \u043c\u043e\u0436\u043d\u043e \u043a\u0440\u0430\u0441\u0438\u0442\u044c \u0432 css\" title=\"SVG-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0447\u0435\u0440\u0435\u0437 handy-svg, \u043c\u043e\u0436\u043d\u043e \u043a\u0440\u0430\u0441\u0438\u0442\u044c \u0432 css\" width=\"944\" height=\"338\" data-src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/de4\/551\/375\/de4551375d12890447cd6c93e0ebe7c2.png\"\/><figcaption>SVG-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0447\u0435\u0440\u0435\u0437 handy-svg, \u043c\u043e\u0436\u043d\u043e \u043a\u0440\u0430\u0441\u0438\u0442\u044c \u0432 css<\/figcaption><\/figure>\n<p>\u041d\u0435 \u0431\u0443\u0434\u0443 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u044d\u0442\u043e\u0439 \u0443\u0442\u0438\u043b\u0438\u0442\u0435, \u043f\u0440\u043e \u043d\u0435\u0435 \u0443 \u043c\u0435\u043d\u044f \u0431\u044b\u043b\u0430 <a href=\"https:\/\/habr.com\/ru\/post\/672984\/\" rel=\"noopener noreferrer nofollow\">\u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f \u043d\u0430 \u0425\u0430\u0431\u0440\u0435<\/a>. \u041d\u0430\u043f\u043e\u043c\u043d\u044e \u0442\u043e\u043b\u044c\u043a\u043e, \u0447\u0442\u043e \u0441 \u0435\u0435 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043c\u043e\u0436\u043d\u043e \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u0438 \u0432\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0442\u044c SVG-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u0432 web-\u043f\u0440\u043e\u0435\u043a\u0442\u044b \u0441 \u043b\u044e\u0431\u044b\u043c \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u043c \u0441\u0442\u0435\u043a\u043e\u043c. \u041f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c \u043e\u043d\u0430 \u0434\u0435\u043b\u0430\u0435\u0442 fetch-\u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430 SVG-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439, \u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u0442 \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435 \u0441\u043f\u0440\u0430\u0439\u0442 \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432 \u0438 \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 React \u0438 standalone API \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438:<\/p>\n<pre><code class=\"xml\">import {HandySvg} from '@handy-ones\/handy-svg'; import iconSrc from '.\/icon.svg';  export const Icon = () => (     &lt;HandySvg         src={iconSrc}         className=\"icon\"         width=\"32\"         height=\"32\"     \/> );<\/code><\/pre>\n<p>\u0423\u0442\u0438\u043b\u0438\u0442\u0430<strong> handy-svg<\/strong> \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043e\u0432\u0430\u043b\u0430 \u043a\u0430\u043a \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0435\u0435 \u0447\u0430\u0441\u0442\u044c\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 <strong>handy-ones <\/strong>\u043d\u0435 \u0441\u043e\u0441\u0442\u0430\u0432\u0438\u0442 \u0442\u0440\u0443\u0434\u0430. \u0411\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0438\u0437\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0441\u0442\u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u0432\u043d\u0443\u0442\u0440\u0438 \u043c\u043e\u043d\u043e\u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f \u043d\u0435 \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u0434\u0430\u0436\u0435 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0441\u0442\u0430\u0440\u044b\u0445 \u0438 \u043d\u043e\u0432\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a, npm \u0445\u043e\u0440\u043e\u0448\u043e \u0441\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0441 \u044d\u0442\u0438\u043c \u0441\u0430\u043c. \u041f\u043e\u0440\u044f\u0434\u043e\u043a \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439 \u0442\u0430\u043a\u043e\u0439 \u0436\u0435, \u043a\u0430\u043a \u0441 \u043d\u043e\u0432\u044b\u043c\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u043c\u0438: \u043d\u043e\u0432\u0430\u044f \u043f\u0430\u043f\u043a\u0430, \u043d\u043e\u0432\u044b\u0439 package.json, \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u043c \u0438 \u0432\u044b\u0434\u044b\u0445\u0430\u0435\u043c. \u041d\u0430 \u0441\u0435\u0433\u043e\u0434\u043d\u044f \u043a\u0430\u0436\u0435\u0442\u0441\u044f \u0445\u0432\u0430\u0442\u0438\u0442.<\/p>\n<h2>Boilerplate<\/h2>\n<p>\u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u0447\u0430\u0441\u0442\u044c \u044d\u0442\u0438\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u0430\u044f \u0438 \u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0442\u0430\u043a\u043e\u0439 \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u043e\u0439 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b, \u0430, \u043c\u043e\u0436\u0435\u0442, \u0438 \u0438\u0445 \u043f\u0443\u0431\u043b\u0438\u043a\u0430\u0446\u0438\u044f \u0438\u0437\u0431\u044b\u0442\u043e\u0447\u043d\u0430. \u041d\u043e, \u0432\u043e-\u043f\u0435\u0440\u0432\u044b\u0445, \u043e\u0441\u043d\u043e\u0432\u043d\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430 \u043f\u0435\u0440\u0432\u044b\u0445 \u0447\u0435\u0442\u044b\u0440\u0435\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 &#8212; \u043a\u0430\u043a \u0440\u0430\u0437 \u043f\u043e\u043f\u0438\u043b\u043e\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442, \u0430 \u0432\u043e-\u0432\u0442\u043e\u0440\u044b\u0445, \u0432\u044b \u043d\u0438\u043a\u043e\u0433\u0434\u0430 \u043d\u0435 \u0437\u043d\u0430\u0435\u0442\u0435, \u0447\u0442\u043e \u0438\u0437 \u0432\u0430\u0448\u0438\u0445 \u0438\u0434\u0435\u0439 \u0431\u0443\u0434\u0435\u0442 \u043f\u043e\u043b\u0435\u0437\u043d\u043e \u0441\u043e\u043e\u0431\u0449\u0435\u0441\u0442\u0432\u0443, \u0430 \u0447\u0442\u043e \u043d\u0435\u0442.<\/p>\n<p>\u041c\u043e\u0439 \u0441\u043e\u0432\u0435\u0442 &#8212; \u043d\u0435 \u043d\u0430\u0434\u043e \u0434\u043e\u043b\u0433\u043e \u043f\u044b\u0445\u0442\u0435\u0442\u044c \u0438 \u0432\u044b\u043c\u0443\u0447\u0438\u0432\u0430\u0442\u044c \u0447\u0442\u043e-\u0442\u043e \u0437\u0430\u0443\u043c\u043d\u043e\u0435, \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u0445\u043e\u0440\u043e\u0448\u0438\u0445 \u0440\u0435\u0448\u0435\u043d\u0438\u0439 \u043f\u0440\u043e\u0441\u0442\u044b\u0435. \u0413\u043e\u0440\u0430\u0437\u0434\u043e \u0432\u0430\u0436\u043d\u0435\u0435 \u043f\u0440\u0438\u043d\u0446\u0438\u043f <strong>fail-fast <\/strong>&#8212; \u043e\u0444\u043e\u0440\u043c\u0438\u0442\u0435 \u0441\u0432\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u043f\u043e\u0434\u0435\u043b\u0438\u0442\u0435\u0441\u044c \u0438\u043c, \u0432\u044b\u0441\u043b\u0443\u0448\u0430\u0439\u0442\u0435 \u043a\u0440\u0438\u0442\u0438\u043a\u0443, \u0434\u0432\u0438\u0433\u0430\u0439\u0442\u0435\u0441\u044c \u0434\u0430\u043b\u044c\u0448\u0435. \u0414\u0430\u0436\u0435 \u0441\u0442\u0435\u043d\u0434\u0430\u043f-\u043a\u043e\u043c\u0438\u043a\u0438 \u0441 \u043c\u043d\u043e\u0433\u043e\u043b\u0435\u0442\u043d\u0438\u043c \u043e\u043f\u044b\u0442\u043e\u043c \u043d\u0435 \u043f\u043e\u043d\u0438\u043c\u0430\u044e\u0442, \u0441\u043c\u0435\u0448\u043d\u0430\u044f \u043b\u0438 \u0448\u0443\u0442\u043a\u0430, \u043f\u043e\u043a\u0430 \u043d\u0435 \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443\u0442 \u0435\u0435 \u043f\u0435\u0440\u0435\u0434 \u0430\u0443\u0434\u0438\u0442\u043e\u0440\u0438\u0435\u0439*. \u0412\u0430\u0436\u043d\u043e \u0434\u0435\u043b\u0430\u0442\u044c \u043b\u0435\u0433\u043a\u043e \u0438 \u043f\u0440\u043e\u0441\u0442\u043e, \u043a\u0430\u043a \u0449\u0435\u043b\u043a\u0430\u0442\u044c \u043f\u0430\u043b\u044c\u0446\u0430\u043c\u0438, \u0442\u043e\u0433\u0434\u0430 \u0448\u0430\u043d\u0441\u044b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0447\u0442\u043e-\u0442\u043e \u043f\u043e-\u043d\u0430\u0441\u0442\u043e\u044f\u0449\u0435\u043c\u0443 \u043f\u043e\u043b\u0435\u0437\u043d\u043e\u0435 \u0441\u0438\u043b\u044c\u043d\u043e \u0432\u043e\u0437\u0440\u0430\u0441\u0442\u0430\u044e\u0442.<\/p>\n<p>\u0412\u043e\u043f\u0440\u043e\u0441\u044b, \u043a\u043e\u043c\u043c\u0435\u043d\u0442\u0430\u0440\u0438\u0438 \u0430 \u0442\u0430\u043a\u0436\u0435 \u043f\u0443\u043b-\u0440\u0435\u043a\u0432\u0435\u0441\u0442\u044b \u0432\u0441\u044f\u0447\u0435\u0441\u043a\u0438 \u043f\u0440\u0438\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0442\u0441\u044f.<\/p>\n<p>\u042f \u0431\u0443\u0434\u0443 \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u0442\u044c <strong>handy-ones <\/strong>\u043f\u043e \u043c\u0435\u0440\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0435\u0439, \u0437\u0430 \u0437\u0430\u0432\u0442\u0440\u0430\u043a\u043e\u043c \u0438 \u0432 \u0434\u043e\u0440\u043e\u0433\u0435, \u0438 \u0432 \u043b\u044e\u0431\u043e\u0435 \u0443\u0434\u043e\u0431\u043d\u043e\u0435 \u0432\u0440\u0435\u043c\u044f, \u0433\u043b\u0430\u0432\u043d\u043e\u0435, \u0447\u0442\u043e \u0442\u0435\u043f\u0435\u0440\u044c \u0443 \u043c\u0435\u043d\u044f \u0435\u0441\u0442\u044c \u043e\u0442\u043b\u0438\u0447\u043d\u044b\u0439 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442 \u0434\u043b\u044f \u044d\u0442\u043e\u0433\u043e. \u041a\u0430\u043a \u0440\u0430\u0437 \u043f\u0440\u043e \u043d\u0435\u0433\u043e, \u0430 \u0442\u0430\u043a\u0436\u0435 \u043f\u0440\u043e \u0442\u043e, \u043f\u043e\u0447\u0435\u043c\u0443 \u044f \u043d\u0435 \u0441\u0442\u0430\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c lerna, tsup, esbuild, storybook, yarn \u0438 \u0432\u0441\u0435\u0440\u044c\u0435\u0437 \u043f\u043e\u0434\u0443\u043c\u044b\u0432\u0430\u043b \u043f\u0440\u043e gulp, \u044f \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u0441\u0442\u0430\u0442\u044c\u0435.<\/p>\n<hr\/>\n<p>* \u0412\u0438\u0434\u0435\u043e, \u043d\u0430 \u043a\u043e\u0442\u043e\u0440\u043e\u043c \u041b\u0443\u0438 \u0421\u0438 \u041a\u0435\u0439 \u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u0435\u0442 \u043f\u0440\u043e \u044d\u0442\u043e, \u0443\u0434\u0430\u043b\u0438\u043b\u0438 \u0441 \u042e\u0442\u0443\u0431\u0430, \u043f\u0440\u043e \u043d\u0435\u0433\u043e \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u043e\u043c\u043d\u0438\u0442 <a href=\"https:\/\/www.reddit.com\/r\/videos\/comments\/63awf7\/louis_ck_says_they_should_stop_making_porn\/?utm_source=share&amp;utm_medium=web2x&amp;context=3\" rel=\"noopener noreferrer nofollow\">reddit<\/a> \u0438, \u044f \u043d\u0430\u0434\u0435\u044e\u0441\u044c, \u043a\u0442\u043e-\u0442\u043e \u0438\u0437 \u0447\u0438\u0442\u0430\u0442\u0435\u043b\u0435\u0439.<\/p>\n<\/p>\n<\/div>\n<\/div>\n<\/div>\n<div class=\"v-portal\" style=\"display:none;\"><\/div>\n<\/div>\n<p> <!----> <!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/post\/694510\/\"> https:\/\/habr.com\/ru\/post\/694510\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0414\u0435\u043b\u0438\u0442\u044c\u0441\u044f \u0441\u0432\u043e\u0438\u043c\u0438 \u0438\u0434\u0435\u044f\u043c\u0438 \u0441 \u0441\u043e\u043e\u0431\u0449\u0435\u0441\u0442\u0432\u043e\u043c &#8212; \u0445\u043e\u0440\u043e\u0448\u043e \u0438 \u043f\u043e\u043b\u0435\u0437\u043d\u043e. \u042d\u0442\u043e \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u0435\u0442 \u0440\u0430\u0437\u0432\u0438\u0432\u0430\u0442\u044c\u0441\u044f, \u043f\u0435\u0440\u0435\u043d\u0438\u043c\u0430\u0442\u044c \u043b\u0443\u0447\u0448\u0438\u0435 \u043f\u0440\u0430\u043a\u0442\u0438\u043a\u0438, \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u044c \u043d\u043e\u0432\u044b\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b, \u0443\u0447\u0438\u0442\u044c\u0441\u044f \u043e\u0444\u043e\u0440\u043c\u043b\u044f\u0442\u044c \u0441\u0432\u043e\u0438 \u0440\u0435\u0448\u0435\u043d\u0438\u044f. \u041d\u043e \u043a\u0430\u043a\u043e\u0439 \u043a\u043e\u0434 \u0441\u0442\u043e\u0438\u0442 \u0432\u044b\u043d\u043e\u0441\u0438\u0442\u044c \u0432 \u043e\u0431\u0449\u0438\u0439 \u0434\u043e\u0441\u0442\u0443\u043f? \u0418 \u043a\u0430\u043a \u0434\u0435\u043b\u0430\u0442\u044c \u044d\u0442\u043e \u043d\u0430 \u043f\u043e\u0441\u0442\u043e\u044f\u043d\u043d\u043e\u0439 \u043e\u0441\u043d\u043e\u0432\u0435? \u0427\u0442\u043e\u0431\u044b \u0440\u0430\u0437\u043e\u0431\u0440\u0430\u0442\u044c\u0441\u044f \u0432 \u044d\u0442\u0438\u0445 \u0432\u043e\u043f\u0440\u043e\u0441\u0430\u0445, \u044f \u0440\u0435\u0448\u0438\u043b \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0441\u0432\u043e\u0439 <strong>JavaScript OpenSource Boilerplate <\/strong>&#8212; \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0443\u044e, \u043d\u043e \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u0440\u0430\u0441\u0448\u0438\u0440\u044f\u0435\u043c\u0443\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0443 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432. \u042f \u043d\u0430\u0437\u0432\u0430\u043b \u0435\u0451 <a href=\"https:\/\/github.com\/ivliag\/handy-ones\" rel=\"noopener noreferrer nofollow\"><strong>handy-ones<\/strong><\/a>.<\/p>\n<h2>\u0417\u0430\u0434\u0430\u0447\u0430<\/h2>\n<p>\u041d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u0437\u0430\u0434\u0430\u0447\u0430 \u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u0443\u0435\u0442\u0441\u044f \u0434\u0430\u0436\u0435 \u0448\u0438\u0440\u0435, \u043e\u0441\u043d\u043e\u0432\u043d\u043e\u0439 \u043c\u043e\u0442\u0438\u0432 \u0432 \u043b\u044e\u0431\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 &#8212; \u0438\u0441\u0441\u043b\u0435\u0434\u043e\u0432\u0430\u0442\u0435\u043b\u044c\u0441\u043a\u0438\u0439. \u041a\u0430\u0436\u0434\u044b\u0439 \u0434\u0435\u043d\u044c \u0432 JavaScript-\u043c\u0438\u0440\u0435 \u043f\u043e\u044f\u0432\u043b\u044f\u044e\u0442\u0441\u044f \u043d\u043e\u0432\u044b\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b \u0438 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438, \u043f\u0440\u043e\u0442\u0438\u0432\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 ui-\u0444\u0440\u0435\u0439\u043c\u0432\u043e\u0440\u043a\u043e\u0432 \u0441\u043c\u0435\u043d\u0438\u043b\u043e\u0441\u044c \u0431\u043e\u0440\u044c\u0431\u043e\u0439 js-\u0440\u0430\u043d\u0442\u0430\u0439\u043c\u043e\u0432, \u0431\u0430\u043d\u0434\u043b\u0435\u0440\u043e\u0432, \u0441\u0442\u0435\u0439\u0442-\u043c\u0435\u043d\u0435\u0434\u0436\u0435\u0440\u043e\u0432, \u0443\u0442\u0438\u043b\u0438\u0442 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u043c\u043e\u043d\u043e\u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f\u043c\u0438. \u041c\u043d\u0435 \u043f\u043e\u043d\u0430\u0434\u043e\u0431\u0438\u043b\u0441\u044f \u043f\u0440\u043e\u0435\u043a\u0442, \u0432\u043d\u0443\u0442\u0440\u0438 \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u044f \u0441\u043c\u043e\u0433\u0443 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0441 \u043d\u043e\u0432\u044b\u043c\u0438 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u044f\u043c\u0438, \u0430 \u0443\u0434\u0430\u0447\u043d\u044b\u0435 \u044d\u043a\u0441\u043f\u0435\u0440\u0438\u043c\u0435\u043d\u0442\u044b \u043b\u0435\u0433\u043a\u043e \u043e\u0444\u043e\u0440\u043c\u043b\u044f\u0442\u044c \u0438 \u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u0442\u044c. \u042f \u0441\u0444\u043e\u0440\u043c\u0443\u043b\u0438\u0440\u043e\u0432\u0430\u043b \u043a \u043d\u0435\u043c\u0443 \u0442\u0430\u043a\u0438\u0435 \u0442\u0440\u0435\u0431\u043e\u0432\u0430\u043d\u0438\u044f:<\/p>\n<ol>\n<li>\n<p>\u0423\u0434\u043e\u0431\u0441\u0442\u0432\u043e \u0438 \u043a\u043e\u043c\u0444\u043e\u0440\u0442 \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u043a\u0438. \u041f\u0440\u043e\u0435\u043a\u0442 \u0434\u043e\u043b\u0436\u0435\u043d \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0442\u044c\u0441\u044f \u0438 \u0441\u043e\u0431\u0438\u0440\u0430\u0442\u044c\u0441\u044f \u0431\u044b\u0441\u0442\u0440\u043e, \u0434\u043e\u043b\u0436\u043d\u044b \u0431\u044b\u0442\u044c \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b \u0432\u0441\u0435 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u0435 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b: HMR, source-maps \u0438 \u0442\u0434.<\/p>\n<\/li>\n<li>\n<p>\u0423\u0434\u043e\u0431\u0441\u0442\u0432\u043e \u0434\u043b\u044f \u043f\u043e\u0442\u0440\u0435\u0431\u0438\u0442\u0435\u043b\u044f. \u041a\u043e\u043c\u043f\u0438\u043b\u044f\u0446\u0438\u044f \u0432 ES6, d.ts \u0438 source-maps \u0432\u043d\u0443\u0442\u0440\u0438 \u043f\u0430\u043a\u0435\u0442\u043e\u0432. \u041f\u043e\u0441\u0442\u0430\u0432\u043a\u0430 \u0447\u0435\u0440\u0435\u0437 npm.<\/p>\n<\/li>\n<li>\n<p>\u041c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u044b\u0439 time-to-market. \u041e\u0442 \u043d\u0430\u043f\u0438\u0441\u0430\u043d\u0438\u044f \u043a\u043e\u0434\u0430 \u0434\u043e \u0434\u0438\u0441\u0442\u0440\u0438\u0431\u0443\u0446\u0438\u0438 \u0434\u043e\u043b\u0436\u043d\u044b \u043f\u0440\u043e\u0445\u043e\u0434\u0438\u0442\u044c \u043c\u0438\u043d\u0443\u0442\u044b.<\/p>\n<\/li>\n<li>\n<p>\u041d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u044b\u0435 \u0441\u0431\u043e\u0440\u043a\u0430, \u043f\u043e\u0441\u0442\u0430\u0432\u043a\u0430, \u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u043d\u0438\u0435 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0441\u0438\u0441\u0442\u0435\u043c\u044b. \u041a\u0442\u043e \u0437\u043d\u0430\u0435\u0442, \u0447\u0442\u043e \u043d\u043e\u0432\u043e\u0433\u043e \u043f\u0440\u0438\u0434\u0443\u043c\u0430\u044e\u0442 \u0437\u0430\u0432\u0442\u0440\u0430, \u0438 \u0432 \u0447\u0435\u043c \u0437\u0430\u0445\u043e\u0447\u0435\u0442\u0441\u044f \u043f\u043e\u043a\u043e\u0432\u044b\u0440\u044f\u0442\u044c\u0441\u044f?<\/p>\n<\/li>\n<li>\n<p>\u041c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u044f \u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u0430\u044f \u0443\u043d\u0438\u0444\u0438\u043a\u0430\u0446\u0438\u044f \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432.<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u043a\u0443\u043c\u0435\u043d\u0442\u0430\u0446\u0438\u044f \u0438 demo-\u0441\u0442\u0435\u043d\u0434\u044b &#171;\u0438\u0437 \u043a\u043e\u0440\u043e\u0431\u043a\u0438&#187;.<\/p>\n<\/li>\n<\/ol>\n<h2>\u0418\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u044b<\/h2>\n<figure class=\"full-width\"><figcaption><\/figcaption><\/figure>\n<p>\u0422\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u0439 \u0441\u0442\u0435\u043a, \u043f\u043e\u0437\u0432\u043e\u043b\u0438\u0432\u0448\u0438\u0439 \u0440\u0435\u0448\u0438\u0442\u044c \u0431\u043e\u043b\u044c\u0448\u0438\u043d\u0441\u0442\u0432\u043e \u044d\u0442\u0438\u0445 \u0437\u0430\u0434\u0430\u0447, \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c:<\/p>\n<ol>\n<li>\n<p><a href=\"https:\/\/docs.npmjs.com\/about-npm\" rel=\"noopener noreferrer nofollow\">npm<\/a> \u0434\u043b\u044f \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0438 \u0432\u043d\u0435\u0448\u043d\u0438\u0445 \u0438 \u043f\u0435\u0440\u0435\u043b\u0438\u043d\u043a\u043e\u0432\u043a\u0438 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0445 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0435\u0439<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/turborepo.org\/docs\/core-concepts\/why-turborepo\" rel=\"noopener noreferrer nofollow\">turborepo<\/a> \u0434\u043b\u044f \u0437\u0430\u043f\u0443\u0441\u043a\u0430 \u0441\u043a\u0440\u0438\u043f\u0442\u043e\u0432<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/www.typescriptlang.org\/docs\/handbook\/compiler-options.html\" rel=\"noopener noreferrer nofollow\">tsc<\/a> \u0438 <a href=\"https:\/\/github.com\/postcss\/postcss-cli\" rel=\"noopener noreferrer nofollow\">postcss-cli<\/a> \u0434\u043b\u044f \u0441\u0431\u043e\u0440\u043a\u0438 \u043f\u0430\u043a\u0435\u0442\u043e\u0432<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/vitejs.dev\/guide\/why.html\" rel=\"noopener noreferrer nofollow\">vite<\/a> \u0434\u043b\u044f \u0441\u0431\u043e\u0440\u043a\u0438 \u0441\u0435\u0440\u0432\u0438\u0441\u043d\u044b\u0445 \u0431\u0430\u043d\u0434\u043b\u043e\u0432<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/ladle.dev\/\" rel=\"noopener noreferrer nofollow\">ladle<\/a> \u043a\u0430\u043a \u0434\u0432\u0438\u0436\u043e\u043a \u0434\u043b\u044f \u0434\u0435\u043c\u043e-\u0441\u0442\u0435\u043d\u0434\u0430<\/p>\n<\/li>\n<\/ol>\n<p>\u0427\u0430\u0441\u0442\u044c \u044d\u0442\u0438\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u0441\u0443\u043f\u0435\u0440-\u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043d\u044b\u0435, \u0434\u0440\u0443\u0433\u0438\u0435, \u043d\u0430\u043e\u0431\u043e\u0440\u043e\u0442, \u043e\u0447\u0435\u043d\u044c \u0441\u0432\u0435\u0436\u0438\u0435. \u041b\u044e\u0431\u043e\u0439 \u0438\u0437 \u043d\u0438\u0445 \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0437\u0432\u0430\u0442\u044c <a href=\"https:\/\/www.urbandictionary.com\/define.php?term=Holy%20War\" rel=\"noopener noreferrer nofollow\">\u0441\u043f\u043e\u0440\u044b<\/a>. \u042f \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u043f\u0440\u043e \u0432\u044b\u0431\u043e\u0440 \u043a\u0430\u0436\u0434\u043e\u0433\u043e \u0438\u0437 \u043d\u0438\u0445 \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435, \u043f\u043e\u043a\u0430 \u0436\u0435 \u043f\u0440\u043e\u0441\u0442\u043e \u0441\u043a\u0430\u0436\u0443, \u0447\u0442\u043e \u044f \u0438\u043c\u0438 <em>\u0434\u043e\u0432\u043e\u043b\u0435\u043d<\/em>. \u0418 \u043f\u043e\u0434\u0435\u043b\u044e\u0441\u044c \u043f\u0435\u0440\u0432\u044b\u043c\u0438 \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043d\u043d\u044b\u043c\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u043c\u0438 \u043c\u043e\u0435\u0439 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438.<\/p>\n<h2>First ones<\/h2>\n<p>\u041f\u0435\u0440\u0432\u044b\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u044b &#8212; \u0441\u0430\u043c\u044b\u0435 \u043f\u0440\u043e\u0441\u0442\u044b\u0435, \u0431\u0430\u0437\u043e\u0432\u044b\u0435, \u0430\u0442\u043e\u043c\u0430\u0440\u043d\u044b\u0435. \u041d\u043e \u043e\u043d\u0438 \u0436\u0435 \u0438 \u0441\u0430\u043c\u044b\u0435 \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u044b\u0435 \u0438 \u0433\u0438\u0431\u043a\u0438\u0435. \u041e\u0431\u044a\u0435\u0434\u0438\u043d\u044f\u0435\u0442 \u0438\u0445 \u0435\u0449\u0435 \u0438 \u0441\u0442\u0440\u0435\u043c\u043b\u0435\u043d\u0438\u0435 \u0440\u0435\u0448\u0438\u0442\u044c \u0437\u0430\u0434\u0430\u0447\u0443 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u043c \u0441\u043f\u043e\u0441\u043e\u0431\u043e\u043c: \u0432\u0437\u044f\u0442\u044c \u0432\u0441\u0435 \u043b\u0443\u0447\u0448\u0435\u0435, \u0447\u0442\u043e \u043f\u0440\u0435\u0434\u043b\u0430\u0433\u0430\u0435\u0442 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u043e\u0435 API, \u0438 \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043f\u043e\u0432\u0435\u0440\u0445 \u043d\u0435\u0433\u043e \u043c\u0438\u043d\u0438\u043c\u0430\u043b\u044c\u043d\u043e\u0435 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e JavaScript-\u043a\u043e\u0434\u0430.<\/p>\n<p>\u041a\u0430\u0436\u0434\u044b\u0439 \u0438\u0437 \u044d\u0442\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0434\u043e\u0441\u0442\u0443\u043f\u0435\u043d \u0447\u0435\u0440\u0435\u0437 npm, \u043d\u043e \u0447\u0430\u0441\u0442\u043e \u0437\u043d\u0430\u0447\u0438\u043c\u044b\u0439 \u043a\u043e\u0434 \u043c\u043e\u0436\u043d\u043e \u0437\u0430\u0431\u0440\u0430\u0442\u044c \u043f\u0440\u044f\u043c\u043e \u0438\u0437 \u0433\u0438\u0442\u0445\u0430\u0431\u0430.<\/p>\n<p>\u0412\u0441\u0435\u0433\u043e \u0442\u0430\u043a\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0447\u0435\u0442\u044b\u0440\u0435:<\/p>\n<ol>\n<li>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-clamp\" rel=\"noopener noreferrer nofollow\"><strong>handy-clamp<\/strong><\/a><strong> <\/strong>&#8212; React-\u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u0443\u043c\u0435\u044e\u0449\u0438\u0439 \u043f\u0440\u044f\u0442\u0430\u0442\u044c \u043b\u0438\u0448\u043d\u0438\u0435 <em>\u0441\u0442\u0440\u043e\u0447\u043a\u0438<\/em> \u0442\u0435\u043a\u0441\u0442\u0430 \u043f\u043e\u0434 &#171;\u043a\u0430\u0442&#187;;<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-range-slider\" rel=\"noopener noreferrer nofollow\"><strong>handy-range-slider<\/strong><\/a> &#8212; \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043a\u0430\u0441\u0442\u043e\u043c\u0438\u0437\u0438\u0440\u0443\u0435\u043c\u044b\u0439, \u043d\u043e \u0432 \u0442\u043e\u0436\u0435 \u0432\u0440\u0435\u043c\u044f \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u0432\u044b\u0431\u043e\u0440\u0430 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u0430;<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-scroll-strip\" rel=\"noopener noreferrer nofollow\"><strong>handy-scroll-strip<\/strong><\/a> &#8212; \u043d\u0430\u0434\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u043d\u0430\u0434 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u043c \u0441\u043a\u0440\u043e\u043b\u043b-\u0431\u0430\u0440\u043e\u043c, \u043f\u043e\u0437\u0432\u043e\u043b\u044f\u044e\u0449\u0430\u044f \u0438\u0437\u044f\u0449\u043d\u043e \u0440\u0430\u0437\u043c\u0435\u0449\u0430\u0442\u044c \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435 \u0434\u043b\u0438\u043d\u043d\u044b\u0435 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u0431\u043b\u043e\u043a\u0438 \u043a\u043e\u043d\u0442\u0435\u043d\u0442\u0430;<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-svg\" rel=\"noopener noreferrer nofollow\"><strong>handy-svg<\/strong><\/a><strong> <\/strong>&#8212; \u0441\u0430\u043c\u044b\u0439 \u0443\u0434\u043e\u0431\u043d\u044b\u0439 \u0441\u043f\u043e\u0441\u043e\u0431 \u0432\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u043d\u0438\u044f <code>SVG<\/code> \u0432 \u0432\u0435\u0431\u0435. \u042f \u0443\u0436\u0435 <a href=\"https:\/\/habr.com\/ru\/post\/672984\/\" rel=\"noopener noreferrer nofollow\">\u0440\u0430\u0441\u0441\u043a\u0430\u0437\u044b\u0432\u0430\u043b<\/a> \u043e \u043d\u0435\u043c \u043d\u0430 \u0425\u0430\u0431\u0440\u0435.<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u044d\u0442\u0438\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u0445 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u044b \u043f\u043e\u0434\u0445\u043e\u0434\u044b, \u043a \u043a\u043e\u0442\u043e\u0440\u044b\u043c \u044f \u043f\u0440\u0438\u0431\u0435\u0433\u0430\u044e \u0433\u043e\u0434\u0430\u043c\u0438. \u0422\u0435\u043f\u0435\u0440\u044c \u0436\u0435, \u0431\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442\u0443 \u0432 <strong>handy-ones<\/strong>, \u044f \u0441\u043c\u043e\u0433 \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0438\u0445 \u0434\u043e\u0441\u0442\u0443\u043f\u043d\u044b\u043c\u0438 \u0432\u0441\u0435\u043c. \u0410 \u0434\u043e\u0431\u0430\u0432\u0438\u0442\u044c \u043d\u043e\u0432\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442 \u0438\u043b\u0438 \u0443\u0442\u0438\u043b\u0438\u0442\u0443 \u043c\u043e\u0436\u043d\u043e \u0431\u0443\u043a\u0432\u0430\u043b\u044c\u043d\u043e \u0437\u0430 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u043c\u0438\u043d\u0443\u0442, \u043f\u0440\u044f\u043c\u043e \u0437\u0430 \u0437\u0430\u0432\u0442\u0440\u0430\u043a\u043e\u043c.<\/p>\n<p>\u0420\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u043e \u043f\u0435\u0440\u0432\u043e\u0439 \u043f\u0430\u0447\u043a\u0435 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435.<\/p>\n<h2>Handy clamp<\/h2>\n<p><a href=\"https:\/\/ivliag.github.io\/handy-ones\/?story=handy-clamp--basic\" rel=\"noopener noreferrer nofollow\"><strong>\u0414\u0435\u043c\u043e<\/strong><\/a> | <a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-clamp\" rel=\"noopener noreferrer nofollow\"><strong>\u0418\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438<\/strong><\/a><\/p>\n<figure class=\"full-width\"><figcaption>handy-clamp \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442 \u043f\u0435\u0440\u0432\u044b\u0435 \u0434\u0432\u0435 \u0441\u0442\u0440\u043e\u0447\u043a\u0438 \u0442\u0435\u043a\u0441\u0442\u0430<\/figcaption><\/figure>\n<p>\u0422\u0438\u043f\u043e\u0432\u0430\u044f \u0437\u0430\u0434\u0430\u0447\u0430 &#8212; \u0441\u043f\u0440\u044f\u0442\u0430\u0442\u044c \u043b\u0438\u0448\u043d\u0438\u0439 \u0442\u0435\u043a\u0441\u0442 \u043f\u043e\u0434 &#171;\u043a\u0430\u0442&#187;. \u041e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u044c <strong>handy-clamp<\/strong> \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043e\u043d \u0443\u043c\u0435\u0435\u0442 \u043e\u0431\u0440\u0435\u0437\u0430\u0442\u044c \u0442\u0435\u043a\u0441\u0442 \u043f\u043e \u0441\u0442\u0440\u043e\u0447\u043a\u0430\u043c, \u0430 \u0435\u0449\u0435 \u043e\u043d \u043e\u0442\u0437\u044b\u0432\u0447\u0438\u0432\u044b\u0439 \u0438 \u043c\u0430\u043a\u0441\u0438\u043c\u0430\u043b\u044c\u043d\u043e \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439. \u0412 \u043e\u0441\u043d\u043e\u0432\u0435 \u0435\u0433\u043e \u0440\u0430\u0431\u043e\u0442\u044b \u0434\u0432\u0435 \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0438:<\/p>\n<ol>\n<li>\n<p>\u0422\u0430\u043a \u0438 <a href=\"https:\/\/drafts.csswg.org\/css-overflow-3\/#line-clamp\" rel=\"noopener noreferrer nofollow\">\u043d\u0435 \u0441\u0442\u0430\u0432\u0448\u0435\u0435 \u0441\u0442\u0430\u043d\u0434\u0430\u0440\u0442\u043e\u043c<\/a>, \u043d\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0430\u043d\u043d\u043e\u0435 <a href=\"https:\/\/caniuse.com\/css-line-clamp\" rel=\"noopener noreferrer nofollow\">\u0432\u0441\u0435\u043c\u0438 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u043c\u0438 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u043c\u0438<\/a> css-\u0441\u0432\u043e\u0439\u0441\u0442\u0432\u043e <code>line-clamp<\/code><\/p>\n<\/li>\n<li>\n<p><code>ResizeObserver<\/code> &#8212; \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u043e\u0435 API \u0434\u043b\u044f \u043e\u0442\u0441\u043b\u0435\u0436\u0438\u0432\u0430\u043d\u0438\u044f \u0438\u0437\u043c\u0435\u043d\u0435\u043d\u0438\u0439 \u0440\u0430\u0437\u043c\u0435\u0440\u0430 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430.<\/p>\n<\/li>\n<\/ol>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 \u0432\u0441\u0435 \u043f\u0440\u043e\u0441\u0442\u043e &#8212; \u0441\u043b\u0435\u0434\u0438\u043c \u0437\u0430 \u0440\u0430\u0437\u043c\u0435\u0440\u0430\u043c\u0438 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u0430 \u0441 \u0442\u0435\u043a\u0441\u0442\u043e\u043c, \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u0442\u0441\u044f \u043b\u0438 \u043e\u043d \u0432 \u0441\u0432\u043e\u0435\u0433\u043e \u0440\u043e\u0434\u0438\u0442\u0435\u043b\u044f:<\/p>\n<pre><code class=\"javascript\">const isOverflowing = el.scrollHeight > el.clientHeight<\/code><\/pre>\n<p>\u0415\u0441\u043b\u0438 \u043d\u0435 \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u0442\u0441\u044f &#8212; \u0440\u0438\u0441\u0443\u0435\u043c \u043a\u043d\u043e\u043f\u043a\u0443 &#171;\u041f\u043e\u043a\u0430\u0437\u0430\u0442\u044c \u0435\u0449\u0435&#187;, \u0435\u0441\u043b\u0438 \u043f\u043e\u043c\u0435\u0449\u0430\u0435\u0442\u0441\u044f &#8212; \u0441\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u044d\u0442\u0443 \u0436\u0435 \u043a\u043d\u043e\u043f\u043a\u0443. \u0417\u0430\u0432\u043e\u0440\u0430\u0447\u0438\u0432\u0430\u0435\u043c \u0438\u0434\u0435\u044e \u0432 React-\u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u043f\u0440\u0438\u0434\u0443\u043c\u044b\u0432\u0430\u0435\u043c \u043d\u0435\u0437\u0430\u043c\u044b\u0441\u043b\u043e\u0432\u0430\u0442\u043e\u0435 API.<\/p>\n<pre><code class=\"xml\">import {HandyClamp} from '@handy-ones\/handy-clamp';  &lt;HandyClamp lines={2}>    \u0414\u043b\u0438\u043d\u043d\u044b\u0439-\u0434\u043b\u0438\u043d\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u0432 \u0434\u0435\u0441\u044f\u0442\u043a\u0438 \u0441\u0442\u0440\u043e\u0447\u0435\u043a, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043d\u0430\u0434\u043e \u0441\u043f\u0440\u044f\u0442\u0430\u0442\u044c... &lt;\/HandyClamp><\/code><\/pre>\n<p>\u041f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u043c, \u043b\u044e\u0431\u0443\u0435\u043c\u0441\u044f, \u0441\u0442\u0430\u0432\u0438\u043c \u0447\u0430\u0439\u043d\u0438\u043a, \u0434\u0432\u0438\u0433\u0430\u0435\u043c\u0441\u044f \u0434\u0430\u043b\u044c\u0448\u0435.<\/p>\n<h3>Handy range slider<\/h3>\n<p><a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-range-slider\" rel=\"noopener noreferrer nofollow\"><strong>\u0414\u0435\u043c\u043e<\/strong><\/a> | <a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-range-slider\" rel=\"noopener noreferrer nofollow\"><strong>\u0418\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438<\/strong><\/a><\/p>\n<figure class=\"full-width\"><figcaption>handy-range-slider \u043c\u043e\u0436\u043d\u043e \u0440\u0430\u0441\u043a\u0440\u0430\u0448\u0438\u0432\u0430\u0442\u044c<\/figcaption><\/figure>\n<p>\u0415\u0449\u0435 \u0441\u043e \u0432\u0440\u0435\u043c\u0435\u043d jQuery \u044f \u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0441\u043e \u043c\u043d\u043e\u0436\u0435\u0441\u0442\u0432\u043e\u043c \u0440\u0430\u0437\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u043e\u0432 \u0432\u044b\u0431\u043e\u0440\u0430 \u0434\u0438\u0430\u043f\u0430\u0437\u043e\u043d\u0430, \u0441\u0440\u0435\u0434\u0438 \u043d\u0438\u0445 <a href=\"https:\/\/jqueryui.com\/slider\/\" rel=\"noopener noreferrer nofollow\">\u0441\u043b\u0430\u0439\u0434\u0435\u0440 \u0438\u0437 jQuery UI<\/a>, \u0437\u0430\u043c\u0435\u0447\u0430\u0442\u0435\u043b\u044c\u043d\u043e\u0435 standalone-\u0440\u0435\u0448\u0435\u043d\u0438\u0435 <a href=\"https:\/\/refreshless.com\/nouislider\/\" rel=\"noopener noreferrer nofollow\">noUiSlider<\/a>, React-\u043e\u0431\u0435\u0440\u0442\u043a\u0438 \u0432 <a href=\"https:\/\/mui.com\/material-ui\/react-slider\/\" rel=\"noopener noreferrer nofollow\">Material UI<\/a> \u0438 <a href=\"https:\/\/ant.design\/components\/slider\/\" rel=\"noopener noreferrer nofollow\">Ant Design<\/a>. \u0418 \u044f \u0437\u043d\u0430\u044e \u043f\u0440\u043e \u043e\u043f\u044b\u0442 \u0440\u0435\u0431\u044f\u0442 \u0438\u0437 \u0422\u0438\u043d\u044c\u043a\u043e\u0444\u0444 \u0441 \u043a\u0430\u0441\u0442\u043e\u043c\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0430 range-\u0438\u043d\u043f\u0443\u0442\u0430, \u044d\u0442\u043e \u0438 \u043f\u0440\u0430\u0432\u0434\u0430 <a href=\"https:\/\/habr.com\/ru\/company\/tinkoff\/blog\/667254\/\" rel=\"noopener noreferrer nofollow\">\u0432\u043f\u0435\u0447\u0430\u0442\u043b\u044f\u044e\u0449\u0430\u044f<\/a> \u0440\u0430\u0431\u043e\u0442\u0430. \u041d\u043e \u0442\u0430\u0449\u0438\u0442\u044c \u0432 \u043f\u0440\u043e\u0435\u043a\u0442 \u0442\u044f\u0436\u0435\u043b\u043e\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0441\u043d\u0430\u0440\u0443\u0436\u0438 \u043d\u0435 \u0445\u043e\u0442\u0435\u043b\u043e\u0441\u044c, \u0430 \u043f\u043e\u0434\u0445\u043e\u0434 \u0441 css-\u043a\u0430\u0441\u0442\u043e\u043c\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u0430 \u043d\u0435 \u0434\u0430\u0435\u0442 \u043f\u043e\u043b\u043d\u043e\u0439 \u0433\u0438\u0431\u043a\u043e\u0441\u0442\u0438. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u043d\u0435 \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u0441\u044f \u043f\u043e\u043a\u0440\u0430\u0441\u0438\u0442\u044c \u0442\u0440\u0435\u043a \u0441\u043b\u0430\u0439\u0434\u0435\u0440\u0430 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043e\u043c. \u041f\u043b\u044e\u0441, css-\u043c\u0430\u0433\u0438\u044f \u0432\u043e\u043a\u0440\u0443\u0433 \u043d\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430 \u043c\u0435\u043d\u044f \u043d\u0435\u043c\u043d\u043e\u0433\u043e \u043f\u0443\u0433\u0430\u0435\u0442, \u044f \u043d\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u043e\u043d\u0438\u043c\u0430\u044e, \u043a\u0430\u043a \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0442\u044c &#171;\u0442\u0440\u0438 \u0441\u043b\u043e\u044f \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u0430&#187; \u0438 \u043f\u0430\u0447\u043a\u0443 \u0432\u0435\u043d\u0434\u043e\u0440\u043d\u044b\u0445 \u043f\u0440\u0435\u0444\u0438\u043a\u0441\u043e\u0432.<\/p>\n<p>\u0414\u043b\u044f \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u0441\u043b\u0430\u0439\u0434\u0435\u0440\u0430 \u0441 \u043e\u0434\u043d\u0438\u043c \u043f\u043e\u043b\u0437\u0443\u043d\u043a\u043e\u043c \u044f \u0440\u0435\u0448\u0438\u043b \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442, \u0430 \u0434\u043b\u044f \u0433\u0438\u0431\u043a\u043e\u0439 \u0441\u0442\u0438\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b, \u043e\u0442\u0440\u0435\u043d\u0434\u0435\u0440\u0435\u043d\u043d\u044b\u0435 \u0447\u0435\u0440\u0435\u0437 JavaScript. \u0414\u043b\u044f \u043c\u0435\u043d\u044f \u043b\u0443\u0447\u0448\u0435 \u0432\u0441\u0435\u0433\u043e \u0441\u0440\u0430\u0431\u043e\u0442\u0430\u043b \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u043f\u043e\u0434\u0445\u043e\u0434:<\/p>\n<ol>\n<li>\n<p>\u0420\u0435\u043d\u0434\u0435\u0440\u0438\u043c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0441\u043b\u0430\u0439\u0434\u0435\u0440 \u043d\u0443\u0436\u043d\u043e\u0433\u043e \u0440\u0430\u0437\u043c\u0435\u0440\u0430. \u0418 \u0434\u0435\u043b\u0430\u0435\u043c \u0432\u0441\u0435 \u0435\u0433\u043e \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u043f\u0440\u043e\u0437\u0440\u0430\u0447\u043d\u044b\u043c\u0438.<\/p>\n<\/li>\n<li>\n<p>\u0420\u0435\u043d\u0434\u0435\u0440\u0438\u043c <em>\u043f\u043e\u0434 \u043d\u0438\u043c <\/em>\u043f\u0441\u0435\u0432\u0434\u043e-\u043a\u043e\u043d\u0442\u0440\u043e\u043b<em>, <\/em>\u043b\u044e\u0431\u0443\u044e \u0443\u0434\u043e\u0431\u043d\u0443\u044e \u043d\u0430\u043c HTML-\u0440\u0430\u0437\u043c\u0435\u0442\u043a\u0443, \u043a\u043e\u0442\u043e\u0440\u0430\u044f \u0431\u0443\u0434\u0435\u0442 \u043e\u0442\u0432\u0435\u0447\u0430\u0442\u044c \u0438\u0441\u043a\u043b\u044e\u0447\u0438\u0442\u0435\u043b\u044c\u043d\u043e \u0437\u0430 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0435. \u0421\u0442\u0438\u043b\u0438\u0437\u0443\u0435\u043c \u0435\u0435 \u043a\u0430\u043a \u043d\u0430\u043c \u043d\u0440\u0430\u0432\u0438\u0442\u0441\u044f.<\/p>\n<\/li>\n<li>\n<p>\u0421\u0432\u044f\u0437\u044b\u0432\u0430\u0435\u043c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0438 \u043f\u0441\u0435\u0432\u0434\u043e \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044b \u0447\u0435\u0440\u0435\u0437 \u043b\u043e\u043a\u0430\u043b\u044c\u043d\u044b\u0439 \u0441\u0442\u0435\u0439\u0442. \u0422\u0443\u0442 \u043d\u0443\u0436\u043d\u043e \u0431\u0443\u0434\u0435\u0442 \u0447\u0443\u0442\u044c-\u0447\u0443\u0442\u044c \u0430\u0440\u0438\u0444\u043c\u0435\u0442\u0438\u043a\u0438 \u0438 \u0432\u043d\u0438\u043c\u0430\u0442\u0435\u043b\u044c\u043d\u043e \u043f\u043e\u0442\u0435\u0441\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0432 \u0440\u0430\u0437\u043d\u044b\u0445 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445.<\/p>\n<\/li>\n<\/ol>\n<p>\u0412 \u0438\u0442\u043e\u0433\u0435 \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044c \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u043c \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043e\u043c, \u0430 \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u0442\u0441\u044f \u0440\u0430\u0441\u043f\u043e\u043b\u043e\u0436\u0435\u043d\u043d\u044b\u0439 \u0441\u043b\u043e\u0435\u043c \u043d\u0438\u0436\u0435 \u043f\u0441\u0435\u0432\u0434\u043e-\u043a\u043e\u043d\u0442\u0440\u043e\u043b, \u043a\u0430\u0441\u0442\u043e\u043c\u0438\u0437\u0430\u0446\u0438\u044f \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u043d\u0438\u043a\u0430\u043a \u043d\u0435 \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0430. \u0418 \u044d\u0442\u043e \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442, \u0438 \u044d\u0442\u043e \u043f\u0440\u043e\u0441\u0442\u043e, \u0438 \u044d\u0442\u043e \u043c\u0430\u043b\u043e \u043a\u043e\u0434\u0430, \u0438 \u044d\u0442\u043e mobile-friendly.<\/p>\n<p>\u0414\u0430\u043b\u044c\u0448\u0435 &#8212; \u0434\u0435\u043b\u043e \u0442\u0435\u0445\u043d\u0438\u043a\u0438, \u0442\u0435\u0441\u0442\u0438\u0440\u0443\u0435\u043c \u0432 \u0440\u0430\u0437\u043d\u044b\u0445 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445, \u043f\u0440\u0438\u0434\u0443\u043c\u044b\u0432\u0430\u0435\u043c API, \u0441\u043f\u043e\u0441\u043e\u0431 \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438 \u043b\u0435\u0439\u0431\u043b\u043e\u0432, \u043e\u0444\u043e\u0440\u043c\u043b\u044f\u0435\u043c \u043a\u043e\u0434:<\/p>\n<pre><code class=\"xml\">import {HandyRangeSlider} from '@handy-ones\/handy-range-slider';  &lt;HandyRangeSlider     min={50}     max={100}     step={2}     value={10}     labels={[         {value: 50, text: '?'},         {value: 75, text: '?'},         {value: 100, text: '\u2764\ufe0f'}     ]}     onChange={(event, parsedValue) => {}} \/><\/code><\/pre>\n<blockquote>\n<p>\u041f\u0440\u043e\u0435\u043a\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0410\u041f\u0418 \u0443 \u0438\u043d\u043f\u0443\u0442\u043e\u0432 \u043d\u0430 \u0441\u0430\u043c\u043e\u043c \u0434\u0435\u043b\u0435 \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u043e,  <em>\u043b\u044e\u0431\u044b\u0435 <\/em>\u0438\u043d\u043f\u0443\u0442\u044b \u0434\u043e\u043b\u0436\u043d\u044b \u0443\u043f\u0440\u0430\u0432\u043b\u044f\u0442\u044c\u0441\u044f \u0432\u0441\u0435\u0433\u043e \u0434\u0432\u0443\u043c\u044f \u043f\u0440\u043e\u043f\u0441\u0430\u043c\u0438: <code>value<\/code> \u0438 <code>onChange<\/code>. \u0410 \u043f\u0435\u0440\u0432\u044b\u043c \u0430\u0440\u0433\u0443\u043c\u0435\u043d\u0442\u043e\u043c \u0432 <code>onChange<\/code> <em>\u0432\u0441\u0435\u0433\u0434\u0430<\/em> \u0434\u043e\u043b\u0436\u0435\u043d \u043f\u0440\u0438\u0445\u043e\u0434\u0438\u0442\u044c \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b\u044c\u043d\u044b\u0439 <code>event<\/code>. \u042d\u0442\u043e\u0442 \u043f\u043e\u0434\u0445\u043e\u0434 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442 <a href=\"https:\/\/reactjs.org\/docs\/forms.html\" rel=\"noopener noreferrer nofollow\">React<\/a>, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0441\u0430\u043c\u044b\u0435 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0435 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 \u0434\u043b\u044f \u0440\u0430\u0431\u043e\u0442\u044b \u0441 \u0444\u043e\u0440\u043c\u0430\u043c\u0438: <a href=\"https:\/\/formik.org\/docs\/api\/useField#fieldinputpropsvalue\" rel=\"noopener noreferrer nofollow\">Formik<\/a>, <a href=\"https:\/\/react-hook-form.com\/api\/useform\/register\" rel=\"noopener noreferrer nofollow\">React Hook Form<\/a>, <a href=\"https:\/\/final-form.org\/docs\/react-final-form\/api\/Field\" rel=\"noopener noreferrer nofollow\">React Final Form<\/a>.<\/p>\n<\/blockquote>\n<p>\u0422\u0435\u043a\u0443\u0449\u0435\u0435 \u0440\u0435\u0448\u0435\u043d\u0438\u0435 \u0440\u0430\u0431\u043e\u0442\u0430\u0435\u0442 \u0432\u043e \u0432\u0441\u0435\u0445 \u0441\u043e\u0432\u0440\u0435\u043c\u0435\u043d\u043d\u044b\u0445 \u0434\u0435\u0441\u043a\u0442\u043e\u043f\u043d\u044b\u0445 \u0438 \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u044b\u0445 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u0430\u0445, \u0430 \u0442\u0430\u043a\u0436\u0435 \u0432 IE 10+, \u0435\u0441\u043b\u0438 \u044d\u0442\u043e \u043f\u043e \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u043f\u0440\u0438\u0447\u0438\u043d\u0435 \u0435\u0449\u0435 \u0432\u0430\u0436\u043d\u043e. \u041d\u0435\u0442 \u043d\u0438\u043a\u0430\u043a\u0438\u0445 \u043f\u0440\u043e\u0431\u043b\u0435\u043c \u0430\u0434\u0430\u043f\u0442\u0438\u0440\u043e\u0432\u0430\u0442\u044c <strong>handy-range-slider<\/strong> \u0434\u043b\u044f \u0432\u0435\u0440\u0442\u0438\u043a\u0430\u043b\u044c\u043d\u043e\u0433\u043e \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u043d\u043e Firefox \u0432\u0441\u0435 \u0435\u0449\u0435 <a href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/HTML\/Element\/input\/range#browser_compatibility\" rel=\"noopener noreferrer nofollow\">\u043d\u0435 \u043f\u043e\u043b\u043d\u043e\u0441\u0442\u044c\u044e \u0435\u0433\u043e \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442<\/a>. <\/p>\n<p>\u0422\u0430\u043a \u0447\u0442\u043e \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u043c \u0442\u043e, \u0447\u0442\u043e \u0435\u0441\u0442\u044c, \u0437\u0430\u043a\u0438\u0434\u044b\u0432\u0430\u0435\u043c \u043f\u0430\u0440\u0443 \u043f\u0440\u0438\u043c\u0435\u0440\u043e\u0432 \u043d\u0430 \u0434\u0435\u043c\u043e-\u0441\u0442\u0435\u043d\u0434, \u0447\u0430\u0439\u043d\u0438\u043a \u043a\u0430\u043a \u0440\u0430\u0437 \u0432\u0441\u043a\u0438\u043f\u0435\u043b.<\/p>\n<h2>Handy Scroll Strip<\/h2>\n<p><a href=\"https:\/\/ivliag.github.io\/handy-ones\/?story=handy-scroll-strip--imperative-hanlers\" rel=\"noopener noreferrer nofollow\"><strong>\u0414\u0435\u043c\u043e<\/strong><\/a> | <a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-scroll-strip\" rel=\"noopener noreferrer nofollow\"><strong>\u0418\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438<\/strong><\/a><\/p>\n<figure class=\"full-width\"><figcaption>handy-scroll-strip \u0438\u0437\u044f\u0449\u043d\u043e \u043f\u0440\u044f\u0447\u0435\u0442 \u043b\u0438\u0448\u043d\u0438\u0439 \u043a\u043e\u043d\u0442\u0435\u043d\u0442 \u0437\u0430 \u0433\u043e\u0440\u0438\u0437\u043e\u043d\u0442\u0430\u043b\u044c\u043d\u043e\u0439 \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u043e\u0439<\/figcaption><\/figure>\n<p>\u041f\u0440\u043e\u0441\u0442\u0435\u0439\u0448\u0438\u0439, \u043d\u043e \u0432 \u0442\u043e \u0436\u0435 \u0432\u0440\u0435\u043c\u044f \u0443\u043d\u0438\u0432\u0435\u0440\u0441\u0430\u043b\u044c\u043d\u0435\u0439\u0448\u0438\u0439 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442: \u043f\u043e\u043b\u043e\u0441\u0430 \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0438 \u0431\u0435\u0437 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u0445 \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u043e\u0432, \u043d\u043e \u0441 \u0444\u0435\u0439\u0434\u043e\u043c \u043f\u043e \u043a\u0440\u0430\u044f\u043c \u0438 \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u044b\u043c API. \u042f \u0441\u043e\u0437\u0434\u0430\u0432\u0430\u043b \u043d\u0430 \u0435\u0433\u043e \u043e\u0441\u043d\u043e\u0432\u0435 \u0433\u0430\u043b\u0435\u0440\u0435\u0438, \u043c\u043e\u0431\u0438\u043b\u044c\u043d\u0443\u044e \u043d\u0430\u0432\u0438\u0433\u0430\u0446\u0438\u044e, \u043f\u0440\u044f\u0442\u0430\u043b \u0432 \u043d\u0435\u0433\u043e \u043e\u0433\u0440\u043e\u043c\u043d\u044b\u0435 multistep-\u0444\u043e\u0440\u043c\u044b \u0438 \u0448\u0438\u0440\u043e\u0447\u0435\u043d\u043d\u044b\u0435 \u0442\u0430\u0431\u043b\u0438\u0446\u044b. \u041e\u043d \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u0434\u0438\u0442\u0435\u043b\u044c\u043d\u044b\u0439, \u0432\u0435\u0434\u044c \u0441\u043a\u0440\u043e\u043b\u043b \u0432 \u043d\u0435\u043c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439. \u0425\u043e\u0440\u043e\u0448\u0435\u0439 \u0438\u0434\u0435\u0435\u0439 \u0431\u0443\u0434\u0435\u0442 \u0442\u0430\u043a\u0436\u0435 \u0435\u0433\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435 \u0441 <a href=\"https:\/\/web.dev\/css-scroll-snap\/\" rel=\"noopener noreferrer nofollow\">css-scroll-step<\/a>.<\/p>\n<p>\u0412 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u043e\u043d \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442:<\/p>\n<ol>\n<li>\n<p>\u0421\u043a\u0440\u044b\u0432\u0430\u0435\u043c \u043f\u043e\u043b\u043e\u0441\u044b \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0438<\/p>\n<\/li>\n<li>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u0431\u043b\u043e\u043a\u0438 \u0441 \u0433\u0440\u0430\u0434\u0438\u0435\u043d\u0442\u043e\u043c \u043f\u043e \u043a\u0440\u0430\u044f\u043c, \u0441\u043b\u0443\u0448\u0430\u0435\u043c \u0441\u043a\u0440\u043e\u043b\u043b, \u043e\u0442\u043e\u0431\u0440\u0430\u0436\u0430\u0435\u043c \u0438\u0445 \u0438 \u043f\u0440\u044f\u0447\u0435\u043c.<\/p>\n<\/li>\n<li>\n<p>\u0420\u0435\u0430\u043b\u0438\u0437\u0443\u0435\u043c \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u0435 API, \u0441 \u0443\u0436\u0430\u0441\u043e\u043c \u043f\u0440\u043e\u0434\u0438\u0440\u0430\u044f\u0441\u044c \u0447\u0435\u0440\u0435\u0437 <code>useImperativeHandle<\/code> \u0438 \u0432\u0441\u043f\u043e\u043c\u0438\u043d\u0430\u044f, \u043a\u0430\u043a \u0443\u0434\u043e\u0431\u043d\u043e \u044d\u0442\u043e \u0431\u044b\u043b\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u043e \u0432 \u043a\u043b\u0430\u0441\u0441\u043e\u0432\u044b\u0445, \u0430 \u043d\u0435 \u0444\u0443\u043d\u043a\u0446\u0438\u043e\u043d\u0430\u043b\u044c\u043d\u044b\u0445 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u0445.<\/p>\n<\/li>\n<\/ol>\n<p>\u0421\u043a\u0440\u044b\u0442\u044c \u043f\u043e\u043b\u043e\u0441\u044b \u043f\u0440\u043e\u043a\u0440\u0443\u0442\u043a\u0438 \u043c\u043e\u0436\u043d\u043e \u0447\u0435\u0440\u0435\u0437 css, \u044d\u0442\u043e \u043a\u0440\u043e\u0441\u0441\u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u043e, \u0445\u043e\u0442\u044f \u0438 \u043c\u043d\u043e\u0433\u043e\u0441\u043b\u043e\u0432\u043d\u043e:<\/p>\n<pre><code class=\"css\">.content {     overflow-x: scroll;     overflow-y: hidden;     -webkit-overflow-scrolling: touch;     -ms-overflow-style: none;  \/* Internet Explorer 10+ *\/     scrollbar-width: none;  \/* Firefox *\/ }  .content::-webkit-scrollbar {     display: none;  \/* Safari and Chrome *\/ }<\/code><\/pre>\n<p>\u0412 \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u043c API \u043c\u043e\u0436\u043d\u043e \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u043d\u0430\u0442\u0438\u0432\u043d\u044b\u0439 \u0431\u0440\u0430\u0443\u0437\u0435\u0440\u043d\u044b\u0439 <code>Element.scrollTo()<\/code>, \u043e\u043d \u0443\u0436\u0435 \u0434\u0430\u0432\u043d\u043e \u0443\u043c\u0435\u0435\u0442 \u0441\u043a\u0440\u043e\u043b\u043b\u0438\u0442\u044c <em>\u043f\u043b\u0430\u0432\u043d\u043e<\/em>:<\/p>\n<pre><code class=\"javascript\">element.scrollTo({     left: 2000,     behavior: 'smooth' });<\/code><\/pre>\n<p>\u0412\u043e\u0442 \u0438 \u0432\u0441\u0451, \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u0441\u043b\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0442\u0443\u0442 \u0431\u0443\u0434\u0443\u0442 \u0441 \u0442\u0438\u043f\u0438\u0437\u0430\u0446\u0438\u0435\u0439 \u0438\u043c\u043f\u0435\u0440\u0430\u0442\u0438\u0432\u043d\u043e\u0433\u043e API \u0438 <code>forwardRef<\/code>, \u043d\u043e \u0435\u0441\u0442\u044c \u0445\u043e\u0440\u043e\u0448\u0438\u0439 \u043f\u0440\u0438\u043c\u0435\u0440 \u0432 <a href=\"https:\/\/react-typescript-cheatsheet.netlify.app\/docs\/basic\/getting-started\/hooks\/#useimperativehandle\" rel=\"noopener noreferrer nofollow\">React Typescript Cheatsheet<\/a>, \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0442\u0430\u043a\u043e\u0439:<\/p>\n<pre><code class=\"typescript\">interface ImperativeHandlers {     getContainer: () => HTMLDivElement | null;     getScrollLeft: () => number;     scrollTo: (value: number) => void; }<\/code><\/pre>\n<p>\u0420\u0435\u0448\u0438\u0442\u044c \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0435 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u044b \u043f\u043e\u043c\u043e\u0436\u0435\u0442 \u043d\u0430\u0448 \u0431\u043e\u0439\u043b\u0435\u0440\u043f\u043b\u0435\u0439\u0442. \u0417\u0430\u043a\u0438\u0434\u044b\u0432\u0430\u0435\u043c \u0432 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0443\u044e \u043f\u0430\u043f\u043a\u0443, \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u043c \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c, \u0447\u0442\u043e \u0442\u0430\u043c \u043e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u0432 \u0445\u043e\u043b\u043e\u0434\u0438\u043b\u044c\u043d\u0438\u043a\u0435.<\/p>\n<h2>Handy SVG<\/h2>\n<p><a href=\"https:\/\/ivliag.github.io\/handy-ones\/?story=handy-svg--colored\" rel=\"noopener noreferrer nofollow\"><strong>\u0414\u0435\u043c\u043e<\/strong><\/a> | <a href=\"https:\/\/github.com\/ivliag\/handy-ones\/tree\/master\/packages\/handy-svg\" rel=\"noopener noreferrer nofollow\"><strong>\u0418\u0441\u0445\u043e\u0434\u043d\u0438\u043a\u0438<\/strong><\/a><\/p>\n<figure class=\"full-width\"><figcaption>SVG-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f, \u0432\u0441\u0442\u0440\u043e\u0435\u043d\u043d\u044b\u0435 \u0447\u0435\u0440\u0435\u0437 handy-svg, \u043c\u043e\u0436\u043d\u043e \u043a\u0440\u0430\u0441\u0438\u0442\u044c \u0432 css<\/figcaption><\/figure>\n<p>\u041d\u0435 \u0431\u0443\u0434\u0443 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0442\u044c\u0441\u044f \u043d\u0430 \u044d\u0442\u043e\u0439 \u0443\u0442\u0438\u043b\u0438\u0442\u0435, \u043f\u0440\u043e \u043d\u0435\u0435 \u0443 \u043c\u0435\u043d\u044f \u0431\u044b\u043b\u0430 <a href=\"https:\/\/habr.com\/ru\/post\/672984\/\" rel=\"noopener noreferrer nofollow\">\u043e\u0442\u0434\u0435\u043b\u044c\u043d\u0430\u044f \u0441\u0442\u0430\u0442\u044c\u044f \u043d\u0430 \u0425\u0430\u0431\u0440\u0435<\/a>. \u041d\u0430\u043f\u043e\u043c\u043d\u044e \u0442\u043e\u043b\u044c\u043a\u043e, \u0447\u0442\u043e \u0441 \u0435\u0435 \u043f\u043e\u043c\u043e\u0449\u044c\u044e \u043c\u043e\u0436\u043d\u043e \u0434\u0438\u043d\u0430\u043c\u0438\u0447\u0435\u0441\u043a\u0438 \u0432\u0441\u0442\u0440\u0430\u0438\u0432\u0430\u0442\u044c SVG-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u044f \u0432 web-\u043f\u0440\u043e\u0435\u043a\u0442\u044b \u0441 \u043b\u044e\u0431\u044b\u043c \u0442\u0435\u0445\u043d\u043e\u043b\u043e\u0433\u0438\u0447\u0435\u0441\u043a\u0438\u043c \u0441\u0442\u0435\u043a\u043e\u043c. \u041f\u043e\u0434 \u043a\u0430\u043f\u043e\u0442\u043e\u043c \u043e\u043d\u0430 \u0434\u0435\u043b\u0430\u0435\u0442 fetch-\u0437\u0430\u043f\u0440\u043e\u0441\u044b \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u043a\u043e\u0434\u0430 SVG-\u0438\u0437\u043e\u0431\u0440\u0430\u0436\u0435\u043d\u0438\u0439, \u0444\u043e\u0440\u043c\u0438\u0440\u0443\u0435\u0442 \u043d\u0430 \u0441\u0442\u0440\u0430\u043d\u0438\u0446\u0435 \u0441\u043f\u0440\u0430\u0439\u0442 \u0441\u0438\u043c\u0432\u043e\u043b\u043e\u0432 \u0438 \u043f\u0440\u0435\u0434\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 React \u0438 standalone API \u0434\u043b\u044f \u043e\u0442\u0440\u0438\u0441\u043e\u0432\u043a\u0438:<\/p>\n<pre><code class=\"xml\">import {HandySvg} from '@handy-ones\/handy-svg'; import iconSrc from '.\/icon.svg';  export const Icon = () => (     &lt;HandySvg         src={iconSrc}         className=\"icon\"         width=\"32\"         height=\"32\"     \/> );<\/code><\/pre>\n<p>\u0423\u0442\u0438\u043b\u0438\u0442\u0430<strong> handy-svg<\/strong> \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0432\u0440\u0435\u043c\u044f \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043e\u0432\u0430\u043b\u0430 \u043a\u0430\u043a \u043d\u0435\u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e \u0440\u0435\u0448\u0435\u043d\u0438\u0435, \u043d\u043e \u0441\u0434\u0435\u043b\u0430\u0442\u044c \u0435\u0435 \u0447\u0430\u0441\u0442\u044c\u044e \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 <strong>handy-ones <\/strong>\u043d\u0435 \u0441\u043e\u0441\u0442\u0430\u0432\u0438\u0442 \u0442\u0440\u0443\u0434\u0430. \u0411\u043b\u0430\u0433\u043e\u0434\u0430\u0440\u044f \u0438\u0437\u043e\u043b\u0438\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0441\u0442\u0438 \u043e\u0442\u0434\u0435\u043b\u044c\u043d\u044b\u0445 \u043f\u0440\u043e\u0435\u043a\u0442\u043e\u0432 \u0432\u043d\u0443\u0442\u0440\u0438 \u043c\u043e\u043d\u043e\u0440\u0435\u043f\u043e\u0437\u0438\u0442\u043e\u0440\u0438\u044f \u043d\u0435 \u043f\u0440\u0438\u0434\u0435\u0442\u0441\u044f \u0434\u0430\u0436\u0435 \u0441\u0438\u043d\u0445\u0440\u043e\u043d\u0438\u0437\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u0441\u0442\u0430\u0440\u044b\u0445 \u0438 \u043d\u043e\u0432\u044b\u0445 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a, npm \u0445\u043e\u0440\u043e\u0448\u043e \u0441\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0441 \u044d\u0442\u0438\u043c \u0441\u0430\u043c. \u041f\u043e\u0440\u044f\u0434\u043e\u043a \u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0439 \u0442\u0430\u043a\u043e\u0439 \u0436\u0435, \u043a\u0430\u043a \u0441 \u043d\u043e\u0432\u044b\u043c\u0438 \u043a\u043e\u043c\u043f\u043e\u043d\u0435\u043d\u0442\u0430\u043c\u0438: \u043d\u043e\u0432\u0430\u044f \u043f\u0430\u043f\u043a\u0430, \u043d\u043e\u0432\u044b\u0439 package.json, \u043f\u0443\u0431\u043b\u0438\u043a\u0443\u0435\u043c \u0438 \u0432\u044b\u0434\u044b\u0445\u0430\u0435\u043c. \u041d\u0430 \u0441\u0435\u0433\u043e\u0434\u043d\u044f \u043a\u0430\u0436\u0435\u0442\u0441\u044f \u0445\u0432\u0430\u0442\u0438\u0442.<\/p>\n<h2>Boilerplate<\/h2>\n<p>\u041a\u043e\u043d\u0435\u0447\u043d\u043e, \u0447\u0430\u0441\u0442\u044c \u044d\u0442\u0438\u0445 \u0438\u043d\u0441\u0442\u0440\u0443\u043c\u0435\u043d\u0442\u043e\u0432 \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u0430\u044f \u0438 \u043d\u0435 \u0442\u0440\u0435\u0431\u0443\u0435\u0442 \u0442\u0430\u043a\u043e\u0439 \u0440\u0430\u0437\u0432\u0435\u0440\u043d\u0443\u0442\u043e\u0439 \u0438\u043d\u0444\u0440\u0430\u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u044b, \u0430, \u043c\u043e\u0436\u0435\u0442, \u0438 \u0438\u0445 \u043f\u0443\u0431\u043b\u0438\u043a\u0430\u0446\u0438\u044f<\/p>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-340197","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/340197","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=340197"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/340197\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=340197"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=340197"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=340197"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}