{"id":15977,"date":"2024-01-19T09:28:09","date_gmt":"2024-01-19T05:58:09","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/"},"modified":"2024-01-19T09:28:09","modified_gmt":"2024-01-19T05:58:09","slug":"%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/","title":{"rendered":"\u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062a\u0646\u0628\u0644 \u0628\u0627 \u0631\u0648\u062a\u0631 Vue \u0628\u0627 \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0628\u0647\u200c\u0637\u0648\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636\u060c \u0647\u0646\u06af\u0627\u0645 \u0646\u0648\u0634\u062a\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062a\u06a9 \u0635\u0641\u062d\u0647\u200c\u0627\u06cc Vue.js (SPA)\u060c \u0647\u0645\u0647 \u062f\u0627\u0631\u0627\u06cc\u06cc\u200c\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0645\u0627\u0646\u0646\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSS \u0628\u0627 \u0647\u0645 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u06cc\u200c\u0634\u0648\u0646\u062f. page \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0627 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062d\u062c\u06cc\u0645 \u0633\u0631\u0648\u06a9\u0627\u0631 \u062f\u0627\u0631\u06cc\u062f\u060c \u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0645\u0646\u062c\u0631 \u0628\u0647 \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0646\u0627\u0645\u0637\u0644\u0648\u0628 \u0634\u0648\u062f.  \u0628\u0647 \u06a9\u0645\u06a9 Webpack \u0627\u0645\u06a9\u0627\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc&#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\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c\" >\u0645\u0639\u0631\u0641\u06cc<\/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\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/#%da%86%d8%b1%d8%a7_%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d8%b1%d9%88%db%8c_%d8%aa%d9%82%d8%a7%d8%b6%d8%a7%d8%9f\" >\u0686\u0631\u0627 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0631\u0648\u06cc \u062a\u0642\u0627\u0636\u0627\u061f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/#%d8%a2%d9%85%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d9%be%d8%b1%d9%88%da%98%d9%87\" >\u0622\u0645\u0627\u062f\u0647 \u0633\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-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/#%d8%a7%d8%b6%d8%a7%d9%81%d9%87_%da%a9%d8%b1%d8%af%d9%86_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7_%d9%88_%d8%b5%d9%81%d8%ad%d8%a7%d8%aa\" >\u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0645\u0633\u06cc\u0631\u0647\u0627 \u0648 \u0635\u0641\u062d\u0627\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/#%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d9%86%d9%88%d8%a7%d8%b1_%d9%be%db%8c%d8%b4%d8%b1%d9%81%d8%aa\" >\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a<\/a><\/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\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/#%d9%86%d9%88%d8%a7%d8%b1_%d9%be%db%8c%d8%b4%d8%b1%d9%81%d8%aa_%d9%85%d8%a7%d8%b4%d9%87_%d8%a8%d8%b1%d8%a7%db%8c_%d8%b5%d9%81%d8%ad%d8%a7%d8%aa_%d9%84%d9%88%d8%af_%d8%b4%d8%af%d9%87_%d8%a8%d8%a7_%d8%aa%d9%86%d8%a8%d9%84%db%8c\" >\u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0645\u0627\u0634\u0647 \u0628\u0631\u0627\u06cc \u0635\u0641\u062d\u0627\u062a \u0644\u0648\u062f \u0634\u062f\u0647 \u0628\u0627 \u062a\u0646\u0628\u0644\u06cc<\/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\/%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c-%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c-%d8%aa%d9%86%d8%a8%d9%84-%d8%a8%d8%a7-%d8%b1%d9%88%d8%aa%d8%b1-vue-%d8%a8%d8%a7-%d9%86%d9%88%d8%a7%d8%b1\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\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\"> 5<\/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<h2 id=\"introduction\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c\"><\/span>\u0645\u0639\u0631\u0641\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636\u060c \u0647\u0646\u06af\u0627\u0645 \u0646\u0648\u0634\u062a\u0646 \u06cc\u06a9 Vue.js Single Page Application (SPA)\u060c \u0647\u0645\u0647 \u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0645\u0627\u0646\u0646\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSS \u0628\u0627 \u0647\u0645 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f. page \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0627 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062d\u062c\u06cc\u0645 \u0633\u0631\u0648\u06a9\u0627\u0631 \u062f\u0627\u0631\u06cc\u062f\u060c \u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0645\u0646\u062c\u0631 \u0628\u0647 \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0646\u0627\u0645\u0637\u0644\u0648\u0628 \u0634\u0648\u062f.<\/p>\n<p>\u0628\u0627 \u06a9\u0645\u06a9 <em>\u0628\u0633\u062a\u0647 \u0648\u0628<\/em>\u060c \u0627\u0645\u06a9\u0627\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0635\u0641\u062d\u0627\u062a \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u0631\u0648\u06cc \u062a\u0642\u0627\u0636\u0627 \u062f\u0631 Vue.js \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>import()<\/code> <em>\u062a\u0627\u0628\u0639<\/em> \u0628\u0647 \u062c\u0627\u06cc <code>import<\/code> <em>\u06a9\u0644\u0645\u0647 \u06a9\u0644\u06cc\u062f\u06cc<\/em>.<\/p>\n<h2 id=\"whyloadondemand\"><span class=\"ez-toc-section\" id=\"%da%86%d8%b1%d8%a7_%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d8%b1%d9%88%db%8c_%d8%aa%d9%82%d8%a7%d8%b6%d8%a7%d8%9f\"><\/span>\u0686\u0631\u0627 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0631\u0648\u06cc \u062a\u0642\u0627\u0636\u0627\u061f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u06cc\u06a9 SPA \u0645\u0639\u0645\u0648\u0644\u06cc \u062f\u0631 Vue.js \u0628\u0627 \u062f\u0627\u0634\u062a\u0646 \u062a\u0645\u0627\u0645 \u0642\u0627\u0628\u0644\u06cc\u062a\u200c\u0647\u0627 \u0648 \u062f\u0627\u0631\u0627\u06cc\u06cc\u200c\u0647\u0627 \u0628\u0627 \u0647\u0645 \u0628\u0633\u062a\u0647\u200c\u0628\u0646\u062f\u06cc \u0648 \u062a\u062d\u0648\u06cc\u0644 \u062f\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f \u062a\u0627 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u062f \u0628\u062f\u0648\u0646 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0628\u0627\u0632\u062e\u0648\u0627\u0646\u06cc \u0635\u0641\u062d\u0627\u062a \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f.  \u0627\u06af\u0631 \u0628\u0647 \u0635\u0631\u0627\u062d\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0635\u0641\u062d\u0627\u062a \u0637\u0631\u0627\u062d\u06cc \u0646\u06a9\u0631\u062f\u0647 \u0627\u06cc\u062f \u0631\u0648\u06cc \u0647\u0645\u0647 \u0635\u0641\u062d\u0627\u062a \u0628\u0647 \u06cc\u06a9\u0628\u0627\u0631\u0647 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f \u06cc\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u0647\u0646\u0627\u06cc \u0628\u0627\u0646\u062f \u063a\u06cc\u0631 \u0636\u0631\u0648\u0631\u06cc \u0648 \u06a9\u0627\u0647\u0634 \u0633\u0631\u0639\u062a \u0627\u0632 \u0642\u0628\u0644 \u0648\u0627\u06a9\u0634\u06cc\/\u0627\u0632 \u067e\u06cc\u0634 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f. page \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc.<\/p>\n<p>\u0627\u06cc\u0646 \u0627\u0645\u0631 \u0628\u0647 \u0648\u06cc\u0698\u0647 \u0628\u0631\u0627\u06cc SPA\u0647\u0627\u06cc \u0628\u0632\u0631\u06af \u0628\u0627 \u0635\u0641\u062d\u0627\u062a \u0632\u06cc\u0627\u062f \u0628\u062f \u0627\u0633\u062a.  \u0627\u0641\u0631\u0627\u062f\u06cc \u06a9\u0647 \u0627\u062a\u0635\u0627\u0644 \u0627\u06cc\u0646\u062a\u0631\u0646\u062a \u0622\u0647\u0633\u062a\u0647 \u062f\u0627\u0631\u0646\u062f \u06cc\u0627 \u062f\u0633\u062a\u06af\u0627\u0647\u200c\u0647\u0627\u06cc \u0627\u0631\u0632\u0627\u0646 \u0642\u06cc\u0645\u062a\u06cc \u0645\u0627\u0646\u0646\u062f \u062a\u0644\u0641\u0646 \u0647\u0645\u0631\u0627\u0647 \u062f\u0627\u0631\u0646\u062f\u060c \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u062f\u06cc \u062e\u0648\u0627\u0647\u0646\u062f \u062f\u0627\u0634\u062a.  \u0628\u0627 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0631\u0648\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0647\u0631\u06af\u0632 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u062f\u0627\u0646\u0644\u0648\u062f \u0628\u06cc\u0634\u062a\u0631 \u0627\u0632 \u0646\u06cc\u0627\u0632 \u062e\u0648\u062f \u0646\u062f\u0627\u0631\u0646\u062f.<\/p>\n<p>Vue.js \u0628\u0627 \u0647\u06cc\u0686 \u0646\u0634\u0627\u0646\u06af\u0631 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0628\u0631\u0627\u06cc \u0645\u0627\u0698\u0648\u0644 \u0647\u0627\u06cc \u067e\u0648\u06cc\u0627 \u0647\u0645\u0631\u0627\u0647 \u0646\u06cc\u0633\u062a.  \u062d\u062a\u06cc \u0628\u0627 \u0648\u0627\u06a9\u0634\u06cc \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0627\u0648\u0644\u06cc\u0647 &#8211; \u0647\u06cc\u0686 \u0646\u0634\u0627\u0646\u06af\u0631 \u0628\u0635\u0631\u06cc \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u062c\u0627\u0632\u0647 \u0646\u0645\u06cc\u200c\u062f\u0647\u062f \u062a\u0627 \u0628\u062f\u0627\u0646\u0646\u062f \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0686\u06af\u0648\u0646\u0647 \u067e\u06cc\u0634 \u0645\u06cc\u200c\u0631\u0648\u062f.  \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u06cc\u06a9 \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0628\u0631\u0627\u06cc \u0628\u0647\u0628\u0648\u062f \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0636\u0627\u0641\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<h2 id=\"preparingtheproject\"><span class=\"ez-toc-section\" id=\"%d8%a2%d9%85%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d9%be%d8%b1%d9%88%da%98%d9%87\"><\/span>\u0622\u0645\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u067e\u0631\u0648\u0698\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0628\u062a\u062f\u0627 \u0628\u0647 \u0631\u0627\u0647\u06cc \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645 \u062a\u0627 \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0645\u0627 \u0628\u0627 \u0631\u0648\u062a\u0631 Vue \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u0631\u0642\u0631\u0627\u0631 \u06a9\u0646\u062f.  \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0645\u0627 \u0627\u0632 <em>\u0627\u0644\u06af\u0648\u06cc \u0627\u062a\u0648\u0628\u0648\u0633 \u0631\u0648\u06cc\u062f\u0627\u062f<\/em>.<\/p>\n<p>Event Bus \u0627\u0633\u0627\u0633\u0627\u064b \u06cc\u06a9 \u0646\u0645\u0648\u0646\u0647 Vue \u062a\u06a9\u200c\u062a\u0646\u0647 \u0627\u0633\u062a.  \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u062a\u0645\u0627\u0645 \u0646\u0645\u0648\u0646\u0647 \u0647\u0627\u06cc Vue \u062f\u0627\u0631\u0627\u06cc \u06cc\u06a9 \u0633\u06cc\u0633\u062a\u0645 \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>$\u0631\u0648\u06cc<\/code> \u0648 <code>$emit<\/code>\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0642\u0627\u0644 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u062f\u0631 \u0647\u0631 \u0646\u0642\u0637\u0647 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645\u060c <code>eventHub.js<\/code> \u062f\u0631 <code>components<\/code> \u0641\u0647\u0631\u0633\u062a \u0631\u0627\u0647\u0646\u0645\u0627:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> Vue <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> <span class=\"hljs-keyword\">new<\/span> Vue()\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646\u060c Webpack \u0631\u0627 \u0628\u0631\u0627\u06cc \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0648\u0627\u06a9\u0634\u06cc \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0627\u0648\u0644\u06cc\u0647 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645.  \u0645\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0628\u0647\u200c\u0635\u0648\u0631\u062a \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u0628\u0631\u0627\u06cc \u0647\u0631 \u062a\u0627\u0628\u0639 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645 \u06cc\u0627 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0633\u0631\u0627\u0633\u0631\u06cc \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u0645.  \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 <code>vue.config.js<\/code> \u0641\u0627\u06cc\u0644 \u062f\u0631 root \u067e\u0648\u0634\u0647 \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u062f \u0648 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0648\u0627\u06a9\u0634\u06cc \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-built_in\">module<\/span>.exports = {\n    <span class=\"hljs-attr\">chainWebpack<\/span>: <span class=\"hljs-function\">(<span class=\"hljs-params\">config<\/span>) =&gt;<\/span> {\n        <span class=\"hljs-comment\">\/\/ Disable prefetching and preloading<\/span>\n        config.plugins.delete(<span class=\"hljs-string\">'prefetch'<\/span>)\n        config.plugins.delete(<span class=\"hljs-string\">'preload'<\/span>)\n    },\n}\n<\/code><\/pre>\n<h2 id=\"addingroutesandpages\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b6%d8%a7%d9%81%d9%87_%da%a9%d8%b1%d8%af%d9%86_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7_%d9%88_%d8%b5%d9%81%d8%ad%d8%a7%d8%aa\"><\/span>\u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0645\u0633\u06cc\u0631\u0647\u0627 \u0648 \u0635\u0641\u062d\u0627\u062a<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u0627 \u0627\u0632 Vue Router \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0645\u0646\u0638\u0648\u0631\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <code>npx<\/code> \u0628\u0631\u0627\u06cc \u0646\u0635\u0628 \u0622\u0646:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npx vue add router<\/span>\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0641\u0627\u06cc\u0644 \u0631\u0648\u062a\u0631 \u062e\u0648\u062f \u0631\u0627 \u06a9\u0647 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u062f\u0631 \u0632\u06cc\u0631 \u0642\u0631\u0627\u0631 \u062f\u0627\u0631\u062f \u0648\u06cc\u0631\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u0645 <code>router\/index.js<\/code> \u0648 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u0627 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u06cc\u0645 <code>import()<\/code> \u062a\u0627\u0628\u0639\u060c \u0628\u0647 \u062c\u0627\u06cc <code>import<\/code> \u0628\u06cc\u0627\u0646\u06cc\u0647:<\/p>\n<p>\u0627\u06cc\u0646 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> About <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'..\/views\/About.vue'<\/span>\n{\n    <span class=\"hljs-attr\">path<\/span>: <span class=\"hljs-string\">'\/about'<\/span>,\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'About'<\/span>,\n    <span class=\"hljs-attr\">component<\/span>: About\n},\n<\/code><\/pre>\n<p>\u0645\u0627 \u0622\u0646 \u0631\u0627 \u0628\u0647:<\/p>\n<pre><code class=\"hljs\">{\n    <span class=\"hljs-attr\">path<\/span>: <span class=\"hljs-string\">'\/about'<\/span>,\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'About'<\/span>,\n    <span class=\"hljs-attr\">component<\/span>: <span class=\"hljs-function\">() =&gt;<\/span> <span class=\"hljs-keyword\">import<\/span>(<span class=\"hljs-string\">'..\/views\/About.vue'<\/span>)\n},\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u062a\u0631\u062c\u06cc\u062d \u0645\u06cc \u062f\u0647\u06cc\u062f \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f \u06a9\u062f\u0627\u0645 \u0635\u0641\u062d\u0627\u062a \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0634\u0648\u0646\u062f \u0631\u0648\u06cc \u062a\u0642\u0627\u0636\u0627 \u0628\u0647 \u062c\u0627\u06cc \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0648\u0627\u06a9\u0634\u06cc \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0627\u0648\u0644\u06cc\u0647 \u062f\u0631 \u0633\u0637\u062d \u062c\u0647\u0627\u0646\u06cc\u060c \u0627\u0632 \u0646\u0638\u0631\u0627\u062a \u0648\u06cc\u0698\u0647 Webpack \u0628\u0647 \u062c\u0627\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc Webpack \u062f\u0631 <code>vue.config.js<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span>(\n    <span class=\"hljs-comment\">\/* webpackPrefetch: true *\/<\/span>\n    <span class=\"hljs-comment\">\/* webpackPreload: true *\/<\/span>\n    <span class=\"hljs-string\">'..\/views\/About.vue'<\/span>\n)\n<\/code><\/pre>\n<p>\u062a\u0641\u0627\u0648\u062a \u0627\u0635\u0644\u06cc \u0628\u06cc\u0646 <code>import()<\/code> \u0648 <code>import<\/code> \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627\u0698\u0648\u0644 \u0647\u0627\u06cc ES \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f <code>import()<\/code> \u062f\u0631 \u0632\u0645\u0627\u0646 \u0627\u062c\u0631\u0627 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0622\u0646\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0628\u0627 \u0622\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f <code>import<\/code> \u062f\u0631 \u0637\u0648\u0644 \u0632\u0645\u0627\u0646 \u06a9\u0627\u0645\u067e\u0627\u06cc\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f.  \u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u0627\u0698\u0648\u0644 \u0647\u0627 \u0631\u0627 \u0628\u0627 \u0622\u0646 \u0628\u0647 \u062a\u0639\u0648\u06cc\u0642 \u0628\u06cc\u0627\u0646\u062f\u0627\u0632\u06cc\u0645 <code>import()<\/code> \u0648 \u0641\u0642\u0637 \u062f\u0631 \u0635\u0648\u0631\u062a \u0644\u0632\u0648\u0645 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<h2 id=\"implementingtheprogressbar\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d9%86%d9%88%d8%a7%d8%b1_%d9%be%db%8c%d8%b4%d8%b1%d9%81%d8%aa\"><\/span>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u062a\u062e\u0645\u06cc\u0646 \u062f\u0642\u06cc\u0642 \u0632\u0645\u0627\u0646\u06cc \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f page \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062e\u0648\u0627\u0647\u062f \u0634\u062f (\u06cc\u0627 \u0627\u06af\u0631 \u0627\u0635\u0644\u0627\u064b \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0634\u0648\u062f)\u060c \u0646\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 <em>\u0648\u0627\u0642\u0639\u0627<\/em> \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f  \u0647\u06cc\u0686 \u0631\u0627\u0647\u06cc \u0628\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0686\u0642\u062f\u0631 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f page \u06cc\u0627 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u06a9\u0631\u062f\u0647 \u0627\u0633\u062a.  \u0645\u0627 \u0686\u06cc <em>\u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u062f<\/em> \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0627\u0633\u062a \u06a9\u0647 \u0648\u0642\u062a\u06cc \u062a\u0645\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f page \u0628\u0627\u0631\u0647\u0627<\/p>\n<p>\u0647\u0645\u0647 \u0686\u06cc\u0632 \u062f\u0631 \u0627\u06cc\u0646 \u0628\u06cc\u0646 \u0648\u0627\u0642\u0639\u0627\u064b \u067e\u06cc\u0634\u0631\u0641\u062a \u0631\u0627 \u0645\u0646\u0639\u06a9\u0633 \u0646\u0645\u06cc \u06a9\u0646\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u062f\u0631 \u0628\u06cc\u0634\u062a\u0631 \u0645\u0648\u0627\u0631\u062f\u060c \u067e\u06cc\u0634\u0631\u0641\u062a \u062a\u0635\u0648\u06cc\u0631 \u0634\u062f\u0647 \u0641\u0642\u0637 \u062c\u0647\u0634 \u0647\u0627\u06cc \u062a\u0635\u0627\u062f\u0641\u06cc \u0627\u0633\u062a.<\/p>\n<p>\u0646\u0635\u0628 \u06a9\u0646\u06cc\u0645 <code>lodash.random<\/code> \u0627\u0648\u0644\u060c \u0632\u06cc\u0631\u0627 \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0628\u0633\u062a\u0647 \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u062e\u0627\u0628 \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0639\u062f\u0627\u062f \u062a\u0635\u0627\u062f\u0641\u06cc \u062f\u0631 \u0637\u0648\u0644 \u062a\u0648\u0644\u06cc\u062f \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f:<\/p>\n<pre><code class=\"hljs\">$ npm i lodash.random\n<\/code><\/pre>\n<p>\u0633\u067e\u0633\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u062c\u0632\u0621 Vue \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 &#8211; <code>components\/ProgressBar.vue<\/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\">div<\/span> <span class=\"hljs-attr\">:class<\/span>=<span class=\"hljs-string\">\"{'loading-container': true, loading: isLoading, visible: isVisible}\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"loader\"<\/span> <span class=\"hljs-attr\">:style<\/span>=<span class=\"hljs-string\">\"{ width: progress + '%' }\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"light\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"glow\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646\u060c \u0628\u0647 \u0622\u0646 \u062c\u0632\u0621\u060c \u06cc\u06a9 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645.  \u062f\u0631 \u062f\u0627\u062e\u0644 \u0622\u0646 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c \u0645\u0627 \u0627\u0628\u062a\u062f\u0627 import <code>random<\/code>  \u0648 <code>$eventHub<\/code>\u060c \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">import<\/span> random <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'lodash.random'<\/span>\n<span class=\"hljs-keyword\">import<\/span> $eventHub <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'..\/components\/eventHub'<\/span>\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646\u060c \u067e\u0633 \u0627\u0632 \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646\u060c \u062f\u0631 \u0647\u0645\u0627\u0646 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0686\u0646\u062f \u0645\u062a\u063a\u06cc\u0631 \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ Assume that loading will complete under this amount of time.<\/span>\n<span class=\"hljs-keyword\">const<\/span> defaultDuration = <span class=\"hljs-number\">8000<\/span> \n<span class=\"hljs-comment\">\/\/ How frequently to update<\/span>\n<span class=\"hljs-keyword\">const<\/span> defaultInterval = <span class=\"hljs-number\">1000<\/span> \n<span class=\"hljs-comment\">\/\/ 0 - 1. Add some variation to how much the bar will grow at each interval<\/span>\n<span class=\"hljs-keyword\">const<\/span> variation = <span class=\"hljs-number\">0.5<\/span> \n<span class=\"hljs-comment\">\/\/ 0 - 100. Where the progress bar should start from.<\/span>\n<span class=\"hljs-keyword\">const<\/span> startingPoint = <span class=\"hljs-number\">0<\/span> \n<span class=\"hljs-comment\">\/\/ Limiting how far the progress bar will get to before loading is complete<\/span>\n<span class=\"hljs-keyword\">const<\/span> endingPoint = <span class=\"hljs-number\">90<\/span> \n<\/code><\/pre>\n<p>\u0628\u0627 \u0648\u062c\u0648\u062f \u0622\u0646\u200c\u0647\u0627\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0645\u0646\u0637\u0642 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0646\u0627\u0647\u0645\u0632\u0645\u0627\u0646 \u0627\u062c\u0632\u0627 \u0631\u0627 \u0628\u0646\u0648\u06cc\u0633\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'ProgressBar'<\/span>,\n    \n    <span class=\"hljs-attr\">data<\/span>: <span class=\"hljs-function\">() =&gt;<\/span> ({\n        <span class=\"hljs-attr\">isLoading<\/span>: <span class=\"hljs-literal\">true<\/span>, <span class=\"hljs-comment\">\/\/ Once loading is done, start fading away<\/span>\n        <span class=\"hljs-attr\">isVisible<\/span>: <span class=\"hljs-literal\">false<\/span>, <span class=\"hljs-comment\">\/\/ Once animate finish, set display: none<\/span>\n        <span class=\"hljs-attr\">progress<\/span>: startingPoint,\n        <span class=\"hljs-attr\">timeoutId<\/span>: <span class=\"hljs-literal\">undefined<\/span>,\n    }),\n\n    <span class=\"hljs-function\"><span class=\"hljs-title\">mounted<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n        $eventHub.$\u0631\u0648\u06cc(<span class=\"hljs-string\">'asyncComponentLoading'<\/span>, <span class=\"hljs-built_in\">this<\/span>.start)\n        $eventHub.$\u0631\u0648\u06cc(<span class=\"hljs-string\">'asyncComponentLoaded'<\/span>, <span class=\"hljs-built_in\">this<\/span>.stop)\n    },\n\n    <span class=\"hljs-attr\">methods<\/span>: {\n        <span class=\"hljs-function\"><span class=\"hljs-title\">start<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n            <span class=\"hljs-built_in\">this<\/span>.isLoading = <span class=\"hljs-literal\">true<\/span>\n            <span class=\"hljs-built_in\">this<\/span>.isVisible = <span class=\"hljs-literal\">true<\/span>\n            <span class=\"hljs-built_in\">this<\/span>.progress = startingPoint\n            <span class=\"hljs-built_in\">this<\/span>.loop()\n        },\n\n        <span class=\"hljs-function\"><span class=\"hljs-title\">loop<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n            <span class=\"hljs-keyword\">if<\/span> (<span class=\"hljs-built_in\">this<\/span>.timeoutId) {\n                <span class=\"hljs-built_in\">clearTimeout<\/span>(<span class=\"hljs-built_in\">this<\/span>.timeoutId)\n            }\n            <span class=\"hljs-keyword\">if<\/span> (<span class=\"hljs-built_in\">this<\/span>.progress &gt;= endingPoint) {\n                <span class=\"hljs-keyword\">return<\/span>\n            }\n            <span class=\"hljs-keyword\">const<\/span> size = (endingPoint - startingPoint) \/ (defaultDuration \/ defaultInterval)\n            <span class=\"hljs-keyword\">const<\/span> p = <span class=\"hljs-built_in\">Math<\/span>.round(<span class=\"hljs-built_in\">this<\/span>.progress + random(size * (<span class=\"hljs-number\">1<\/span> - variation), size * (<span class=\"hljs-number\">1<\/span> + variation)))\n            <span class=\"hljs-built_in\">this<\/span>.progress = <span class=\"hljs-built_in\">Math<\/span>.min(p, endingPoint)\n            <span class=\"hljs-built_in\">this<\/span>.timeoutId = <span class=\"hljs-built_in\">setTimeout<\/span>(\n                <span class=\"hljs-built_in\">this<\/span>.loop,\n                random(defaultInterval * (<span class=\"hljs-number\">1<\/span> - variation), defaultInterval * (<span class=\"hljs-number\">1<\/span> + variation))\n            )\n        },\n\n        <span class=\"hljs-function\"><span class=\"hljs-title\">stop<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n            <span class=\"hljs-built_in\">this<\/span>.isLoading = <span class=\"hljs-literal\">false<\/span>\n            <span class=\"hljs-built_in\">this<\/span>.progress = <span class=\"hljs-number\">100<\/span>\n            <span class=\"hljs-built_in\">clearTimeout<\/span>(<span class=\"hljs-built_in\">this<\/span>.timeoutId)\n            <span class=\"hljs-keyword\">const<\/span> self = <span class=\"hljs-built_in\">this<\/span>\n            <span class=\"hljs-built_in\">setTimeout<\/span>(<span class=\"hljs-function\">() =&gt;<\/span> {\n                <span class=\"hljs-keyword\">if<\/span> (!self.isLoading) {\n                    self.isVisible = <span class=\"hljs-literal\">false<\/span>\n                }\n            }, <span class=\"hljs-number\">200<\/span>)\n        },\n    },\n}\n<\/code><\/pre>\n<p>\u062f\u0631 <code>mounted()<\/code> \u062a\u0627\u0628\u0639\u060c \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u06cc\u062f \u06a9\u0647 \u0645\u0627 \u0627\u0632 \u06af\u0630\u0631\u06af\u0627\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0631\u0627\u06cc \u06af\u0648\u0634 \u062f\u0627\u062f\u0646 \u0628\u0647 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0646\u0627\u0647\u0645\u0632\u0645\u0627\u0646 \u0645\u0624\u0644\u0641\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645.  \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0631\u0648\u062a\u0631 \u0628\u0647 \u0645\u0627 \u0628\u06af\u0648\u06cc\u062f \u06a9\u0647 \u0628\u0647 a \u067e\u06cc\u0645\u0627\u06cc\u0634 \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u0645\u060c \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0631\u0627 \u0634\u0631\u0648\u0639 \u0645\u06cc\u200c\u06a9\u0646\u062f page \u06a9\u0647 \u0647\u0646\u0648\u0632 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0646\u0634\u062f\u0647 \u0627\u0633\u062a<\/p>\n<p>\u0648 \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u06a9\u0645\u06cc \u0633\u0628\u06a9 \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><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\">.loading-container<\/span> {\n    <span class=\"hljs-attribute\">font-size<\/span>: <span class=\"hljs-number\">0<\/span>; <span class=\"hljs-comment\">\/* remove space *\/<\/span>\n    <span class=\"hljs-attribute\">position<\/span>: fixed;\n    <span class=\"hljs-attribute\">top<\/span>: <span class=\"hljs-number\">0<\/span>;\n    <span class=\"hljs-attribute\">left<\/span>: <span class=\"hljs-number\">0<\/span>;\n    <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">5px<\/span>;\n    <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">100%<\/span>;\n    <span class=\"hljs-attribute\">opacity<\/span>: <span class=\"hljs-number\">0<\/span>;\n    <span class=\"hljs-attribute\">display<\/span>: none;\n    <span class=\"hljs-attribute\">z-index<\/span>: <span class=\"hljs-number\">100<\/span>;\n    <span class=\"hljs-attribute\">transition<\/span>: opacity <span class=\"hljs-number\">200<\/span>;\n}\n\n<span class=\"hljs-selector-class\">.loading-container<\/span><span class=\"hljs-selector-class\">.visible<\/span> {\n    <span class=\"hljs-attribute\">display<\/span>: block;\n}\n<span class=\"hljs-selector-class\">.loading-container<\/span><span class=\"hljs-selector-class\">.loading<\/span> {\n    <span class=\"hljs-attribute\">opacity<\/span>: <span class=\"hljs-number\">1<\/span>;\n}\n\n<span class=\"hljs-selector-class\">.loader<\/span> {\n    <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-number\">#23d6d6<\/span>;\n    <span class=\"hljs-attribute\">display<\/span>: inline-block;\n    <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">100%<\/span>;\n    <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">50%<\/span>;\n    <span class=\"hljs-attribute\">overflow<\/span>: hidden;\n    <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">0<\/span> <span class=\"hljs-number\">0<\/span> <span class=\"hljs-number\">5px<\/span> <span class=\"hljs-number\">0<\/span>;\n    <span class=\"hljs-attribute\">transition<\/span>: <span class=\"hljs-number\">200<\/span> width ease-out;\n}\n\n<span class=\"hljs-selector-class\">.loader<\/span> &gt; <span class=\"hljs-selector-class\">.light<\/span> {\n    <span class=\"hljs-attribute\">float<\/span>: right;\n    <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">100%<\/span>;\n    <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">20%<\/span>;\n    <span class=\"hljs-attribute\">background-image<\/span>: <span class=\"hljs-built_in\">linear-gradient<\/span>(to right, <span class=\"hljs-number\">#23d6d6<\/span>, <span class=\"hljs-number\">#29ffff<\/span>, <span class=\"hljs-number\">#23d6d6<\/span>);\n    <span class=\"hljs-attribute\">animation<\/span>: loading-animation <span class=\"hljs-number\">2s<\/span> ease-in infinite;\n}\n\n<span class=\"hljs-selector-class\">.glow<\/span> {\n    <span class=\"hljs-attribute\">display<\/span>: inline-block;\n    <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">100%<\/span>;\n    <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">30px<\/span>;\n    <span class=\"hljs-attribute\">margin-left<\/span>: -<span class=\"hljs-number\">30px<\/span>;\n    <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">0<\/span> <span class=\"hljs-number\">0<\/span> <span class=\"hljs-number\">5px<\/span> <span class=\"hljs-number\">0<\/span>;\n    <span class=\"hljs-attribute\">box-shadow<\/span>: <span class=\"hljs-number\">0<\/span> <span class=\"hljs-number\">0<\/span> <span class=\"hljs-number\">10px<\/span> <span class=\"hljs-number\">#23d6d6<\/span>;\n}\n\n<span class=\"hljs-keyword\">@keyframes<\/span> loading-animation {\n    <span class=\"hljs-number\">0%<\/span> {\n        <span class=\"hljs-attribute\">margin-right<\/span>: <span class=\"hljs-number\">100%<\/span>;\n    }\n    <span class=\"hljs-number\">50%<\/span> {\n        <span class=\"hljs-attribute\">margin-right<\/span>: <span class=\"hljs-number\">100%<\/span>;\n    }\n    <span class=\"hljs-number\">100%<\/span> {\n        <span class=\"hljs-attribute\">margin-right<\/span>: -<span class=\"hljs-number\">10%<\/span>;\n    }\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">style<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0645\u0627 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <code>ProgressBar<\/code> \u0628\u0647 \u0645\u0627 <code>App.vue<\/code> \u06cc\u0627 \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 layout \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u062f\u0631 \u0647\u0645\u0627\u0646 \u0645\u0624\u0644\u0641\u0647 \u0646\u0645\u0627\u06cc \u0631\u0648\u062a\u0631 \u0628\u0627\u0634\u062f.  \u0645\u0627 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0631 \u0637\u0648\u0644 \u0686\u0631\u062e\u0647 \u0639\u0645\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \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\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">progress-bar<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">progress-bar<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">router-view<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">router-view<\/span>&gt;<\/span>\n        <span class=\"hljs-comment\">&lt;!--- your other components --&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/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> ProgressBar <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'.\/components\/ProgressBar.vue'<\/span>\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n       <span class=\"hljs-attr\">components<\/span>: { ProgressBar },\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0647\u0645\u0647 \u0627\u06cc\u0646\u0647\u0627 \u0645\u0646\u062c\u0631 \u0628\u0647 \u06cc\u06a9 \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0634\u06cc\u06a9 \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/lazy-loading-vue-js-pages-1.png\" alt=\"\u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a\" title=\"\"><\/p>\n<h2 id=\"triggerprogressbarforlazyloadedpages\"><span class=\"ez-toc-section\" id=\"%d9%86%d9%88%d8%a7%d8%b1_%d9%be%db%8c%d8%b4%d8%b1%d9%81%d8%aa_%d9%85%d8%a7%d8%b4%d9%87_%d8%a8%d8%b1%d8%a7%db%8c_%d8%b5%d9%81%d8%ad%d8%a7%d8%aa_%d9%84%d9%88%d8%af_%d8%b4%d8%af%d9%87_%d8%a8%d8%a7_%d8%aa%d9%86%d8%a8%d9%84%db%8c\"><\/span>\u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0645\u0627\u0634\u0647 \u0628\u0631\u0627\u06cc \u0635\u0641\u062d\u0627\u062a \u0644\u0648\u062f \u0634\u062f\u0647 \u0628\u0627 \u062a\u0646\u0628\u0644\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u0627 <code>ProgressBar<\/code> \u062f\u0631 \u062d\u0627\u0644 \u06af\u0648\u0634 \u062f\u0627\u062f\u0646 \u0627\u0633\u062a \u0631\u0648\u06cc \u06af\u0630\u0631\u06af\u0627\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0631\u0627\u06cc \u0631\u0648\u06cc\u062f\u0627\u062f \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u0624\u0644\u0641\u0647 \u0646\u0627\u0647\u0645\u0632\u0645\u0627\u0646.  \u0648\u0642\u062a\u06cc \u0686\u06cc\u0632\u06cc \u0628\u0647 \u0627\u06cc\u0646 \u0634\u06a9\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc\u200c\u0634\u0648\u062f\u060c \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u0645 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0631\u0627 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u0645.  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0645\u062d\u0627\u0641\u0638 \u0645\u0633\u06cc\u0631 \u0628\u0647 \u0631\u0648\u062a\u0631 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0627\u06cc\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> $eventHub <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'..\/components\/eventHub'<\/span>\n\nrouter.beforeEach(<span class=\"hljs-function\">(<span class=\"hljs-params\">to, <span class=\"hljs-keyword\">from<\/span>, next<\/span>) =&gt;<\/span> {\n    <span class=\"hljs-keyword\">if<\/span> (<span class=\"hljs-keyword\">typeof<\/span> to.matched(<span class=\"hljs-number\">0<\/span>)?.components.default === <span class=\"hljs-string\">'function'<\/span>) {\n        $eventHub.$emit(<span class=\"hljs-string\">'asyncComponentLoading'<\/span>, to) <span class=\"hljs-comment\">\/\/ Start progress bar<\/span>\n    }\n    next()\n})\n\nrouter.beforeResolve(<span class=\"hljs-function\">(<span class=\"hljs-params\">to, <span class=\"hljs-keyword\">from<\/span>, next<\/span>) =&gt;<\/span> {\n    $eventHub.$emit(<span class=\"hljs-string\">'asyncComponentLoaded'<\/span>) <span class=\"hljs-comment\">\/\/ Stop progress bar<\/span>\n    next()\n})\n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u062a\u0634\u062e\u06cc\u0635 \u0627\u06cc\u0646\u06a9\u0647 \u0622\u06cc\u0627 page \u062a\u0646\u0628\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0628\u0627\u06cc\u062f \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0622\u06cc\u0627 \u0645\u0624\u0644\u0641\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u067e\u0648\u06cc\u0627 \u062a\u0639\u0631\u06cc\u0641 \u0634\u062f\u0647 \u0627\u0633\u062a \u06cc\u0627 \u062e\u06cc\u0631 import \u06cc\u0639\u0646\u06cc <code>component: () =&gt; import('...')<\/code> \u0628\u062c\u0627\u06cc<code>component: MyComponent<\/code>.<\/p>\n<p>\u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0628\u0627 <code>typeof to.matched(0)?.components.default === 'function'<\/code>.  \u0627\u062c\u0632\u0627\u06cc\u06cc \u06a9\u0647 \u0628\u0627 <code>import<\/code> \u0628\u06cc\u0627\u0646\u06cc\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062a\u0648\u0627\u0628\u0639 \u0637\u0628\u0642\u0647 \u0628\u0646\u062f\u06cc \u0646\u0645\u06cc \u0634\u0648\u062f.<\/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>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062a\u0646\u0628\u0644\u06cc \u0635\u0641\u062d\u0627\u062a \u062e\u0627\u0635 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645.  \u0645\u0627 \u0648\u0627\u06a9\u0634\u06cc \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0631\u0627 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 Vue \u062e\u0648\u062f \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 \u0648 \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0634\u0628\u06cc\u0647 \u0633\u0627\u0632\u06cc \u067e\u06cc\u0634\u0631\u0641\u062a \u0648\u0627\u0642\u0639\u06cc \u062f\u0631 \u0647\u0646\u06af\u0627\u0645 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f. page.<\/p>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-19 09:28:03<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;15977&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;\u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062a\u0646\u0628\u0644 \u0628\u0627 \u0631\u0648\u062a\u0631 Vue \u0628\u0627 \u0646\u0648\u0627\u0631 \u067e\u06cc\u0634\u0631\u0641\u062a \u0628\u0647\u200c\u0637\u0648\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636\u060c \u0647\u0646\u06af\u0627\u0645 \u0646\u0648\u0634\u062a\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062a\u06a9 \u0635\u0641\u062d\u0647\u200c\u0627\u06cc Vue.js (SPA)\u060c \u0647\u0645\u0647 \u062f\u0627\u0631\u0627\u06cc\u06cc\u200c\u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0645\u0627\u0646\u0646\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648 \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc CSS \u0628\u0627 \u0647\u0645 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u06cc\u200c\u0634\u0648\u0646\u062f. page \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0627 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062d\u062c\u06cc\u0645 \u0633\u0631\u0648\u06a9\u0627\u0631 \u062f\u0627\u0631\u06cc\u062f\u060c \u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0645\u0646\u062c\u0631 \u0628\u0647 \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0646\u0627\u0645\u0637\u0644\u0648\u0628 \u0634\u0648\u062f.  \u0628\u0647 \u06a9\u0645\u06a9 Webpack \u0627\u0645\u06a9\u0627\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc...&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\"> 5<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636\u060c \u0647\u0646\u06af\u0627\u0645 \u0646\u0648\u0634\u062a\u0646 \u06cc\u06a9 Vue.js Single Page Application (SPA)\u060c \u0647\u0645\u0647 \u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0645\u0627\u0646\u0646\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc CSS \u0628\u0627 \u0647\u0645 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f. page \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a. \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0627 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u062d\u062c\u06cc\u0645 \u0633\u0631\u0648\u06a9\u0627\u0631 \u062f\u0627\u0631\u06cc\u062f\u060c \u0627\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0645\u0646\u062c\u0631 \u0628\u0647 \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0646\u0627\u0645\u0637\u0644\u0648\u0628 \u0634\u0648\u062f. \u0628\u0627 \u06a9\u0645\u06a9 \u0628\u0633\u062a\u0647 \u0648\u0628\u060c \u0627\u0645\u06a9\u0627\u0646 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":15978,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[3292,2914,1843,2730,3562,3294,3368,1964,1844,1811,1781,2839,1967,1789,1779,2822,3597,1909,1841,1807,4336,4335,4337,3411,3561,3585,1791,1780,1103,4341,4339,1799,4334,2342,1798,2097,2264,4338,1901,4340,3654,2004,1795,3742,1979,3641,3336,1790,3959,4342,3718,2005,1785,3696,2648,1983,3844,1813],"class_list":["post-15977","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming","tag-vue","tag-css","tag-nodejs-hosting","tag-page","tag-spa","tag-vue-js","tag-webpack","tag----frontend","tag-1844","tag-1811","tag-1781","tag-2839","tag----nodejs","tag-1789","tag-1779","tag-2822","tag-3597","tag-1909","tag-1841","tag-1807","tag-4336","tag-4335","tag-4337","tag-3411","tag-3561","tag-3585","tag-1791","tag-1780","tag-1103","tag-4341","tag-4339","tag-1799","tag-4334","tag-2342","tag-1798","tag-2097","tag-2264","tag-4338","tag-1901","tag-4340","tag-3654","tag-2004","tag-1795","tag-3742","tag-1979","tag-3641","tag-3336","tag-1790","tag-3959","tag-4342","tag-3718","tag-2005","tag-1785","tag-3696","tag-2648","tag-1983","tag-3844","tag-1813"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15977","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=15977"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15977\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/15978"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=15977"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=15977"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=15977"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}