{"id":14627,"date":"2024-01-05T19:21:13","date_gmt":"2024-01-05T15:51:13","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/"},"modified":"2024-01-05T19:21:13","modified_gmt":"2024-01-05T15:51:13","slug":"%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/","title":{"rendered":"\u062f\u0631 Vue \u0628\u0627 \u0627\u062c\u0632\u0627\u06cc \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u0628\u0647 \u0628\u0627\u0644\u0627 \u0628\u0631\u0648\u06cc\u062f \u062a\u0627 \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0647\u0628\u0648\u062f \u0628\u0628\u062e\u0634\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 \u0648\u0628 \u0633\u0627\u06cc\u062a\u06cc \u0628\u0627 \u0645\u062d\u062a\u0648\u0627\u06cc \u0632\u06cc\u0627\u062f \u0631\u0648\u06cc \u062f\u0631 \u0635\u0641\u062d\u0627\u062a \u0648\u0628 \u0622\u0646\u060c \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0641\u0631\u0627\u0646\u062a \u0627\u0646\u062f \u0645\u0639\u0645\u0648\u0644 \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u0646\u062f \u062a\u0627 \u06a9\u0627\u0631\u0647\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0644\u0630\u062a \u0628\u062e\u0634 \u062a\u0631 \u0648 \u0631\u0627\u062d\u062a \u062a\u0631 \u0634\u0648\u062f.  \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 + \u0641\u0644\u0634 \u0628\u0627\u0644\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f \u0631\u0648\u06cc \u0622&#8230;"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_%d9%be%d8%b1%d9%88%da%98%d9%87\" >\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u067e\u0631\u0648\u0698\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d8%b3%d8%a7%d8%ae%d8%aa_%d8%a7%d8%ac%d8%b2%d8%a7\" >\u0633\u0627\u062e\u062a \u0627\u062c\u0632\u0627<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d8%aa%d9%85%db%8c%d8%b2_%da%a9%d8%b1%d8%af%d9%86_%d9%be%d8%b1%d9%88%da%98%d9%87_vue\" >\u062a\u0645\u06cc\u0632 \u06a9\u0631\u062f\u0646 \u067e\u0631\u0648\u0698\u0647 Vue<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d8%b3%d8%a7%d8%ae%d8%aa_%d8%b1%d8%a7%d8%a8%d8%b7_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%db%8c_%d8%af%da%a9%d9%85%d9%87\" >\u0633\u0627\u062e\u062a \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u062f\u06a9\u0645\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d8%b1%d8%a7%d8%a8%d8%b7_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%db%8c_news_feeds\" >\u0627\u06cc\u062c\u0627\u062f \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc News Feeds<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d9%86%d9%85%d8%a7%db%8c%d8%b4%d9%be%d9%86%d9%87%d8%a7%d9%86_%da%a9%d8%b1%d8%af%d9%86_%d8%af%da%a9%d9%85%d9%87_%d8%a7%d8%b3%da%a9%d8%b1%d9%88%d9%84_%d8%a8%d9%87_%d8%a8%d8%a7%d9%84%d8%a7_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_%d8%a7%d8%b3%da%a9%d8%b1%d9%88%d9%84_%d8%b4%d9%86%d9%88%d9%86%d8%af%d9%87\" >\u0646\u0645\u0627\u06cc\u0634\/\u067e\u0646\u0647\u0627\u0646 \u06a9\u0631\u062f\u0646 \u062f\u06a9\u0645\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0634\u0646\u0648\u0646\u062f\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d8%a7%d8%ac%d8%b1%d8%a7%db%8c_%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af_%d8%a7%d8%b3%da%a9%d8%b1%d9%88%d9%84\" >\u0627\u062c\u0631\u0627\u06cc \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u0633\u06a9\u0631\u0648\u0644<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%af%d8%b1-vue-%d8%a8%d8%a7-%d8%a7%d8%ac%d8%b2%d8%a7%db%8c-%d9%82%d8%a7%d8%a8%d9%84-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d9%85%d8%ac%d8%af%d8%af-%d8%a8%d9%87-%d8%a8%d8%a7%d9%84%d8%a7-%d8%a8\/#%d9%85%d9%86%d8%a7%d8%a8%d8%b9_%d9%85%d8%b1%d8%a8%d9%88%d8%b7%d9%87\" >\u0645\u0646\u0627\u0628\u0639 \u0645\u0631\u0628\u0648\u0637\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 6<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<p>\u062f\u0631 \u0628\u0647\u0628\u0648\u062f \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0631\u0648\u06cc \u0647\u0631 \u0648\u0628 \u0633\u0627\u06cc\u062a\u06cc \u0628\u0627 \u0645\u062d\u062a\u0648\u0627\u06cc \u0632\u06cc\u0627\u062f \u0631\u0648\u06cc \u062f\u0631 \u0635\u0641\u062d\u0627\u062a \u0648\u0628 \u0622\u0646\u060c \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0641\u0631\u0627\u0646\u062a \u0627\u0646\u062f \u0645\u0639\u0645\u0648\u0644 \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u0646\u062f \u062a\u0627 \u06a9\u0627\u0631\u0647\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0644\u0630\u062a \u0628\u062e\u0634 \u062a\u0631 \u0648 \u0631\u0627\u062d\u062a \u062a\u0631 \u0634\u0648\u062f.<\/p>\n<p>\u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 + \u0641\u0644\u0634 \u0628\u0627\u0644\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f \u0631\u0648\u06cc \u06cc\u06a9 \u0635\u0641\u062d\u0647 \u06a9\u0644\u06cc\u062f\u060c \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u0647\u0645 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u0628\u0627\u0644\u0642\u0648\u0647 \u062f\u0631 \u0646\u0638\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f <em>\u0628\u06cc\u0634 \u0627\u0632 \u0646\u06cc\u0645\u06cc \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0634\u0645\u0627<\/em> \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0627\u0632 \u062f\u0633\u062a\u06af\u0627\u0647\u200c\u0647\u0627\u06cc \u062a\u0644\u0641\u0646 \u0647\u0645\u0631\u0627\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f \u0648 \u0647\u0646\u06af\u0627\u0645 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u062f\u0631 \u0648\u0628\u200c\u0633\u0627\u06cc\u062a \u0634\u0645\u0627 \u0627\u0632 \u0635\u0641\u062d\u0647\u200c\u06a9\u0644\u06cc\u062f \u0645\u062a\u0635\u0644 \u0628\u0647 \u062a\u0644\u0641\u0646 \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0646\u06a9\u0646\u062f.  \u0646\u0645\u0627\u06cc\u0634\u06af\u0631\u0647\u0627\u06cc \u06a9\u0648\u0686\u06a9\u062a\u0631 \u0627\u063a\u0644\u0628 \u0628\u0647 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0628\u06cc\u0634\u062a\u0631 \u0646\u06cc\u0632 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u0646\u062f \u0648 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0627\u0632 \u067e\u0627\u06cc\u06cc\u0646 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0631\u0627 \u067e\u0631 \u0632\u062d\u0645\u062a \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<blockquote>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0645\u0627 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue 3 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645 &#8211; \u0645\u0631\u062d\u0644\u0647 \u0628\u0647 \u0645\u0631\u062d\u0644\u0647.  \u062f\u0631 \u06a9\u0646\u0627\u0631 \u0645\u0648\u0644\u0641\u0647 \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f\u060c \u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0628\u0631\u06cc \u0647\u0633\u062a\u06cc\u0645 \u06a9\u0647 \u0627\u062e\u0628\u0627\u0631 \u0641\u0648\u0631\u06cc \u0631\u0627 \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u0645\u062e\u062a\u0644\u0641 \u0628\u0627 <a rel=\"nofollow noopener noreferrer\" target=\"_blank\" href=\"https:\/\/newsapi.org\/\">News API<\/a>.<\/p>\n<\/blockquote>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/scroll-to-top-in-vue-with-reusable-components-1.gif\" alt=\"\" title=\"\"><\/p>\n<h2 id=\"projectsetup\"><span class=\"ez-toc-section\" id=\"%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c_%d9%be%d8%b1%d9%88%da%98%d9%87\"><\/span>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u067e\u0631\u0648\u0698\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0634\u0631\u0648\u0639 \u06a9\u0627\u0631 \u0628\u0627 \u0686\u0627\u0631\u0686\u0648\u0628 Vue.JS \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc \u06af\u0646\u062c\u0627\u0646\u062f\u0646 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u062f\u0631 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 HTML \u0627\u0633\u062a.  \u0627\u0645\u0627 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u062f\u0646\u06cc\u0627\u06cc \u0648\u0627\u0642\u0639\u06cc \u0648 \u062f\u0631 \u0645\u0642\u06cc\u0627\u0633 \u0628\u0632\u0631\u06af\u060c <code>vue-cli<\/code> \u0628\u0647\u062a\u0631\u06cc\u0646 \u0631\u0627\u0647 \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u0627\u0633\u062a!  \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <code>vue-cli<\/code> \u062f\u0631 \u0622\u0645\u0648\u0632\u0634 \u0627\u0645\u0631\u0648\u0632 \u0645\u0627<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 \u0648 \u0646\u0627\u0645 \u0622\u0646 \u0631\u0627 \u0628\u06af\u0630\u0627\u0631\u06cc\u0645 <code>vue-scroll-to-top<\/code>\u060c \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> vue create vue-scroll-to-top<\/span>\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u06cc\u06a9 \u0627\u0644\u06af\u0648 \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u0633\u0627\u062e\u062a \u067e\u0631\u0648\u0698\u0647 \u0645\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.  \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0627 \u0631\u0641\u062a\u0646 \u0628\u0647 \u067e\u0631\u0648\u0698\u0647 \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> <span class=\"hljs-built_in\">cd<\/span> vue-scroll-to-top<\/span>\n<\/code><\/pre>\n<p>\u0648 <code>serve<\/code> \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0646\u062e \u06cc\u0627 NPM:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> yarn serve<\/span>\n<\/code><\/pre>\n<p>\u06cc\u0627:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm run serve<\/span>\n<\/code><\/pre>\n<p>\u0628\u0631 <code>localhost<\/code>\u060c \u062f\u0631 \u0628\u0646\u062f\u0631 <code>8080<\/code> &#8211; \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0634\u0645\u0627 \u0627\u0631\u0627\u0626\u0647 \u062e\u0648\u0627\u0647\u062f \u0634\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/scroll-to-top-in-vue-with-reusable-components-2.png\" alt=\"\" title=\"\"><\/p>\n<h2 id=\"buildingthecomponents\"><span class=\"ez-toc-section\" id=\"%d8%b3%d8%a7%d8%ae%d8%aa_%d8%a7%d8%ac%d8%b2%d8%a7\"><\/span>\u0633\u0627\u062e\u062a \u0627\u062c\u0632\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0627 \u0686\u0631\u062e\u0627\u0646\u062f\u0646 \u0627\u0644\u06af\u0648 &#8211; \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0634\u0631\u0648\u0639 \u0628\u0647 \u0633\u0627\u062e\u062a \u0645\u0648\u0644\u0641\u0647 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u06a9\u0646\u06cc\u0645\u060c \u06a9\u0647 \u0628\u0647 \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0627\u06cc \u06a9\u0647 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0633\u0627\u0632\u06cc\u062f \u062a\u0639\u0645\u06cc\u0645 \u0645\u06cc\u200c\u06cc\u0627\u0628\u062f.  \u0642\u0628\u0644 \u0627\u0632 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0622\u0645\u0627\u062f\u0647 \u0648 \u062a\u0645\u06cc\u0632 \u06a9\u0646\u06cc\u0645 <code>App.vue<\/code> \u0634\u0631\u0648\u0639\u06cc \u06a9\u0647 \u0628\u0627 Vue CLI \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645.<\/p>\n<h3 id=\"cleaningthevueproject\"><span class=\"ez-toc-section\" id=\"%d8%aa%d9%85%db%8c%d8%b2_%da%a9%d8%b1%d8%af%d9%86_%d9%be%d8%b1%d9%88%da%98%d9%87_vue\"><\/span>\u062a\u0645\u06cc\u0632 \u06a9\u0631\u062f\u0646 \u067e\u0631\u0648\u0698\u0647 Vue<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0632\u06cc\u0631 <code>src\/App.vue<\/code>\u060c \u0645\u0627 \u062c\u0632\u0621 \u0628\u0647 \u0632\u0648\u062f\u06cc \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062b\u0628\u062a \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>AppButton<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">section<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"app-container\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">AppButton<\/span> \/&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">section<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">import<\/span> AppButton <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\".\/components\/AppButton.vue\"<\/span>;\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">\"App\"<\/span>,\n\n    <span class=\"hljs-attr\">components<\/span>: {\n        AppButton\n    },\n\n    <span class=\"hljs-function\"><span class=\"hljs-title\">setup<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n        <span class=\"hljs-keyword\">return<\/span> {};\n    }\n};\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">style<\/span>&gt;<\/span><span class=\"css\">\n<span class=\"hljs-keyword\">@import<\/span> url(<span class=\"hljs-string\">\"https:\/\/fonts.googleapis.com\/css2\u061ffamily=Nunito&amp;display=swap\"<\/span>);\n* {\n    <span class=\"hljs-attribute\">margin<\/span>: <span class=\"hljs-number\">0<\/span>;\n    <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">0<\/span>;\n    <span class=\"hljs-attribute\">box-sizing<\/span>: border-box;\n    <span class=\"hljs-attribute\">font<\/span>: inherit;\n}\n<span class=\"hljs-selector-tag\">html<\/span> {\n    <span class=\"hljs-attribute\">font-family<\/span>: <span class=\"hljs-string\">\"Nunito\"<\/span>, sans-serif;\n}\n<span class=\"hljs-selector-tag\">body<\/span> {\n    <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">15px<\/span>;\n    <span class=\"hljs-attribute\">color<\/span>: <span class=\"hljs-number\">#000000<\/span>;\n    <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-number\">#fff<\/span>;\n}\n<span class=\"hljs-selector-tag\">h1<\/span>,\n<span class=\"hljs-selector-tag\">h2<\/span>,\n<span class=\"hljs-selector-tag\">h3<\/span>,\n<span class=\"hljs-selector-tag\">h4<\/span>,\n<span class=\"hljs-selector-tag\">h5<\/span>,\n<span class=\"hljs-selector-tag\">h6<\/span> {\n    <span class=\"hljs-attribute\">color<\/span>: <span class=\"hljs-number\">#000000<\/span>;\n}\n<span class=\"hljs-selector-tag\">img<\/span> {\n    <span class=\"hljs-attribute\">max-width<\/span>: <span class=\"hljs-number\">100%<\/span>;\n}\n<span class=\"hljs-selector-tag\">ul<\/span> {\n    <span class=\"hljs-attribute\">list-style<\/span>: none;\n}\n<span class=\"hljs-selector-tag\">a<\/span> {\n    <span class=\"hljs-attribute\">text-decoration<\/span>: none;\n    <span class=\"hljs-attribute\">display<\/span>: inline-block;\n}\n<span class=\"hljs-selector-class\">.app-container<\/span> {\n    <span class=\"hljs-attribute\">max-width<\/span>: <span class=\"hljs-number\">82rem<\/span>;\n    <span class=\"hljs-attribute\">margin<\/span>: auto;\n    <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">3rem<\/span> <span class=\"hljs-number\">1rem<\/span>;\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">style<\/span>&gt;<\/span>\n<\/code><\/pre>\n<h3 id=\"buildingthebuttonui\"><span class=\"ez-toc-section\" id=\"%d8%b3%d8%a7%d8%ae%d8%aa_%d8%b1%d8%a7%d8%a8%d8%b7_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%db%8c_%d8%af%da%a9%d9%85%d9%87\"><\/span>\u0633\u0627\u062e\u062a \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u062f\u06a9\u0645\u0647<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0627 page \u06a9\u0647 \u062f\u06a9\u0645\u0647 (\u0648 \u0627\u062e\u0628\u0627\u0631) \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f &#8211; \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0634\u0631\u0648\u0639 \u0628\u0647 \u0633\u0627\u062e\u062a \u0627\u062c\u0632\u0627 \u06a9\u0646\u06cc\u0645.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0627 \u062f\u06a9\u0645\u0647 \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u0645!<\/p>\n<p>\u062f\u0631 <code>components<\/code> \u067e\u0648\u0634\u0647\u060c \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f <code>AppButton.vue<\/code> \u0641\u0627\u06cc\u0644.  \u062f\u0631 \u062f\u06a9\u0645\u0647\u060c \u0646\u0645\u0627\u062f\u06cc \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0646\u0634\u0627\u0646 \u062f\u0647\u0646\u062f\u0647 \u0627\u06cc\u0646 \u0627\u0633\u062a <em>\u0641\u0644\u0634 \u0628\u0627\u0644\u0627<\/em> \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0642\u0627\u0644 \u0628\u0635\u0631\u06cc \u0639\u0645\u0644\u06a9\u0631\u062f.  \u0628\u0631\u0627\u06cc \u062e\u0648\u062f \u0622\u06cc\u06a9\u0648\u0646\u060c \u0627\u0632 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0622\u06cc\u06a9\u0648\u0646 \u0628\u0647 \u0646\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <em>\u0641\u0648\u0646\u062a \u0639\u0627\u0644\u06cc<\/em> \u06a9\u0647 \u062f\u0627\u0631\u0627\u06cc \u0628\u06cc\u0634 \u0627\u0632 19000 \u0646\u0645\u0627\u062f \u062f\u0631 6 \u0633\u0628\u06a9 \u0648 \u0645\u0627\u0631\u06a9 \u0627\u0633\u062a\u060c \u0627\u06af\u0631\u0686\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u0639\u0644\u0627\u0645\u062a \u0633\u0627\u062f\u0647 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0631\u062f (<code>^<\/code>)\u060c \u06cc\u06a9 \u0646\u0645\u0627\u062f \u0633\u0641\u0627\u0631\u0634\u06cc \u06cc\u0627 \u06cc\u06a9 \u0646\u0645\u0627\u062f \u0627\u0632 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0627\u06af\u0631 \u0646\u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u062f\u06cc\u06af\u0631\u06cc \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u062f\u0644\u062e\u0648\u0627\u0647 \u062e\u0648\u062f\u060c \u0628\u0633\u062a\u0647 \u0627\u0635\u0644\u06cc \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0634\u0627\u0645\u0644 \u062a\u0645\u0627\u0645 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u06a9\u0631\u062f \u0622\u06cc\u06a9\u0648\u0646 \u0647\u0627 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> yarn add @fortawesome\/fontawesome-svg-core<\/span>\n<span class=\"hljs-meta\">#<\/span><span class=\"bash\"> Or<\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm i --save @fortawesome\/fontawesome-svg-core<\/span>\n<\/code><\/pre>\n<p>\u0628\u0639\u062f\u060c \u0645\u0627 \u0631\u0627 \u0646\u0635\u0628 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <em>\u0622\u06cc\u06a9\u0648\u0646 \u0647\u0627\u06cc \u062c\u0627\u0645\u062f SVG \u0631\u0627\u06cc\u06af\u0627\u0646<\/em> (\u06cc\u06a9\u06cc \u0627\u0632 \u0645\u062c\u0645\u0648\u0639\u0647\u200c\u0647\u0627 \u06cc\u0627 \u0633\u0628\u06a9\u200c\u0647\u0627\u06cc \u0645\u0648\u062c\u0648\u062f)\u060c \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> yarn add @fortawesome\/free-solid-svg-icons<\/span>\n<span class=\"hljs-meta\">#<\/span><span class=\"bash\"> Or<\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm i --save @fortawesome\/free-solid-svg-icons<\/span>\n<\/code><\/pre>\n<p>\u0648 \u062f\u0631 \u0622\u062e\u0631\u060c \u0645\u0627 \u0622\u0646 \u0631\u0627 \u0646\u0635\u0628 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <em>\u0641\u0648\u0646\u062a Awesome Vue Component<\/em> \u0628\u0631\u0627\u06cc Vue 3 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> yarn add @fortawesome\/vue-fontawesome@latest-3<\/span>\n<span class=\"hljs-meta\">#<\/span><span class=\"bash\"> Or<\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm i --save @fortawesome\/vue-fontawesome@latest-3<\/span>\n<\/code><\/pre>\n<p>\u0642\u0628\u0644 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u062a\u0648\u0627\u0646\u06cc\u0645 \u0646\u0645\u0627\u062f \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u062f\u06a9\u0645\u0647 \u062e\u0648\u062f \u0631\u0646\u062f\u0631 \u06a9\u0646\u06cc\u0645\u060c \u0628\u0627\u06cc\u062f \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645 import \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc Font Awesome \u0646\u0635\u0628 \u0634\u062f\u0647 \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u0645\u0627\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u0646\u0627\u0645 \u0646\u0645\u0627\u062f \u062e\u0627\u0635\u06cc \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u06a9\u0646\u06cc\u0645 <code>main.js<\/code> \u0641\u0627\u06cc\u0644:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { createApp } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'vue'<\/span>\n<span class=\"hljs-keyword\">import<\/span> App <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'.\/App.vue'<\/span>\n\n<span class=\"hljs-comment\">\/* Import the fontawesome core *\/<\/span>\n<span class=\"hljs-keyword\">import<\/span> { library } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@fortawesome\/fontawesome-svg-core'<\/span>\n<span class=\"hljs-comment\">\/* Import font awesome icon component *\/<\/span>\n<span class=\"hljs-keyword\">import<\/span> { FontAwesomeIcon } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@fortawesome\/vue-fontawesome'<\/span>\n<span class=\"hljs-comment\">\/* Import specific icons *\/<\/span>\n<span class=\"hljs-keyword\">import<\/span> { faArrowUp } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@fortawesome\/free-solid-svg-icons'<\/span>\n<span class=\"hljs-comment\">\/* Add icons to the library *\/<\/span>\nlibrary.add(faArrowUp)\n\ncreateApp(App).component(<span class=\"hljs-string\">'font-awesome-icon'<\/span>, FontAwesomeIcon).mount(<span class=\"hljs-string\">'#app'<\/span>)\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0646\u0645\u0627\u062f \u0641\u0644\u0634 \u0631\u0648 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0631\u0627 as \u0635\u062f\u0627 \u06a9\u0646\u06cc\u0645 <code>faArrowUp<\/code>\u060c \u06a9\u0647 \u062f\u0631 <code>AppButton.vue<\/code> \u0628\u0631\u0627\u06cc \u0631\u0646\u062f\u0631 \u06a9\u0631\u062f\u0646 \u0622\u0646 \u062f\u0631 UI!  \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u062f\u06a9\u0645\u0647 \u0631\u0627 \u0627\u0632 \u0641\u0627\u06cc\u0644 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0627\u0633\u062a\u0627\u06cc\u0644 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"app-button\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">font-awesome-icon<\/span> <span class=\"hljs-attr\">icon<\/span>=<span class=\"hljs-string\">\"fa-solid fa-arrow-up\"<\/span> \/&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">style<\/span> <span class=\"hljs-attr\">scoped<\/span>&gt;<\/span><span class=\"css\">\n<span class=\"hljs-selector-class\">.app-button<\/span> {\n  <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">50%<\/span>;\n  <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">50px<\/span>;\n  <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">50px<\/span>;\n  <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">4px<\/span>;\n  <span class=\"hljs-attribute\">box-shadow<\/span>: <span class=\"hljs-number\">2px<\/span> <span class=\"hljs-number\">2px<\/span> <span class=\"hljs-number\">#e9e9e9<\/span>;\n  <span class=\"hljs-attribute\">cursor<\/span>: pointer;\n  <span class=\"hljs-attribute\">position<\/span>: fixed;\n  <span class=\"hljs-attribute\">right<\/span>: <span class=\"hljs-number\">40px<\/span>;\n  <span class=\"hljs-attribute\">bottom<\/span>: <span class=\"hljs-number\">40px<\/span>;\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">style<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u062f\u0631 DOM\u060c \u0648\u0642\u062a\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627\u0632 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u062f\u06a9\u0645\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0645\u0627 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0627\u06cc\u0646 \u0634\u06a9\u0644 \u0628\u0627\u0634\u062f \u0631\u0648\u06cc <code>localhost:8080<\/code>:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/scroll-to-top-in-vue-with-reusable-components-3.png\" alt=\"\" title=\"\"><\/p>\n<h3 id=\"buildingthenewsfeedsui\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d8%b1%d8%a7%d8%a8%d8%b7_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%db%8c_news_feeds\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc News Feeds<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u062d\u06cc\u0637\u06cc \u06a9\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u06a9\u0627\u0631\u0628\u0631 \u0628\u062e\u0648\u0627\u0647\u062f \u062f\u0631 \u0622\u0646 \u0627\u0632 \u062f\u06a9\u0645\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u062f\u060c \u0628\u0647 \u062c\u0627\u06cc \u067e\u06cc\u0645\u0627\u06cc\u0634 \u062f\u0633\u062a\u06cc &#8211; \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0645\u062d\u062a\u0648\u0627\u06cc \u062e\u0628\u0631\u06cc \u0632\u06cc\u0627\u062f\u06cc \u0631\u0627 \u0627\u0632 News API \u0631\u0627\u06cc\u06af\u0627\u0646 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u06cc\u0645.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc \u0648\u0627\u06a9\u0634\u06cc\u060c \u0627\u0632 \u0627\u06cc\u0646 \u0645\u0632\u06cc\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <code>axios<\/code> \u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc<\/p>\n<p>\u0627\u06af\u0631 \u0642\u0628\u0644\u0627\u064b \u0622\u0646 \u0631\u0627 \u0646\u0635\u0628 \u0646\u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0637\u0631\u06cc\u0642 Yarn \u06cc\u0627 NPM \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> yarn add axios<\/span>\n<span class=\"hljs-meta\">#<\/span><span class=\"bash\"> Or<\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install axios<\/span>\n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 News API\u060c \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0631\u0627 \u062b\u0628\u062a \u06a9\u0646\u06cc\u062f <a rel=\"nofollow noopener noreferrer\" href=\"https:\/\/newsapi.org\/register\" target=\"_blank\">\u062d\u0633\u0627\u0628<\/a> &#8211; \u0628\u0631\u0627\u06cc \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u06cc\u06a9 \u06a9\u0644\u06cc\u062f API \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0645\u062d\u06cc\u0637 \u0647\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u0631\u0627\u06cc\u06af\u0627\u0646 \u0627\u0633\u062a.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0646\u0633\u062e\u0647 \u06cc \u0646\u0645\u0627\u06cc\u0634\u06cc\u060c \u0641\u0642\u0637 \u0628\u0627 \u0648\u0627\u06a9\u0634\u06cc \u0647\u0645\u0647 \u0645\u0642\u0627\u0644\u0627\u062a\u060c \u0645\u062b\u0644\u0627\u064b\u060c \u0628\u06cc\u062a \u06a9\u0648\u06cc\u0646\u060c \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0631\u0627 \u0633\u0627\u062f\u0647 \u0646\u06af\u0647 \u0645\u06cc \u062f\u0627\u0631\u06cc\u0645.  \u062f\u0631 <code>components<\/code> \u067e\u0648\u0634\u0647\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062c\u062f\u06cc\u062f \u0628\u0647 \u0646\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>NewsList.vue<\/code>.  \u06a9\u0647 \u062f\u0631 <code>NewsList.vue<\/code>\u060c \u0645\u0627 \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0645\u0642\u0627\u0644\u0627\u062a \u062e\u0628\u0631\u06cc \u0628\u06cc\u062a \u06a9\u0648\u06cc\u0646 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f \u06a9\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0627\u0633\u062e \u0627\u0632 API \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p><code>NewsList.vue<\/code>  \u0627\u06a9\u0646\u0648\u0646 \u0628\u0627\u06cc\u062f \u0634\u0627\u0645\u0644 \u06a9\u062f\u0647\u0627\u06cc \u0632\u06cc\u0631 \u0628\u0627\u0634\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">section<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">ul<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"news-list\"<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">li<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"news-card\"<\/span> <span class=\"hljs-attr\">v-for<\/span>=<span class=\"hljs-string\">\"newsItem in newsList\"<\/span> <span class=\"hljs-attr\">:key<\/span>=<span class=\"hljs-string\">\"newsItem.id\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"heading\"<\/span>&gt;<\/span>Title<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>: {{ newsItem.title }}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"heading\"<\/span>&gt;<\/span>Author<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>: {{ newsItem.author }}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"heading\"<\/span>&gt;<\/span>Description<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>: {{ newsItem.description }}\n        <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"heading\"<\/span>&gt;<\/span>Source<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>: {{ newsItem.source.name }}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">li<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">ul<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">section<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">import<\/span> axios <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"axios\"<\/span>;\n<span class=\"hljs-keyword\">import<\/span> { onMounted, ref } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"vue\"<\/span>;\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">\"NewsList\"<\/span>,\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setup<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">const<\/span> newsList = ref(());\n\n    <span class=\"hljs-keyword\">const<\/span> fetchNews = <span class=\"hljs-function\">() =&gt;<\/span> {\n      axios\n        .get(\n          <span class=\"hljs-string\">\"https:\/\/newsapi.org\/v2\/everything\u061fq=bitcoin&amp;apiKey=94585b39692e4ea6b372bea15abf7dcc\"<\/span>\n        )\n        .then(<span class=\"hljs-function\">(<span class=\"hljs-params\">response<\/span>) =&gt;<\/span> (newsList.value = response.data.articles));\n    };\n\n    onMounted(<span class=\"hljs-function\">() =&gt;<\/span> {\n      fetchNews();\n    });\n\n    <span class=\"hljs-keyword\">return<\/span> { newsList };\n  },\n};\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">style<\/span> <span class=\"hljs-attr\">scoped<\/span>&gt;<\/span><span class=\"css\">\n<span class=\"hljs-selector-tag\">ul<\/span><span class=\"hljs-selector-class\">.news-list<\/span> {\n  <span class=\"hljs-attribute\">display<\/span>: grid;\n  grid-template-<span class=\"hljs-attribute\">columns<\/span>: <span class=\"hljs-built_in\">repeat<\/span>(<span class=\"hljs-number\">3<\/span>, <span class=\"hljs-number\">1<\/span>fr);\n  gap: <span class=\"hljs-number\">3rem<\/span>;\n}\n<span class=\"hljs-selector-tag\">ul<\/span> <span class=\"hljs-selector-tag\">li<\/span><span class=\"hljs-selector-class\">.news-card<\/span> {\n  <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">10px<\/span>;\n  <span class=\"hljs-attribute\">display<\/span>: flex;\n  <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">8px<\/span>;\n  <span class=\"hljs-attribute\">flex-direction<\/span>: column;\n  row-gap: <span class=\"hljs-number\">5px<\/span>;\n  <span class=\"hljs-attribute\">box-shadow<\/span>: <span class=\"hljs-number\">0px<\/span> <span class=\"hljs-number\">4px<\/span> <span class=\"hljs-number\">12px<\/span> -<span class=\"hljs-number\">1px<\/span> <span class=\"hljs-built_in\">rgba<\/span>(<span class=\"hljs-number\">120<\/span>,<span class=\"hljs-number\">116<\/span>,<span class=\"hljs-number\">120<\/span>,<span class=\"hljs-number\">0.79<\/span>);\n}\n<span class=\"hljs-selector-tag\">li<\/span> <span class=\"hljs-selector-tag\">p<\/span> <span class=\"hljs-selector-tag\">span<\/span><span class=\"hljs-selector-class\">.heading<\/span> {\n  <span class=\"hljs-attribute\">font-weight<\/span>: <span class=\"hljs-number\">600<\/span>;\n  <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">18<\/span>;\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">style<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0633\u067e\u0633\u060c \u0645\u0627 \u062d\u062a\u0645\u0627 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>App.vue<\/code>\u060c \u062a\u0627 \u0644\u06cc\u0633\u062a \u0645\u0642\u0627\u0644\u0627\u062a \u062e\u0628\u0631\u06cc \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0634\u0648\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">section<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"app-container\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">AppButton<\/span> \/&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">NewsList<\/span> \/&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">section<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">import<\/span> AppButton <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\".\/components\/AppButton.vue\"<\/span>;\n<span class=\"hljs-keyword\">import<\/span> NewsList <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\".\/components\/NewsList.vue\"<\/span>;\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">\"App\"<\/span>,\n  <span class=\"hljs-attr\">components<\/span>: {\n    AppButton,\n    NewsList,\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setup<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span>{}\n  }\n};\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">style<\/span>&gt;<\/span><span class=\"css\">\n<span class=\"hljs-keyword\">@import<\/span> url(<span class=\"hljs-string\">\"https:\/\/fonts.googleapis.com\/css2\u061ffamily=Nunito&amp;display=swap\"<\/span>);\n* {\n  <span class=\"hljs-attribute\">margin<\/span>: <span class=\"hljs-number\">0<\/span>;\n  <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">0<\/span>;\n  <span class=\"hljs-attribute\">box-sizing<\/span>: border-box;\n  <span class=\"hljs-attribute\">font<\/span>: inherit;\n}\n<span class=\"hljs-selector-tag\">html<\/span> {\n  <span class=\"hljs-attribute\">font-family<\/span>: <span class=\"hljs-string\">\"Nunito\"<\/span>, sans-serif;\n}\n<span class=\"hljs-selector-tag\">body<\/span> {\n  <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">15px<\/span>;\n  <span class=\"hljs-attribute\">color<\/span>: <span class=\"hljs-number\">#000000<\/span>;\n  <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-number\">#fff<\/span>;\n}\n<span class=\"hljs-selector-tag\">h1<\/span>,\n<span class=\"hljs-selector-tag\">h2<\/span>,\n<span class=\"hljs-selector-tag\">h3<\/span>,\n<span class=\"hljs-selector-tag\">h4<\/span>,\n<span class=\"hljs-selector-tag\">h5<\/span>,\n<span class=\"hljs-selector-tag\">h6<\/span> {\n  <span class=\"hljs-attribute\">color<\/span>: <span class=\"hljs-number\">#000000<\/span>;\n}\n<span class=\"hljs-selector-tag\">img<\/span> {\n  <span class=\"hljs-attribute\">max-width<\/span>: <span class=\"hljs-number\">100%<\/span>;\n}\n<span class=\"hljs-selector-tag\">ul<\/span> {\n  <span class=\"hljs-attribute\">list-style<\/span>: none;\n}\n<span class=\"hljs-selector-tag\">a<\/span> {\n  <span class=\"hljs-attribute\">text-decoration<\/span>: none;\n  <span class=\"hljs-attribute\">display<\/span>: inline-block;\n}\n<span class=\"hljs-selector-class\">.app-container<\/span> {\n  <span class=\"hljs-attribute\">max-width<\/span>: <span class=\"hljs-number\">82rem<\/span>;\n  <span class=\"hljs-attribute\">margin<\/span>: auto;\n  <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">3rem<\/span> <span class=\"hljs-number\">1rem<\/span>;\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">style<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0645\u0639\u0645\u0648\u0644\u0627 &#8211; \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0646\u062a\u0627\u06cc\u062c \u0631\u0627 \u0628\u0647 \u062c\u0627\u06cc \u0627\u0646\u0628\u0627\u0634\u062a\u0647 \u06a9\u0631\u062f\u0646 \u0622\u0646\u0647\u0627 \u0635\u0641\u062d\u0647 \u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f.  \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0645\u0627 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0627\u0635 \u0645\u0648\u0631\u062f\u06cc \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0645\u0641\u06cc\u062f \u0627\u0633\u062a.<\/p>\n<h2 id=\"showhidescrolltotopbuttonusingscrolllistener\"><span class=\"ez-toc-section\" id=\"%d9%86%d9%85%d8%a7%db%8c%d8%b4%d9%be%d9%86%d9%87%d8%a7%d9%86_%da%a9%d8%b1%d8%af%d9%86_%d8%af%da%a9%d9%85%d9%87_%d8%a7%d8%b3%da%a9%d8%b1%d9%88%d9%84_%d8%a8%d9%87_%d8%a8%d8%a7%d9%84%d8%a7_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_%d8%a7%d8%b3%da%a9%d8%b1%d9%88%d9%84_%d8%b4%d9%86%d9%88%d9%86%d8%af%d9%87\"><\/span>\u0646\u0645\u0627\u06cc\u0634\/\u067e\u0646\u0647\u0627\u0646 \u06a9\u0631\u062f\u0646 \u062f\u06a9\u0645\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0634\u0646\u0648\u0646\u062f\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0628\u062e\u0634\u06cc \u0627\u0632 \u06cc\u06a9 \u062a\u062c\u0631\u0628\u0647 \u062c\u0630\u0627\u0628 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u0645 \u06a9\u0647 \u062f\u06a9\u0645\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u062a\u0646\u0647\u0627 \u0632\u0645\u0627\u0646\u06cc \u0622\u0634\u06a9\u0627\u0631 \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0634\u0631\u0648\u0639 \u0628\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u06a9\u0631\u062f\u0646 \u0628\u0647 \u067e\u0627\u06cc\u06cc\u0646 page.<\/p>\n<blockquote>\n<p>\u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u06cc\u0627\u0628\u06cc \u0628\u0647 \u0627\u06cc\u0646 \u0647\u062f\u0641\u060c \u0645\u0627 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u0633\u06a9\u0631\u0648\u0644 \u062f\u0631 \u0646\u0642\u0637\u0647 \u0627\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0647 \u067e\u0627\u06cc\u06cc\u0646 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0645\u06cc \u06a9\u0646\u062f \u06af\u0648\u0634 \u062f\u0647\u06cc\u0645 page.<\/p>\n<\/blockquote>\n<p>\u0627\u0628\u062a\u062f\u0627\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0639\u0646\u0635\u0631 \u062f\u06a9\u0645\u0647 \u0631\u0627 \u0628\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06cc\u06a9 \u0645\u0631\u062c\u0639 \u0628\u0631\u0627\u06cc \u0622\u0646 \u0647\u062f\u0641 \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u0645.  \u0633\u067e\u0633\u060c \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>beforeUnmount()<\/code> \u0642\u0644\u0627\u0628\u200c\u0647\u0627\u06cc \u0686\u0631\u062e\u0647 \u062d\u06cc\u0627\u062a \u0628\u0631\u0627\u06cc \u0627\u0641\u0632\u0648\u062f\u0646 \u0648 \u062d\u0630\u0641 \u062f\u06a9\u0645\u0647 \u0627\u0632 DOM\u060c \u0628\u0627 \u06a9\u0645\u06a9 \u0634\u0646\u0648\u0646\u062f\u0647 \u067e\u06cc\u0645\u0627\u06cc\u0634 &#8211; \u067e\u0633 \u0627\u0632 \u0627\u0633\u06a9\u0631\u0648\u0644 \u06a9\u0631\u062f\u0646 page \u06cc\u0627 \u0628\u0647 \u0628\u0627\u0644\u0627\u062a\u0631\u06cc\u0646 \u0642\u0633\u0645\u062a page.  \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0622\u06cc\u0627 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u062f\u0631 \u0628\u0627\u0644\u0627\u06cc \u0635\u0641\u062d\u0647 \u0642\u0631\u0627\u0631 \u062f\u0627\u0631\u062f \u06cc\u0627 \u062e\u06cc\u0631 page \u0627\u06af\u0631 <code>window.scrollY<\/code> \u0628\u0632\u0631\u06af\u062a\u0631 \u0627\u0632 0 \u0627\u0633\u062a. \u0628\u0627 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u062f\u06cc\u062f \u062f\u06a9\u0645\u0647 \u0631\u0627 \u062f\u0631 \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0644\u0627\u0632\u0645 \u0627\u0633\u062a \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u0645.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u06a9\u0646\u06cc\u0645 <code>AppButton.vue<\/code> \u062c\u0632\u0621 \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u06cc\u0627 \u067e\u0646\u0647\u0627\u0646 \u06a9\u0631\u062f\u0646 \u062f\u06a9\u0645\u0647 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0631\u0648\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0686\u0642\u062f\u0631 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u06a9\u0631\u062f\u0647 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">ref<\/span>=<span class=\"hljs-string\">\"appButton\"<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"app-button\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">font-awesome-icon<\/span> <span class=\"hljs-attr\">icon<\/span>=<span class=\"hljs-string\">\"fa-solid fa-arrow-up\"<\/span> \/&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">import<\/span> { onMounted, ref, onBeforeMount } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"vue\"<\/span>;\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">\"AppButton\"<\/span>,\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setup<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">const<\/span> appButton = ref();\n    <span class=\"hljs-keyword\">const<\/span> userScroll = <span class=\"hljs-function\">() =&gt;<\/span> {\n      <span class=\"hljs-keyword\">if<\/span> (<span class=\"hljs-built_in\">window<\/span>.scrollY &gt; <span class=\"hljs-number\">0<\/span>) {\n        appButton.value.classList.add(<span class=\"hljs-string\">\"showButton\"<\/span>);\n        <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'scrolled'<\/span>);\n      } <span class=\"hljs-keyword\">else<\/span> {\n        appButton.value.classList.remove(<span class=\"hljs-string\">\"showButton\"<\/span>);\n        <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'top'<\/span>);\n      }\n    };\n    onMounted(<span class=\"hljs-function\">() =&gt;<\/span> {\n      <span class=\"hljs-built_in\">window<\/span>.addEventListener(<span class=\"hljs-string\">\"scroll\"<\/span>, userScroll);\n    });\n    onBeforeMount(<span class=\"hljs-function\">() =&gt;<\/span> {\n      <span class=\"hljs-built_in\">window<\/span>.removeEventListener(<span class=\"hljs-string\">\"scroll\"<\/span>, userScroll);\n    });\n    <span class=\"hljs-keyword\">return<\/span> { appButton };\n  },\n};\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">style<\/span> <span class=\"hljs-attr\">scoped<\/span>&gt;<\/span><span class=\"css\">\n<span class=\"hljs-selector-class\">.app-button<\/span> {\n  <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">50%<\/span>;\n  <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">50px<\/span>;\n  <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">50px<\/span>;\n  <span class=\"hljs-attribute\">padding<\/span>: <span class=\"hljs-number\">4px<\/span>;\n  <span class=\"hljs-attribute\">box-shadow<\/span>: <span class=\"hljs-number\">2px<\/span> <span class=\"hljs-number\">2px<\/span> <span class=\"hljs-number\">#e9e9e9<\/span>;\n  <span class=\"hljs-attribute\">cursor<\/span>: pointer;\n  <span class=\"hljs-attribute\">position<\/span>: fixed;\n  <span class=\"hljs-attribute\">bottom<\/span>: <span class=\"hljs-number\">40px<\/span>;\n  <span class=\"hljs-attribute\">display<\/span>: none;\n  <span class=\"hljs-attribute\">right<\/span>: <span class=\"hljs-number\">40px<\/span>;\n}\n\n<span class=\"hljs-selector-class\">.showButton<\/span> {\n  <span class=\"hljs-attribute\">display<\/span>: block;\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">style<\/span>&gt;<\/span>\n<\/code><\/pre>\n<h2 id=\"implementingscrollevent\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%ac%d8%b1%d8%a7%db%8c_%d8%b1%d9%88%db%8c%d8%af%d8%a7%d8%af_%d8%a7%d8%b3%da%a9%d8%b1%d9%88%d9%84\"><\/span>\u0627\u062c\u0631\u0627\u06cc \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u0633\u06a9\u0631\u0648\u0644<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0686\u06cc\u0632\u06cc \u06a9\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647 \u0628\u0631\u0627\u06cc \u0645\u0627 \u0628\u0627\u0642\u06cc \u0645\u06cc \u0645\u0627\u0646\u062f \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u062f\u06a9\u0645\u0647 \u0631\u0627 \u062f\u0631 \u0648\u0627\u0642\u0639 \u0628\u0647 \u0628\u0627\u0644\u0627\u06cc \u0635\u0641\u062d\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u06a9\u0646\u06cc\u0645 page \u0648\u0642\u062a\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0631\u0648\u06cc \u0622\u0646 \u06a9\u0644\u06cc\u06a9 \u0645\u06cc \u06a9\u0646\u062f.  \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u06cc\u0627\u0628\u06cc \u0628\u0647 \u0627\u06cc\u0646\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u06cc\u06a9 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 <code>scrollToTop()<\/code> \u0631\u0648\u0634 \u062f\u0631 <code>AppButton.vue<\/code>.  \u0627\u06cc\u0646 \u0631\u0648\u0634\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>window.scrollY = 0<\/code>.  \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631\u060c \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 <code>scrollToTop()<\/code> \u0631\u0648\u0634 \u0645\u0627 \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f page \u0628\u0647 \u0622\u0631\u0627\u0645\u06cc \u0628\u0647 \u0628\u0627\u0644\u0627\u062a\u0631\u06cc\u0646 \u0642\u0633\u0645\u062a \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u062f\u06a9\u0645\u0647 \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0627\u0644\u0627\u06cc \u0628\u0627\u0644\u0627 \u0646\u06cc\u0632 \u0646\u0627\u067e\u062f\u06cc\u062f \u0645\u06cc\u200c\u0634\u0648\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ AppButton.vue<\/span>\n<span class=\"hljs-keyword\">const<\/span> scrollToTop = <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-built_in\">window<\/span>.scrollTo({ <span class=\"hljs-attr\">top<\/span>: <span class=\"hljs-number\">0<\/span>, <span class=\"hljs-attr\">behavior<\/span>: <span class=\"hljs-string\">\"smooth\"<\/span> });\n};\n<\/code><\/pre>\n<p>\u0648\u0642\u062a\u06cc \u0627\u06cc\u0646 \u0642\u0637\u0639\u0647 \u06a9\u062f \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u0634\u0648\u062f <code>AppButton.vue<\/code>\u060c \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u06a9\u0647 \u0645\u0627 \u06cc\u06a9 \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0631\u0627 \u0628\u0627 \u0645\u0648\u0641\u0642\u06cc\u062a \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 Vue \u062e\u0648\u062f \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u0647\u0631 \u067e\u0631\u0648\u0698\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u0647 \u0622\u0646 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645 \u0645\u062a\u0635\u0644 \u06a9\u0646\u06cc\u0645.<\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062a\u0628\u0631\u06cc\u06a9 \u0645\u06cc \u06af\u0648\u06cc\u0645 \u0631\u0648\u06cc \u062a\u0627 \u0627\u0646\u062a\u0647\u0627 \u062f\u0646\u0628\u0627\u0644 \u06a9\u0646\u06cc\u062f!  \ud83d\udd25<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634\u060c \u0631\u0648\u0634 \u0633\u0627\u062e\u062a \u0642\u0627\u0628\u0644\u06cc\u062a \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u062f\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Vue \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0631\u062f\u06cc\u0645.  \u0627\u06cc\u0646 \u06cc\u06a9 \u062c\u0632\u0621 \u0639\u0645\u0648\u0645\u06cc \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u0627\u0633\u062a \u0648 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0646\u06cc\u0632 \u0645\u0639\u0631\u0641\u06cc \u0634\u0648\u062f.<\/p>\n<h2 id=\"relevantresources\"><span class=\"ez-toc-section\" id=\"%d9%85%d9%86%d8%a7%d8%a8%d8%b9_%d9%85%d8%b1%d8%a8%d9%88%d8%b7%d9%87\"><\/span>\u0645\u0646\u0627\u0628\u0639 \u0645\u0631\u0628\u0648\u0637\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<ul>\n<li><a rel=\"nofollow noopener noreferrer\" target=\"_blank\" href=\"https:\/\/newsapi.org\/docs\">News API<\/a><\/li>\n<li><a rel=\"nofollow noopener noreferrer\" target=\"_blank\" href=\"https:\/\/vuejs.org\/guide\/introduction.html\">Vue Docs<\/a><\/li>\n<li><a rel=\"nofollow noopener noreferrer\" target=\"_blank\" href=\"https:\/\/fontawesome.com\/docs\/web\/use-with\/vue\/\">FontAwesome Docs<\/a><\/li>\n<li><a rel=\"nofollow noopener noreferrer\" target=\"_blank\" href=\"https:\/\/axios-http.com\/docs\/intro\">Axios Docs<\/a><\/li>\n<\/ul>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-05 19:21:04<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;14627&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u062f\u0631 Vue \u0628\u0627 \u0627\u062c\u0632\u0627\u06cc \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u0628\u0647 \u0628\u0627\u0644\u0627 \u0628\u0631\u0648\u06cc\u062f \u062a\u0627 \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0647\u0628\u0648\u062f \u0628\u0628\u062e\u0634\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 \u0648\u0628 \u0633\u0627\u06cc\u062a\u06cc \u0628\u0627 \u0645\u062d\u062a\u0648\u0627\u06cc \u0632\u06cc\u0627\u062f \u0631\u0648\u06cc \u062f\u0631 \u0635\u0641\u062d\u0627\u062a \u0648\u0628 \u0622\u0646\u060c \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0641\u0631\u0627\u0646\u062a \u0627\u0646\u062f \u0645\u0639\u0645\u0648\u0644 \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u0646\u062f \u062a\u0627 \u06a9\u0627\u0631\u0647\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0644\u0630\u062a \u0628\u062e\u0634 \u062a\u0631 \u0648 \u0631\u0627\u062d\u062a \u062a\u0631 \u0634\u0648\u062f.  \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 + \u0641\u0644\u0634 \u0628\u0627\u0644\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f \u0631\u0648\u06cc \u0622...&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 6<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u062f\u0631 \u0628\u0647\u0628\u0648\u062f \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0631\u0648\u06cc \u0647\u0631 \u0648\u0628 \u0633\u0627\u06cc\u062a\u06cc \u0628\u0627 \u0645\u062d\u062a\u0648\u0627\u06cc \u0632\u06cc\u0627\u062f \u0631\u0648\u06cc \u062f\u0631 \u0635\u0641\u062d\u0627\u062a \u0648\u0628 \u0622\u0646\u060c \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0641\u0631\u0627\u0646\u062a \u0627\u0646\u062f \u0645\u0639\u0645\u0648\u0644 \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u0639\u0645\u0644\u06a9\u0631\u062f \u0627\u0633\u06a9\u0631\u0648\u0644 \u0628\u0647 \u0628\u0627\u0644\u0627 \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u0646\u062f \u062a\u0627 \u06a9\u0627\u0631\u0647\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0644\u0630\u062a \u0628\u062e\u0634 \u062a\u0631 \u0648 \u0631\u0627\u062d\u062a \u062a\u0631 \u0634\u0648\u062f. \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":14628,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[3292,3427,1964,1840,1904,3311,1776,1811,1786,3419,3417,1779,2884,3413,3423,1814,1841,3410,1807,3412,3420,2428,3411,3321,3355,1881,1103,3425,2750,1894,2666,1882,1803,3424,2667,3415,1805,3414,2342,2264,3225,2145,3180,3416,3426,3270,2122,1815,3421,2425,1795,3422,2823,3359,3418,1790,1966,2250,1818,2829,1813],"class_list":["post-14627","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming","tag-vue","tag-3427","tag----frontend","tag-1840","tag-1904","tag-3311","tag-1776","tag-1811","tag-1786","tag-3419","tag-3417","tag-1779","tag-2884","tag-3413","tag-3423","tag-1814","tag-1841","tag-3410","tag-1807","tag-3412","tag-3420","tag-2428","tag-3411","tag-3321","tag-3355","tag-1881","tag-1103","tag-3425","tag-2750","tag-1894","tag-2666","tag-1882","tag-1803","tag-3424","tag-2667","tag-3415","tag-1805","tag-3414","tag-2342","tag-2264","tag-3225","tag-2145","tag-3180","tag-3416","tag-3426","tag-3270","tag-2122","tag-1815","tag-3421","tag-2425","tag-1795","tag-3422","tag-2823","tag-3359","tag-3418","tag-1790","tag--javascrip","tag--nodejs","tag-1818","tag-2829","tag-1813"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/14627","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=14627"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/14627\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/14628"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=14627"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=14627"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=14627"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}