{"id":16566,"date":"2024-01-27T03:49:25","date_gmt":"2024-01-27T00:19:25","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/"},"modified":"2024-01-27T03:49:25","modified_gmt":"2024-01-27T00:19:25","slug":"%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/","title":{"rendered":"\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062a\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc \u0628\u0627 Vue.js \u0648 Flask: \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u06cc\u0627\u0644\u062a \u0628\u0627 Vuex. \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u0631\u0627\u06cc \u067e\u0633\u062a \u0633\u0648\u0645 \u0628\u0647 \u0645\u0646 \u067e\u06cc\u0648\u0633\u062a\u06cc\u062f \u0645\u062a\u0634\u06a9\u0631\u06cc\u0645 \u0631\u0648\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue.js \u0648 Flask \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u062a\u0645\u0627\u0645 \u067e\u0634\u062a\u0647.  \u0645\u0648\u0636\u0648\u0639 \u0627\u0635\u0644\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f \u0631\u0648\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vuex \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0648\u0636\u0639\u06cc\u062a \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627.  \u0628\u0631\u0627\u06cc \u0645\u0639\u0631\u0641\u06cc Vuex\u060c \u0631\u0648\u0634 \u0628\u0627\u0632\u0633\u0627\u0632\u06cc \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0647\u0627\u06cc Home \u0648 Survey \u0631\u0627 \u0627\u0632&#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%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/#%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa_%d8%af%d9%88%d9%84%d8%aa%db%8c_%d8%a8%d8%a7_vuex\" >\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0648\u0644\u062a\u06cc \u0628\u0627 Vuex<\/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%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/#%d9%85%d8%ad%d8%aa%d9%88%d8%a7%db%8c_%d8%b3%d8%b1%db%8c\" >\u0645\u062d\u062a\u0648\u0627\u06cc \u0633\u0631\u06cc<\/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\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c_%da%a9%d8%b1%d8%af%d9%86_vuex\" >\u0645\u0639\u0631\u0641\u06cc \u06a9\u0631\u062f\u0646 Vuex<\/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\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/#%d8%a7%d9%86%d8%aa%d9%82%d8%a7%d9%84_%d9%85%d9%88%d9%84%d9%81%d9%87_%d8%ae%d8%a7%d9%86%d9%87_%d8%a8%d9%87_vuex\" >\u0627\u0646\u062a\u0642\u0627\u0644 \u0645\u0648\u0644\u0641\u0647 \u062e\u0627\u0646\u0647 \u0628\u0647 Vuex<\/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\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/#%d9%85%d9%87%d8%a7%d8%ac%d8%b1%d8%aa_%d9%85%d8%a4%d9%84%d9%81%d9%87_%d9%86%d8%b8%d8%b1%d8%b3%d9%86%d8%ac%db%8c\" >\u0645\u0647\u0627\u062c\u0631\u062a \u0645\u0624\u0644\u0641\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc<\/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\/%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/#%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86_%d9%82%d8%a7%d8%a8%d9%84%db%8c%d8%aa_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%86%d8%b8%d8%b1%d8%b3%d9%86%d8%ac%db%8c_%d8%ac%d8%af%db%8c%d8%af\" >\u0627\u0641\u0632\u0648\u062f\u0646 \u0642\u0627\u0628\u0644\u06cc\u062a \u0627\u06cc\u062c\u0627\u062f \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f<\/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%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/#%d9%85%d9%86%d8%a7%d8%a8%d8%b9\" >\u0645\u0646\u0627\u0628\u0639<\/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%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-%d9%87%d8%a7%db%8c-%d8%aa%da%a9-%d8%b5%d9%81%d8%ad%d9%87-%d8%a7%db%8c-%d8%a8%d8%a7-vue-js-%d9%88-flask-%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa-%d8%a7%db%8c%d8%a7\/#%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\"> 15<\/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=\"statemanagementwithvuex\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa_%d8%af%d9%88%d9%84%d8%aa%db%8c_%d8%a8%d8%a7_vuex\"><\/span>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0648\u0644\u062a\u06cc \u0628\u0627 <code>Vuex<\/code><span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u0631\u0627\u06cc \u067e\u0633\u062a \u0633\u0648\u0645 \u0628\u0647 \u0645\u0646 \u067e\u06cc\u0648\u0633\u062a\u06cc\u062f \u0645\u062a\u0634\u06a9\u0631\u0645 \u0631\u0648\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0646 <code>Vue.js<\/code> \u0648 Flask \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u062a\u0645\u0627\u0645 \u067e\u0634\u062a\u0647.  \u0645\u0648\u0636\u0648\u0639 \u0627\u0635\u0644\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f \u0631\u0648\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0646 <code>Vuex<\/code> \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0648\u0636\u0639\u06cc\u062a \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627.  \u0645\u0639\u0631\u0641\u06cc <code>Vuex<\/code>\u060c \u0645\u0646 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u062f \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0645\u0648\u0644\u0641\u0647 \u0647\u0627\u06cc Home \u0648 Survey \u0631\u0627 \u0627\u0632 \u067e\u0633\u062a \u0642\u0628\u0644\u06cc \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0627\u062f <code>Vuex<\/code>\u060c \u0648 \u0645\u0646 \u0647\u0645\u0686\u0646\u06cc\u0646 \u062a\u0648\u0627\u0646\u0627\u06cc\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0647\u0627\u06cc \u062c\u062f\u06cc\u062f \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>Vuex<\/code> \u0627\u0644\u06af\u0648.<\/p>\n<p>\u06a9\u062f \u0627\u06cc\u0646 \u067e\u0633\u062a \u062f\u0631 \u06cc\u06a9 \u0645\u062e\u0632\u0646 \u0627\u0633\u062a \u0631\u0648\u06cc \u0645\u0646 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/amcquistan\/flask-vuejs-survey\/tree\/ThirdPost\">GitHub<\/a> \u062d\u0633\u0627\u0628 \u0632\u06cc\u0631 \u0634\u0639\u0628\u0647 <em>\u067e\u0633\u062a \u0633\u0648\u0645<\/em>.<\/p>\n<h2 id=\"seriescontent\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%ad%d8%aa%d9%88%d8%a7%db%8c_%d8%b3%d8%b1%db%8c\"><\/span>\u0645\u062d\u062a\u0648\u0627\u06cc \u0633\u0631\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<ol>\n<li>\u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0648 \u0622\u0634\u0646\u0627\u06cc\u06cc \u0628\u0627 VueJS<\/li>\n<li>\u0645\u0633\u06cc\u0631\u06cc\u0627\u0628 Vue<\/li>\n<li>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0648\u0644\u062a\u06cc \u0628\u0627 Vuex <em>(\u062a\u0648 \u0627\u06cc\u0646\u062c\u0627\u06cc\u06cc)<\/em><\/li>\n<li>RESTful API \u0628\u0627 Flask<\/li>\n<li>\u0627\u062f\u063a\u0627\u0645 AJAX \u0628\u0627 REST API<\/li>\n<li>\u0627\u062d\u0631\u0627\u0632 \u0647\u0648\u06cc\u062a JWT<\/li>\n<li>\u0627\u0633\u062a\u0642\u0631\u0627\u0631 \u062f\u0631 \u06cc\u06a9 \u0633\u0631\u0648\u0631 \u062e\u0635\u0648\u0635\u06cc \u0645\u062c\u0627\u0632\u06cc<\/li>\n<\/ol>\n<h2 id=\"introducingvuex\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c_%da%a9%d8%b1%d8%af%d9%86_vuex\"><\/span>\u0645\u0639\u0631\u0641\u06cc \u06a9\u0631\u062f\u0646 <code>Vuex<\/code><span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/vuex.vuejs.org\/\">Vuex<\/a> \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0648\u0644\u062a\u06cc \u0645\u062a\u0645\u0631\u06a9\u0632 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u0631\u0633\u0645\u06cc \u062a\u0648\u0633\u0637 \u0647\u0633\u062a\u0647 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f <code>Vue.js<\/code> \u062a\u06cc\u0645 \u062a\u0648\u0633\u0639\u0647. <code>Vuex<\/code> \u0627\u0644\u0641 \u0631\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/code-cartoons.com\/articles\/a-cartoon-guide-to-flux\/\" class=\"broken_link\">\u0634\u0627\u0631 \u0645\u0627\u0646\u0646\u062f<\/a>\u060c \u062c\u0631\u06cc\u0627\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06cc\u06a9 \u0637\u0631\u0641\u0647\u060c \u0627\u0644\u06af\u0648\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u0632 \u0645\u062a\u0648\u0633\u0637 \u200b\u200b\u062a\u0627 \u0628\u0632\u0631\u06af \u0628\u0633\u06cc\u0627\u0631 \u0642\u062f\u0631\u062a\u0645\u0646\u062f \u0627\u0633\u062a <code>Vue.js<\/code> \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc.<\/p>\n<p>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631\u06cc \u0627\u0632 \u0627\u0644\u06af\u0648\u0647\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062d\u0627\u0644\u062a \u0634\u0627\u0631 \u0645\u0627\u0646\u0646\u062f \u0648 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0647\u0627 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f\u060c \u0627\u0645\u0627 <code>Vuex<\/code> \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0627\u0635 \u0637\u0631\u0627\u062d\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a <code>Vue.js<\/code>\u0633\u06cc\u0633\u062a\u0645 \u0648\u0627\u06a9\u0646\u0634 \u0633\u0631\u06cc\u0639 \u0648 \u0633\u0627\u062f\u0647  \u0627\u06cc\u0646 \u0627\u0645\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06cc\u06a9 API \u0628\u0647 \u062e\u0648\u0628\u06cc \u0637\u0631\u0627\u062d\u06cc \u0634\u062f\u0647 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u0645\u0646\u0628\u0639\u06cc \u0627\u0632 \u062d\u0642\u06cc\u0642\u062a \u0631\u0627 \u0628\u0631\u0627\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0634\u06cc \u062a\u06a9 \u062a\u0646\u06cc \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f.  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u0635\u0644 \u0645\u0646\u0628\u0639 \u0648\u0627\u062d\u062f \u062d\u0642\u06cc\u0642\u062a\u060c <code>Vuex<\/code> \u0647\u0645\u0686\u0646\u06cc\u0646 \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u0635\u0631\u06cc\u062d \u0648 \u0642\u0627\u0628\u0644 \u0631\u062f\u06cc\u0627\u0628\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0639\u0645\u0644\u06cc\u0627\u062a \u0646\u0627\u0647\u0645\u0632\u0645\u0627\u0646 (\u0639\u0645\u0644\u06cc\u0627\u062a)\u060c \u062f\u0633\u062a\u0631\u0633\u06cc\u200c\u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u0631\u0627\u062d\u062a (\u06af\u06cc\u0631\u0646\u062f\u0647)\u060c \u0648 \u0642\u0627\u0628\u0644\u06cc\u062a\u200c\u0647\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0627\u062f\u0647 (\u062c\u0647\u0634) \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 <code>Vuex<\/code>\u060c \u0627\u0628\u062a\u062f\u0627 \u0628\u0627\u06cc\u062f \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0647\u0645\u0627\u0646 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u06a9\u0647 \u062d\u0627\u0648\u06cc <code>package.json<\/code> \u0641\u0627\u06cc\u0644 \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"hljs\">$ npm install --save vuex\n<\/code><\/pre>\n<p>\u0628\u0639\u062f \u0645\u0646 \u06cc\u06a9 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u062c\u062f\u06cc\u062f \u062f\u0631 \u062f\u0627\u062e\u0644 \u067e\u0631\u0648\u0698\u0647 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>src\/<\/code> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0634\u062f <code>store<\/code> \u0648 \u06cc\u06a9 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f <code>index.js<\/code> \u0641\u0627\u06cc\u0644.  \u0627\u06cc\u0646 \u0645\u0646\u062c\u0631 \u0628\u0647 \u0633\u0627\u062e\u062a\u0627\u0631 \u067e\u0631\u0648\u0698\u0647 Surve-Spa \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u0627\u06a9\u0646\u0648\u0646 \u0628\u0647 \u0627\u06cc\u0646 \u0634\u06a9\u0644 \u0627\u0633\u062a (\u0628\u0627 \u0646\u0627\u062f\u06cc\u062f\u0647 \u06af\u0631\u0641\u062a\u0646 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0647\u0627\u06cc node_modules\u060c build \u0648 config):<\/p>\n<pre><code class=\"hljs\">\u251c\u2500\u2500 index.html\n\u251c\u2500\u2500 package-lock.json\n\u251c\u2500\u2500 package.json\n\u251c\u2500\u2500 src\n\u2502   \u251c\u2500\u2500 App.vue\n\u2502   \u251c\u2500\u2500 api\n\u2502   \u2502   \u2514\u2500\u2500 index.js\n\u2502   \u251c\u2500\u2500 assets\n\u2502   \u2502   \u2514\u2500\u2500 logo.png\n\u2502   \u251c\u2500\u2500 components\n\u2502   \u2502   \u251c\u2500\u2500 Header.vue\n\u2502   \u2502   \u251c\u2500\u2500 Home.vue\n\u2502   \u2502   \u2514\u2500\u2500 Survey.vue\n\u2502   \u251c\u2500\u2500 main.js\n\u2502   \u251c\u2500\u2500 router\n\u2502   \u2502   \u2514\u2500\u2500 index.js\n\u2502   \u2514\u2500\u2500 store\n\u2502       \u2514\u2500\u2500 index.js\n\u2514\u2500\u2500 static\n    \u2514\u2500\u2500 .gitkeep\n<\/code><\/pre>\n<p>\u062f\u0631\u0648\u0646 <code>store\/index.js<\/code> \u0641\u0627\u06cc\u0644 \u0645\u0646 \u0628\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0648\u0627\u0631\u062f\u0627\u062a \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u0645\u06cc \u06a9\u0646\u0645 <code>Vue<\/code> \u0648 <code>Vuex<\/code> \u0627\u0634\u06cc\u0627\u0621 \u0633\u067e\u0633 \u0645\u062a\u0635\u0644 \u0645\u06cc \u0634\u0648\u0646\u062f <code>Vuex<\/code> \u0628\u0647 <code>Vue<\/code> \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0646 <code>Vue.use(Vuex)<\/code> \u0645\u0634\u0627\u0628\u0647 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0628\u0627 \u0622\u0646 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f <code>vue-router<\/code>.  \u067e\u0633 \u0627\u0632 \u0627\u06cc\u0646\u060c \u0645\u0646 \u0686\u0647\u0627\u0631 \u0634\u06cc\u0621 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u0645: <code>state<\/code>\u060c <code>actions<\/code>\u060c <code>mutations<\/code>\u060c \u0648 <code>getters<\/code>.<\/p>\n<p>\u062f\u0631 \u0627\u0646\u062a\u0647\u0627\u06cc \u0641\u0627\u06cc\u0644 \u06cc\u06a9 \u0634\u06cc \u0646\u0647\u0627\u06cc\u06cc \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u0645 \u06a9\u0647 \u0646\u0645\u0648\u0646\u0647 \u0627\u06cc \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a <code>Vuex.Store({})<\/code> \u0634\u06cc\u060c \u06a9\u0647 \u062a\u0645\u0627\u0645 \u0627\u0634\u06cc\u0627\u0621 \u062e\u0631\u062f \u062f\u06cc\u06af\u0631 \u0631\u0627 \u0628\u0647 \u0647\u0645 \u0645\u06cc\u200c\u06a9\u0634\u062f \u0648 \u0633\u067e\u0633 \u0635\u0627\u062f\u0631 \u0645\u06cc\u200c\u0634\u0648\u062f.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ src\/store\/index.js<\/span>\n\n<span class=\"hljs-keyword\">import<\/span> Vue <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'vue'<\/span>\n<span class=\"hljs-keyword\">import<\/span> Vuex <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'vuex'<\/span>\n\nVue.use(Vuex)\n\n<span class=\"hljs-keyword\">const<\/span> state = {\n  <span class=\"hljs-comment\">\/\/ single source of data<\/span>\n}\n\n<span class=\"hljs-keyword\">const<\/span> actions = {\n  <span class=\"hljs-comment\">\/\/ asynchronous operations<\/span>\n}\n\n<span class=\"hljs-keyword\">const<\/span> mutations = {\n  <span class=\"hljs-comment\">\/\/ isolated data mutations<\/span>\n}\n\n<span class=\"hljs-keyword\">const<\/span> getters = {\n  <span class=\"hljs-comment\">\/\/ reusable data accessors<\/span>\n}\n\n<span class=\"hljs-keyword\">const<\/span> store = <span class=\"hljs-keyword\">new<\/span> Vuex.Store({\n  state,\n  actions,\n  mutations,\n  getters\n})\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> store\n<\/code><\/pre>\n<p>\u062e\u0648\u0628\u060c \u0686\u0646\u062f \u0644\u062d\u0638\u0647 \u0628\u0647 \u0645\u0646 \u0641\u0631\u0635\u062a \u062f\u0647\u06cc\u062f \u062a\u0627 \u0645\u0639\u0646\u0627\u06cc \u0622\u0646 \u0631\u0627 \u062a\u0648\u0636\u06cc\u062d \u062f\u0647\u0645 <code>state<\/code>\u060c <code>actions<\/code>\u060c <code>mutations<\/code>\u060c \u0648 <code>getters<\/code> \u0627\u0634\u06cc\u0627\u0621.<\/p>\n<p>\u0631\u0627 <code>state<\/code> \u0634\u06cc \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u0646\u0628\u0639 \u0645\u0646\u0641\u0631\u062f \u062d\u0642\u06cc\u0642\u062a \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u062a\u0645\u0627\u0645 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u0647\u0645 \u062f\u0631 \u0633\u0637\u062d \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0645\u0648\u062c\u0648\u062f \u0627\u0633\u062a.  \u0627\u06cc\u0646 <code>state<\/code> \u0634\u06cc \u062d\u0627\u0648\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062a\u0648\u0633\u0637 \u0647\u0631 \u0645\u0624\u0644\u0641\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u0647 \u0622\u0646\u0647\u0627 \u0639\u0644\u0627\u0642\u0647 \u062f\u0627\u0631\u062f\u060c \u0645\u0627\u0646\u0646\u062f \u0645\u0624\u0644\u0641\u0647 Home\u060c \u0628\u0647 \u0622\u0646\u0647\u0627 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f \u0648 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0631\u0627 \u0645\u0634\u0627\u0647\u062f\u0647 \u06a9\u0646\u062f.<\/p>\n<p>\u0631\u0627 <code>actions<\/code> \u0634\u06cc \u062c\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0646 \u0622\u0646\u0686\u0647 \u0631\u0627 \u06a9\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0634\u0646\u0627\u062e\u062a\u0647 \u0645\u06cc \u0634\u0648\u062f \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u0645 <em>\u0639\u0645\u0644<\/em> \u0645\u0648\u0627\u062f \u0648 \u0631\u0648\u0634 \u0647\u0627.  \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u0627\u0642\u062f\u0627\u0645 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u00ab\u0627\u0631\u0633\u0627\u0644\u00bb \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0648 \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u0639\u0645\u0644\u06cc\u0627\u062a \u0646\u0627\u0647\u0645\u0632\u0645\u0627\u0646 \u0645\u0627\u0646\u0646\u062f \u062a\u0645\u0627\u0633\u200c\u0647\u0627\u06cc AJAX \u0628\u0647 \u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633 \u062e\u0627\u0631\u062c\u06cc \u06cc\u0627 API \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f.<\/p>\n<p>\u0631\u0627 <code>mutations<\/code> \u0634\u06cc \u0645\u062a\u062f\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0628\u0647 \u0622\u0646\u0647\u0627 &#8220;\u0645\u062a\u0639\u0647\u062f&#8221; \u0645\u06cc \u06af\u0648\u06cc\u0646\u062f \u0648 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0648 \u062a\u0646\u0647\u0627 \u0631\u0627\u0647 \u0628\u0631\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0648\u0636\u0639\u06cc\u062a \u062f\u0627\u062f\u0647 \u0647\u0627 \u062f\u0631 <code>state<\/code> \u0647\u062f\u0641 &#8211; \u0634\u06cc.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06cc\u06a9 \u062c\u0647\u0634 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f\u060c \u0647\u0631 \u0645\u0624\u0644\u0641\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0648\u0627\u06a9\u0646\u0634\u06cc \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u0627\u0631\u062c\u0627\u0639 \u0645\u06cc \u062f\u0647\u062f <code>state<\/code> \u0634\u06cc \u0628\u0627 \u0645\u0642\u0627\u062f\u06cc\u0631 \u062c\u062f\u06cc\u062f \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0628\u0627\u0639\u062b \u0645\u06cc \u0634\u0648\u062f UI \u0639\u0646\u0627\u0635\u0631 \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u062f \u0648 \u062f\u0648\u0628\u0627\u0631\u0647 \u0631\u0646\u062f\u0631 \u06a9\u0646\u062f.<\/p>\n<p>\u0631\u0627 <code>getters<\/code> \u0634\u06cc \u0646\u06cc\u0632 \u062d\u0627\u0648\u06cc \u0645\u062a\u062f\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a\u060c \u0627\u0645\u0627 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f \u0622\u0646\u0647\u0627 \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 <code>state<\/code> \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u0632 \u0645\u0646\u0637\u0642\u06cc \u0628\u0631\u0627\u06cc \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f.  \u062f\u0631\u06cc\u0627\u0641\u062a\u200c\u06a9\u0646\u0646\u062f\u0647\u200c\u0647\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0647\u0634 \u062a\u06a9\u0631\u0627\u0631 \u06a9\u062f \u0648 \u0627\u0631\u062a\u0642\u0627\u06cc \u0642\u0627\u0628\u0644\u06cc\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u062f\u0631 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0645\u0624\u0644\u0641\u0647\u200c\u0647\u0627 \u0645\u0641\u06cc\u062f \u0647\u0633\u062a\u0646\u062f.<\/p>\n<p>\u0622\u062e\u0631\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0641\u0639\u0627\u0644 \u0633\u0627\u0632\u06cc \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u062f\u0648\u0628\u0627\u0631\u0647 \u0628\u0647 \u062f\u0627\u062e\u0644 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f <code>src\/main.js<\/code> \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0646 import \u0631\u0627 <code>store<\/code> \u0645\u0627\u0698\u0648\u0644 \u0628\u0647 \u062a\u0627\u0632\u06af\u06cc \u0627\u06cc\u062c\u0627\u062f \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0633\u067e\u0633 \u062f\u0631 \u0634\u06cc Options \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0646\u0645\u0648\u0646\u0647 Vue \u0633\u0637\u062d \u0628\u0627\u0644\u0627\u06cc \u0646\u0645\u0648\u0646\u0647 \u0627\u0633\u062a\u060c \u0648\u0627\u0631\u062f \u0634\u062f\u0647 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>store<\/code> \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0645\u0644\u06a9  \u0627\u06cc\u0646 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0628\u0627\u0634\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ src\/main.js<\/span>\n\n<span class=\"hljs-keyword\">import<\/span> Vue <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'<\/span>\n<span class=\"hljs-keyword\">import<\/span> router <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'.\/router'<\/span>\n<span class=\"hljs-keyword\">import<\/span> store <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'.\/store'<\/span>\n\nVue.config.productionTip = <span class=\"hljs-literal\">false<\/span>\n\n<span class=\"hljs-keyword\">new<\/span> Vue({\n  <span class=\"hljs-attr\">el<\/span>: <span class=\"hljs-string\">'#app'<\/span>,\n  router,\n  store,\n  <span class=\"hljs-attr\">components<\/span>: { App },\n  <span class=\"hljs-attr\">template<\/span>: <span class=\"hljs-string\">'&lt;App\/&gt;'<\/span>\n})\n<\/code><\/pre>\n<h2 id=\"migratingthehomecomponenttovuex\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%86%d8%aa%d9%82%d8%a7%d9%84_%d9%85%d9%88%d9%84%d9%81%d9%87_%d8%ae%d8%a7%d9%86%d9%87_%d8%a8%d9%87_vuex\"><\/span>\u0627\u0646\u062a\u0642\u0627\u0644 \u0645\u0648\u0644\u0641\u0647 \u062e\u0627\u0646\u0647 \u0628\u0647 <code>Vuex<\/code><span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u0646 \u0645\u06cc \u062e\u0648\u0627\u0647\u0645 \u0634\u0631\u0648\u0639 \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0645 <code>Vuex<\/code> \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 Survey \u0628\u0627 \u0627\u0646\u062a\u0642\u0627\u0644 \u0631\u0648\u0634\u06cc \u06a9\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0647\u0627 \u062f\u0631 \u0645\u0624\u0644\u0641\u0647 Home \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u0646\u062f \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>Vuex<\/code> \u0627\u0644\u06af\u0648.  \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639\u060c \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062e\u0627\u0644\u06cc \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u0648 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>state<\/code> \u0634\u06cc \u062f\u0631 \u062f\u0627\u062e\u0644 <code>store\/index.js<\/code>.  \u0627\u06cc\u0646 \u0645\u06a9\u0627\u0646\u06cc \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f \u06a9\u0647 \u067e\u0633 \u0627\u0632 \u062f\u0631\u06cc\u0627\u0641\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a AJAX\u060c \u062a\u0645\u0627\u0645 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0633\u0637\u062d \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u0622\u0646 \u0642\u0631\u0627\u0631 \u0645\u06cc \u06af\u06cc\u0631\u0646\u062f.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> state = {\n  <span class=\"hljs-comment\">\/\/ single source of data<\/span>\n  <span class=\"hljs-attr\">surveys<\/span>: ()\n}\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u06a9\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0647\u0627 \u0645\u06a9\u0627\u0646\u06cc \u0628\u0631\u0627\u06cc \u0633\u06a9\u0648\u0646\u062a \u062f\u0627\u0631\u0646\u062f\u060c \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0631\u0648\u0634 \u0627\u0642\u062f\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u0645\u060c <code>loadSurveys(...)<\/code>\u060c \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u0632 \u0645\u0624\u0644\u0641\u0647 Home (\u06cc\u0627 \u0647\u0631 \u0645\u0624\u0644\u0641\u0647 \u062f\u06cc\u06af\u0631\u06cc \u06a9\u0647 \u0628\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u062f) \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0646\u0627\u0647\u0645\u0632\u0645\u0627\u0646 \u0628\u0647 \u062a\u0627\u0628\u0639 \u0633\u0627\u062e\u062a\u06af\u06cc AJAX \u0627\u0631\u0633\u0627\u0644 \u0634\u0648\u062f. <code>fetchSurveys()<\/code>.  \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 <code>fetchSurveys()<\/code> \u0645\u0646 \u0627\u0648\u0644 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u0645 import \u0622\u0646 \u0631\u0627 \u0627\u0632 <code>api<\/code> \u0645\u0627\u0698\u0648\u0644 \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u062f <code>loadSurveys(...)<\/code> \u0631\u0648\u0634 \u0639\u0645\u0644 \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a<\/p>\n<p>\u06a9\u0646\u0634\u200c\u0647\u0627 \u0627\u063a\u0644\u0628 \u0647\u0645\u0631\u0627\u0647 \u0628\u0627 \u062c\u0647\u0634\u200c\u0647\u0627\u06cc\u06cc \u062f\u0631 \u0627\u0644\u06af\u0648\u06cc \u0627\u0646\u062c\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc AJAX \u0646\u0627\u0647\u0645\u0632\u0645\u0627\u0646 \u0628\u0631\u0627\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u0628\u0647 \u0633\u0631\u0648\u0631 \u0648 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0635\u0631\u06cc\u062d \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u06a9\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. <code>state<\/code> \u0634\u06cc \u0628\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0634\u062f\u0647  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u062c\u0647\u0634 \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u0628\u062e\u0634\u200c\u0647\u0627\u06cc\u06cc \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0647 \u0627\u0632 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc\u200c\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u0628\u0631\u0631\u0633\u06cc\u200c\u0647\u0627\u06cc \u0628\u0647\u200c\u0631\u0648\u0632 \u0634\u062f\u0647 \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0633\u06cc\u0633\u062a\u0645 \u0648\u0627\u06a9\u0646\u0634\u200c\u067e\u0630\u06cc\u0631\u06cc Vue \u062a\u0634\u062e\u06cc\u0635 \u0645\u06cc\u200c\u062f\u0647\u0646\u062f.  \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u062c\u0647\u0634\u06cc \u06a9\u0647 \u0645\u0646 \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u0645 \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>setSurveys(...)<\/code>.<\/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\">import<\/span> Vuex <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'vuex'<\/span>\n\n<span class=\"hljs-comment\">\/\/ imports of AJAX functions go here<\/span>\n<span class=\"hljs-keyword\">import<\/span> { fetchSurveys } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/api'<\/span>\n\nVue.use(Vuex)\n\n<span class=\"hljs-keyword\">const<\/span> state = {\n  <span class=\"hljs-comment\">\/\/ single source of data<\/span>\n  <span class=\"hljs-attr\">surveys<\/span>: ()\n}\n\n<span class=\"hljs-keyword\">const<\/span> actions = {\n  <span class=\"hljs-comment\">\/\/ asynchronous operations<\/span>\n  <span class=\"hljs-function\"><span class=\"hljs-title\">loadSurveys<\/span>(<span class=\"hljs-params\">context<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> fetchSurveys()\n      .then(<span class=\"hljs-function\">(<span class=\"hljs-params\">response<\/span>) =&gt;<\/span> context.commit(<span class=\"hljs-string\">'setSurveys'<\/span>, { <span class=\"hljs-attr\">surveys<\/span>: response }))\n  }\n}\n\n<span class=\"hljs-keyword\">const<\/span> mutations = {\n  <span class=\"hljs-comment\">\/\/ isolated data mutations<\/span>\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setSurveys<\/span>(<span class=\"hljs-params\">state, payload<\/span>)<\/span> {\n    state.surveys = payload.surveys\n  }\n}\n<\/code><\/pre>\n<p>\u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0627\u06cc\u0646\u06a9\u0647 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0627\u06a9\u0646\u0648\u0646 \u062a\u0648\u0627\u0646\u0627\u06cc\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0647\u0627 \u0631\u0627 \u062f\u0627\u0631\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0645\u0624\u0644\u0641\u0647 Home \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u0645 \u0648 \u0627\u0632 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0628\u0631\u0627\u06cc \u062a\u063a\u0630\u06cc\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0645.  \u0628\u0631\u06af\u0634\u062a \u062f\u0627\u062e\u0644 <code>src\/components\/Home.vue<\/code>\u060c \u0645\u0646 \u062d\u0630\u0641 \u0645\u06cc \u06a9\u0646\u0645 import \u0627\u0632 <code>fetchSurveys<\/code> \u062a\u0627\u0628\u0639:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { fetchSurveys } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/api'<\/span>\n<\/code><\/pre>\n<p>\u0648 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0646\u06cc\u062f import \u0628\u0647 <code>Vuex<\/code> \u062a\u0627\u0628\u0639 \u06a9\u0645\u06a9\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0634\u062f <code>mapState<\/code>.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { mapState } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'vuex'<\/span>\n<\/code><\/pre>\n<p>\u0645\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f <code>mapState<\/code> \u0628\u0631\u0627\u06cc \u0646\u0642\u0634\u0647 \u0628\u0631\u062f\u0627\u0631\u06cc <code>surveys<\/code> \u0622\u0631\u0627\u06cc\u0647 \u0627\u06cc \u06a9\u0647 \u062f\u0631 <code>state<\/code> \u0634\u06cc \u0628\u0647 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647 \u0646\u06cc\u0632 \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>surveys<\/code>. <code>mapState<\/code> \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc \u062a\u0627\u0628\u0639\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0627\u0631\u062c\u0627\u0639 \u0628\u0647 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u062e\u0627\u0635 \u0627\u0632 \u0631\u0627 \u062d\u0641\u0638 \u0645\u06cc \u06a9\u0646\u062f <code>state<\/code> \u0647\u062f\u0641 &#8211; \u0634\u06cc (<code>state.surveys<\/code> \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f)\u060c \u0648 \u0627\u06af\u0631 \u0622\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u062c\u0632\u0621 \u062c\u0647\u0634 \u06cc\u0627\u0641\u062a\u0647 \u0628\u0627\u0634\u062f <code>mapState<\/code> \u0628\u0647 \u0622\u0646 \u062a\u063a\u06cc\u06cc\u0631 \u0648\u0627\u06a9\u0646\u0634 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0648 \u0647\u0631 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0645\u0631\u062a\u0628\u0637 \u0628\u0627 \u0622\u0646 \u062f\u0627\u062f\u0647 \u0631\u0627 \u062a\u0627\u0632\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a Home \u0645\u0646 \u062c\u062f\u06cc\u062f \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0647 \u0627\u0645 <code>surveys<\/code> \u062f\u0627\u0631\u0627\u06cc\u06cc \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u062f\u0631 <code>beforeMount<\/code> \u0631\u0648\u0634 I \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0627\u0631\u0633\u0627\u0644 \u0627\u0632 <code>loadSurveys<\/code> \u0627\u0642\u062f\u0627\u0645 \u0630\u062e\u06cc\u0631\u0647  \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647 \u0628\u0647 \u0646\u0627\u0645 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f <code>surveys<\/code> \u0628\u0627\u06cc\u062f \u0645\u0648\u062c\u0648\u062f \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u0645 <code>surveys<\/code> \u0648\u06cc\u0698\u06af\u06cc \u0627\u0632 \u0642\u0633\u0645\u062a \u062f\u0627\u062f\u0647 \u0634\u06cc Vue \u062c\u0632\u0621.  \u062f\u0631 \u0648\u0627\u0642\u0639\u060c \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u06cc\u0646 \u062a\u0646\u0647\u0627 \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u0628\u0648\u062f\u060c \u0628\u0627\u06cc\u062f \u06a9\u0644 \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u0631\u0627 \u0646\u06cc\u0632 \u062d\u0630\u0641 \u06a9\u0646\u0645 \u062a\u0627 \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0631\u0627 \u0645\u0631\u062a\u0628 \u0646\u06af\u0647 \u062f\u0627\u0631\u0645\u060c \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u062f\u0631 \u0632\u06cc\u0631 \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/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> { mapState } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'vuex'<\/span>\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-attr\">computed<\/span>: mapState({\n    <span class=\"hljs-attr\">surveys<\/span>: <span class=\"hljs-function\"><span class=\"hljs-params\">state<\/span> =&gt;<\/span> state.surveys\n  }),\n  <span class=\"hljs-function\"><span class=\"hljs-title\">beforeMount<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-built_in\">this<\/span>.$store.dispatch(<span class=\"hljs-string\">'loadSurveys'<\/span>)\n  }\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0645\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0628\u0647 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0645 \u0648 \u0645\u062a\u062f \u0639\u0645\u0644 \u0631\u0627 \u0628\u0627 \u0633\u06cc\u0646\u062a\u06a9\u0633 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u0645 <code>this.$store.dispatch(...)<\/code>.  \u0627\u06cc\u0646 \u0628\u0627\u06cc\u062f \u0634\u0628\u06cc\u0647 \u0631\u0648\u0634\u06cc \u0628\u0627\u0634\u062f \u06a9\u0647 \u062f\u0631 \u0645\u0642\u0627\u0644\u0647 \u0642\u0628\u0644\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0628\u0647 \u0645\u0633\u06cc\u0631 \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0631\u062f\u0645 <code>this.$route<\/code>.  \u0627\u06cc\u0646 \u0628\u0647 \u0627\u06cc\u0646 \u062f\u0644\u06cc\u0644 \u0627\u0633\u062a \u06a9\u0647 \u0647\u0631 \u062f\u0648 <code>vue-router<\/code> \u0648 <code>Vuex<\/code> \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0627\u06cc\u0646 \u0627\u0634\u06cc\u0627\u0621 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0631\u0627\u062d\u062a \u0628\u0647 \u0646\u0645\u0648\u0646\u0647 Vue \u062a\u0632\u0631\u06cc\u0642 \u0645\u06cc \u06a9\u0646\u062f.  \u0645\u0646 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0633\u062a\u0645 \u0628\u0647 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0645 <code>state.surveys<\/code> \u0622\u0631\u0627\u06cc\u0647 \u0627\u0632 \u062f\u0631\u0648\u0646 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>this.$store.state.surveys<\/code> \u0628\u062c\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>mapState<\/code>\u060c \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062c\u0647\u0634 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0645 <code>this.$store.commit<\/code>.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647 \u0628\u0627\u06cc\u062f \u0628\u062a\u0648\u0627\u0646\u0645 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u0645 \u0648 \u0628\u0627 \u062f\u0631\u062e\u0648\u0627\u0633\u062a URL\u060c \u0647\u0645\u0627\u0646 \u0639\u0645\u0644\u06a9\u0631\u062f \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u062e\u0648\u062f \u0645\u0634\u0627\u0647\u062f\u0647 \u06a9\u0646\u0645 <code>localhost:8080<\/code> \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0642\u0628\u0644\u0627 \u062f\u06cc\u062f\u0647 \u0634\u062f<\/p>\n<h2 id=\"migratingthesurveycomponent\"><span class=\"ez-toc-section\" id=\"%d9%85%d9%87%d8%a7%d8%ac%d8%b1%d8%aa_%d9%85%d8%a4%d9%84%d9%81%d9%87_%d9%86%d8%b8%d8%b1%d8%b3%d9%86%d8%ac%db%8c\"><\/span>\u0645\u0647\u0627\u062c\u0631\u062a \u0645\u0624\u0644\u0641\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0648\u0638\u06cc\u0641\u0647 \u0628\u0639\u062f\u06cc \u0627\u0646\u062a\u0642\u0627\u0644 \u0645\u0648\u0644\u0641\u0647 Survey \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0633\u062a <code>Vuex<\/code>&#8216;s \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0628\u0631\u0627\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062e\u0627\u0635 \u0628\u0631\u0627\u06cc \u0634\u0631\u06a9\u062a \u062f\u0631 \u06af\u0631\u0641\u062a\u0646.  \u062c\u0631\u06cc\u0627\u0646 \u06a9\u0644\u06cc \u0628\u0631\u0627\u06cc \u0645\u0648\u0644\u0641\u0647 Survey \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0622\u0646 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f <code>:id<\/code> \u067e\u0627\u06cc\u0647 \u0645\u0633\u06cc\u0631 \u0648 \u0633\u067e\u0633 \u0627\u0632 a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>Vuex<\/code> \u0631\u0648\u0634 \u0627\u0642\u062f\u0627\u0645 \u0628\u0631\u0627\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062a\u0648\u0633\u0637 \u0622\u0646 <code>id<\/code>.  \u0628\u0647 \u062c\u0627\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u0633\u062a\u0642\u06cc\u0645 \u062a\u0627\u0628\u0639 \u0633\u0627\u062e\u062a\u06af\u06cc AJAX <code>fetchSurvey<\/code> \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u0627\u0646\u062c\u0627\u0645 \u0634\u062f\u060c \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0631\u0648\u0634 \u062f\u06cc\u06af\u0631\u06cc \u0627\u0632 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0648\u0627\u06af\u0630\u0627\u0631 \u06a9\u0646\u0645 \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0634\u062f\u0647 \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u062f (\u06cc\u0639\u0646\u06cc \u062c\u0647\u0634 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u062f) <code>state<\/code> \u0645\u0644\u06a9\u06cc \u06a9\u0647 \u0646\u0627\u0645 \u062e\u0648\u0627\u0647\u0645 \u0628\u0631\u062f <code>currentSurvey<\/code>.<\/p>\n<p>\u0628\u0627 \u0634\u0631\u0648\u0639 \u062f\u0631 \u0645\u0627\u0698\u0648\u0644 store\/index.js \u0627\u06cc\u0646 \u062e\u0637 \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u06cc \u062f\u0647\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { fetchSurveys } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/api'<\/span>\n<\/code><\/pre>\n<p>\u0628\u0647<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { fetchSurveys, fetchSurvey } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/api'<\/span>\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0628\u0647 \u0645\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u0645\u06cc \u062f\u0647\u062f <code>fetchSurvey<\/code> \u062f\u0631 \u0645\u0627\u0698\u0648\u0644 \u0641\u0631\u0648\u0634\u06af\u0627\u0647  \u0645\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>fetchSurvey<\/code> \u062f\u0631 \u06cc\u06a9 \u0631\u0648\u0634 \u0627\u0642\u062f\u0627\u0645 \u062c\u062f\u06cc\u062f \u0628\u0647 \u0646\u0627\u0645 <code>loadSurvey<\/code> \u06a9\u0647 \u0633\u067e\u0633 \u06cc\u06a9 \u062c\u0647\u0634 \u0631\u0627 \u062f\u0631 \u0631\u0648\u0634 \u062c\u062f\u06cc\u062f \u062f\u06cc\u06af\u0631\u06cc \u062f\u0631 \u062f\u0627\u062e\u0644 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f <code>mutations<\/code> \u0634\u06cc \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>setCurrentSurvey<\/code>.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ src\/store\/index.js<\/span>\n\n<span class=\"hljs-keyword\">const<\/span> actions = {\n  <span class=\"hljs-comment\">\/\/ asynchronous operations<\/span>\n  <span class=\"hljs-function\"><span class=\"hljs-title\">loadSurveys<\/span>(<span class=\"hljs-params\">context<\/span>)<\/span> {\n    <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">loadSurvey<\/span>(<span class=\"hljs-params\">context, { id }<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> fetchSurvey(id)\n      .then(<span class=\"hljs-function\">(<span class=\"hljs-params\">response<\/span>) =&gt;<\/span> context.commit(<span class=\"hljs-string\">'setSurvey'<\/span>. { <span class=\"hljs-attr\">survey<\/span>: response }))\n  }\n}\n<\/code><\/pre>\n<p>\u062f\u0631 \u0628\u0627\u0644\u0627 \u0627\u062c\u0631\u0627\u06cc <code>fetchSurvey<\/code> \u0631\u0648\u0634 \u0639\u0645\u0644 \u0645\u0634\u0627\u0628\u0647 \u0642\u0628\u0644\u06cc <code>fetchSurveys<\/code>\u060c \u0628\u0647 \u062c\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u06cc\u06a9 \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0634\u06cc \u0627\u0636\u0627\u0641\u06cc \u0628\u0627 \u0648\u06cc\u0698\u06af\u06cc id \u0628\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0628\u0647 \u0622\u0646 \u062f\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0628\u0631\u0627\u06cc \u0633\u0627\u062f\u0647 \u06a9\u0631\u062f\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0634\u0646\u0627\u0633\u0647 \u0627\u0632 ES2015 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0645 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/developer.mozilla.org\/en-US\/docs\/Web\/JavaScript\/Reference\/Operators\/Destructuring_assignment#Object_destructuring\">\u062a\u062e\u0631\u06cc\u0628 \u0634\u06cc<\/a>.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0627\u06a9\u0634\u0646 \u0627\u0632 \u06cc\u06a9 \u062c\u0632\u0621 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f\u060c \u0646\u062d\u0648 \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f: <code>this.$store.dispatch('loadSurvey', { id: 1 })<\/code>.<\/p>\n<p>\u0628\u0639\u062f \u0645\u0646 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>currentSurvey<\/code> \u062f\u0627\u0631\u0627\u06cc\u06cc \u0628\u0647 <code>state<\/code> \u0647\u062f\u0641 &#8211; \u0634\u06cc.  \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0645\u0646 \u06cc\u06a9 \u062c\u0647\u0634 \u0628\u0647 \u0646\u0627\u0645 \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u0645 <code>setSurvey<\/code> \u062f\u0631 <code>mutations<\/code> \u0634\u06cc\u060c \u06a9\u0647 a \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u062f <code>choice<\/code> \u0628\u0631\u0627\u06cc \u0647\u0631 \u0633\u0648\u0627\u0644\u060c \u0627\u0646\u062a\u062e\u0627\u0628 \u0627\u0646\u062a\u062e\u0627\u0628 \u0634\u062f\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0631\u0627 \u0646\u06af\u0647 \u062f\u0627\u0631\u06cc\u062f \u0648 \u0645\u0642\u062f\u0627\u0631 \u0622\u0646 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f <code>currentSurvey<\/code>.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> state = {\n  <span class=\"hljs-comment\">\/\/ single source of data<\/span>\n  <span class=\"hljs-attr\">surveys<\/span>: (),\n  <span class=\"hljs-attr\">currentSurvey<\/span>: {}\n}\n\n<span class=\"hljs-keyword\">const<\/span> actions = { <span class=\"hljs-comment\">\/\/ omitted for brevity }<\/span>\n\n<span class=\"hljs-keyword\">const<\/span> mutations = {\n  <span class=\"hljs-comment\">\/\/ isolated data mutations<\/span>\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setSurveys<\/span>(<span class=\"hljs-params\">state, payload<\/span>)<\/span> {\n    state.surveys = payload.surveys\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setSurvey<\/span>(<span class=\"hljs-params\">state, payload<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">const<\/span> nQuestions = payload.survey.questions.length\n    <span class=\"hljs-keyword\">for<\/span> (<span class=\"hljs-keyword\">let<\/span> i = <span class=\"hljs-number\">0<\/span>; i &lt; nQuestions; i++) {\n      payload.survey.questions(i).choice = <span class=\"hljs-literal\">null<\/span>\n    }\n    state.currentSurvey = payload.survey\n  }\n}\n<\/code><\/pre>\n<p>\u062f\u0631 <code>Survey.vue<\/code> \u0641\u0627\u06cc\u0644 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a\u060c \u0645\u0646 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u06a9\u0646\u0645 <code>beforeMount<\/code> \u0631\u0648\u0634 \u0627\u0631\u0633\u0627\u0644 <code>loadSurvey<\/code> \u0627\u0642\u062f\u0627\u0645 \u0648 \u0646\u0642\u0634\u0647 <code>state.currentSurvey<\/code> \u0628\u0647 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647 \u0628\u0647 \u0646\u0627\u0645 <code>survey<\/code>.  \u067e\u0633 \u0627\u0632 \u0622\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0645\u0648\u062c\u0648\u062f \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u0645 <code>survey<\/code> \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647<\/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> { saveSurveyResponse } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/api'<\/span>\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">currentQuestion<\/span>: <span class=\"hljs-number\">0<\/span>\n    }\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">beforeMount<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-built_in\">this<\/span>.$store.dispatch(<span class=\"hljs-string\">'loadSurvey'<\/span>, { <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-built_in\">parseInt<\/span>(<span class=\"hljs-built_in\">this<\/span>.$route.params.id) })\n  },\n  <span class=\"hljs-attr\">methods<\/span>: {\n    <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n  },\n  <span class=\"hljs-attr\">computed<\/span>: {\n    <span class=\"hljs-function\"><span class=\"hljs-title\">surveyComplete<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n    },\n    <span class=\"hljs-function\"><span class=\"hljs-title\">survey<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.$store.state.currentSurvey\n    }\n  }\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0630\u062e\u06cc\u0631\u0647 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u067e\u0631\u0648\u0698\u0647 \u0648 \u0628\u0627\u0632\u062e\u0648\u0627\u0646\u06cc \u0645\u0631\u0648\u0631\u06af\u0631 \u0628\u0631\u0627\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a URL <code>localhost:8080\/#\/surveys\/2<\/code> \u062f\u0648\u0628\u0627\u0631\u0647 \u0647\u0645\u0627\u0646 UI \u0645\u0627\u0646\u0646\u062f \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u0645\u0646 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p><img decoding=\"async\" class=\"img-responsive\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/single-page-apps-vue-and-flask-navigating-vue-router-8.png\" alt=\"\u0635\u0641\u062d\u0647 \u0628\u0646\u062f\u06cc \u0633\u0648\u0627\u0644\u0627\u062a \u0646\u0638\u0631\u0633\u0646\u062c\u06cc\" title=\"\"><\/p>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0647\u0646\u0648\u0632 \u06a9\u0645\u06cc \u0645\u0634\u06a9\u0644 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.  \u062f\u0631 \u06a9\u062f \u0642\u0627\u0644\u0628 \u06a9\u0647 \u0627\u0646\u062a\u062e\u0627\u0628 \u0647\u0627\u06cc \u0647\u0631 \u0633\u0648\u0627\u0644\u06cc \u0631\u0627 \u06a9\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0645 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f <code>v-model=\"question.choice\"<\/code> \u0628\u0631\u0627\u06cc \u0631\u062f\u06cc\u0627\u0628\u06cc \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0646\u062a\u062e\u0627\u0628\u06cc \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">v-for<\/span>=<span class=\"hljs-string\">\"choice in question.choices\"<\/span> <span class=\"hljs-attr\">v-bind:key<\/span>=<span class=\"hljs-string\">\"choice.id\"<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">label<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"radio\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"radio\"<\/span> <span class=\"hljs-attr\">v-model<\/span>=<span class=\"hljs-string\">\"question.choice\"<\/span> <span class=\"hljs-attr\">:value<\/span>=<span class=\"hljs-string\">\"choice.id\"<\/span>&gt;<\/span>\n    {{ choice.text }}\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">label<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0645\u0646\u062c\u0631 \u0628\u0647 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a\u06cc \u062f\u0631 <code>question.choice<\/code> \u0627\u0631\u0632\u0634\u06cc \u06a9\u0647 \u062f\u0631 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0630\u06a9\u0631 \u0634\u062f\u0647 \u0627\u0633\u062a <code>state.currentQuestion<\/code> \u0648\u06cc\u0698\u06af\u06cc.  \u0627\u06cc\u0646 \u0646\u0645\u0648\u0646\u0647 \u0627\u06cc \u0627\u0632 \u062a\u063a\u06cc\u06cc\u0631 \u0646\u0627\u062f\u0631\u0633\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0630\u062e\u06cc\u0631\u0647 \u062e\u0627\u0631\u062c \u0627\u0632 \u06cc\u06a9 \u062c\u0647\u0634 \u0627\u0633\u062a.  \u0631\u0627 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/vuex.vuejs.org\/en\/mutations.html\">vuex<\/a> \u0645\u0633\u062a\u0646\u062f\u0627\u062a \u062a\u0648\u0635\u06cc\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f \u06a9\u0647 \u0647\u0631\u06af\u0648\u0646\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0631 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0648\u0636\u0639\u06cc\u062a \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0645\u0646\u062d\u0635\u0631\u0627\u064b \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062c\u0647\u0634 \u0627\u0646\u062c\u0627\u0645 \u0634\u0648\u062f.  \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u067e\u0631\u0633\u06cc\u062f \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0645\u061f <code>v-model<\/code> \u062f\u0631 \u062a\u0631\u06a9\u06cc\u0628 \u0628\u0627 \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0648\u0631\u0648\u062f\u06cc \u06a9\u0647 \u062a\u0648\u0633\u0637 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u0646\u0628\u0639 \u0627\u0632 a \u0647\u062f\u0627\u06cc\u062a \u0645\u06cc \u0634\u0648\u062f <code>Vuex<\/code> \u0641\u0631\u0648\u0634\u06af\u0627\u0647\u061f<\/p>\n<p>\u067e\u0627\u0633\u062e \u0628\u0647 \u0627\u06cc\u0646\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0646\u0633\u062e\u0647 \u06a9\u0645\u06cc \u067e\u06cc\u0634\u0631\u0641\u062a\u0647 \u062a\u0631 \u0627\u0632 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0634\u0627\u0645\u0644 \u06cc\u06a9 \u062c\u0641\u062a \u062a\u0639\u0631\u06cc\u0641 \u0634\u062f\u0647 \u0627\u0633\u062a <code>get<\/code> \u0648 <code>set<\/code> \u0631\u0648\u0634 \u0647\u0627\u06cc \u062f\u0631\u0648\u0646 \u0622\u0646  \u0627\u06cc\u0646 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f <code>v-model<\/code> \u0645\u06a9\u0627\u0646\u06cc\u0632\u0645\u06cc \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u062a\u0635\u0627\u0644 \u062f\u0627\u062f\u0647 \u062f\u0648 \u0637\u0631\u0641\u0647 \u0628\u06cc\u0646 UI \u0648 \u0634\u06cc Vue \u062c\u0632\u0621.  \u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u0648\u06cc\u0698\u06af\u06cc \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647 \u0628\u0647 \u0635\u0631\u0627\u062d\u062a \u0628\u0631 \u062a\u0639\u0627\u0645\u0644\u0627\u062a \u0628\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u06a9\u0646\u062a\u0631\u0644 \u0645\u06cc \u06a9\u0646\u062f.  \u062f\u0631 \u06a9\u062f \u0642\u0627\u0644\u0628 \u0628\u0627\u06cc\u062f \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0646\u0645 <code>v-model=\"question.choice\"<\/code> \u0628\u0627 \u0648\u06cc\u0698\u06af\u06cc \u062c\u062f\u06cc\u062f \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647 \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646 <code>v-model=\"selectedChoice\"<\/code>.  \u062f\u0631 \u0632\u06cc\u0631 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0648\u06cc\u0698\u06af\u06cc \u0645\u062d\u0627\u0633\u0628\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a <code>selectedChoice<\/code>.<\/p>\n<pre><code class=\"hljs\">  computed: {\n    <span class=\"hljs-function\"><span class=\"hljs-title\">surveyComplete<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n    },\n    <span class=\"hljs-function\"><span class=\"hljs-title\">survey<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-built_in\">this<\/span>.$store.state.currentSurvey\n    },\n    <span class=\"hljs-attr\">selectedChoice<\/span>: {\n      <span class=\"hljs-function\"><span class=\"hljs-title\">get<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n        <span class=\"hljs-keyword\">const<\/span> question = <span class=\"hljs-built_in\">this<\/span>.survey.questions(<span class=\"hljs-built_in\">this<\/span>.currentQuestion)\n        <span class=\"hljs-keyword\">return<\/span> question.choice\n      },\n      <span class=\"hljs-function\"><span class=\"hljs-title\">set<\/span>(<span class=\"hljs-params\">value<\/span>)<\/span> {\n        <span class=\"hljs-keyword\">const<\/span> question = <span class=\"hljs-built_in\">this<\/span>.survey.questions(<span class=\"hljs-built_in\">this<\/span>.currentQuestion)\n        <span class=\"hljs-built_in\">this<\/span>.$store.commit(<span class=\"hljs-string\">'setChoice'<\/span>, { <span class=\"hljs-attr\">questionId<\/span>: question.id, <span class=\"hljs-attr\">choice<\/span>: value })\n      }\n    }\n  }\n<\/code><\/pre>\n<p>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc <code>selectedChoice<\/code> \u062f\u0631 \u0648\u0627\u0642\u0639 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u0634\u06cc \u0628\u0647 \u062c\u0627\u06cc \u062a\u0627\u0628\u0639\u06cc \u0645\u0627\u0646\u0646\u062f \u0628\u0642\u06cc\u0647 \u0627\u0633\u062a.  \u0631\u0627 <code>get<\/code> \u062a\u0627\u0628\u0639 \u062f\u0631 \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u0627 <code>currentQuestion<\/code> \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0646 <code>choice<\/code> \u0627\u0631\u0632\u0634 \u0633\u0648\u0627\u0644 \u062f\u0631 \u062d\u0627\u0644 \u0645\u0634\u0627\u0647\u062f\u0647  \u0631\u0627 <code>set(value)<\/code> \u0628\u062e\u0634 \u0645\u0642\u062f\u0627\u0631 \u062c\u062f\u06cc\u062f\u06cc \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0627\u0632 \u0622\u0646 \u062a\u063a\u0630\u06cc\u0647 \u0645\u06cc \u0634\u0648\u062f <code>v-model<\/code>&#8216;s \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc 2 \u0637\u0631\u0641\u0647 \u0645\u062a\u0635\u0644 \u0645\u06cc \u0634\u0648\u062f \u0648 \u06cc\u06a9 \u062c\u0647\u0634 \u0630\u062e\u06cc\u0631\u0647 \u0627\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0631\u0627 \u0645\u0631\u062a\u06a9\u0628 \u0645\u06cc \u0634\u0648\u062f <code>setChoice<\/code>.  \u0631\u0627 <code>setChoice<\/code> \u062c\u0647\u0634 \u0628\u0647 \u06cc\u06a9 \u0628\u0627\u0631 \u0634\u06cc\u0621 \u062d\u0627\u0648\u06cc <code>id<\/code> \u0627\u0632 \u0633\u0648\u0627\u0644 \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u062c\u062f\u06cc\u062f \u0628\u0647 \u0631\u0648\u0632 \u0634\u0648\u062f <code>value<\/code>.<\/p>\n<p>\u0645\u0646 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>setChoice<\/code> \u062c\u0647\u0634 \u0628\u0647 \u0645\u0627\u0698\u0648\u0644 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0628\u0647 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> mutations = {\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setSurveys<\/span>(<span class=\"hljs-params\">state, payload<\/span>)<\/span> {\n    state.surveys = payload.surveys\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setSurvey<\/span>(<span class=\"hljs-params\">state, payload<\/span>)<\/span> {\n    <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">setChoice<\/span>(<span class=\"hljs-params\">state, payload<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">const<\/span> { questionId, choice } = payload\n    <span class=\"hljs-keyword\">const<\/span> nQuestions = state.currentSurvey.questions.length\n    <span class=\"hljs-keyword\">for<\/span> (<span class=\"hljs-keyword\">let<\/span> i = <span class=\"hljs-number\">0<\/span>; i &lt; nQuestions; i++) {\n      <span class=\"hljs-keyword\">if<\/span> (state.currentSurvey.questions(i).id === questionId) {\n        state.currentSurvey.questions(i).choice = choice\n        <span class=\"hljs-keyword\">break<\/span>\n      }\n    }\n  }\n}\n<\/code><\/pre>\n<p>\u0622\u062e\u0631\u06cc\u0646 \u0686\u06cc\u0632\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u062f\u0631 \u0645\u0648\u0644\u0641\u0647 Survey \u0645\u0647\u0627\u062c\u0631\u062a \u06a9\u0631\u062f\u060c \u0630\u062e\u06cc\u0631\u0647 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u067e\u0627\u0633\u062e \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0627\u0633\u062a.  \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639\u060c \u062f\u0631 <code>Survey.vue<\/code>\u060c \u0628\u0627\u06cc\u062f \u0622\u0646 \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u0645 import \u0627\u0632 <code>saveSurveyResponse<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f AJAX<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { saveSurveyResponse } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/api'<\/span>\n<\/code><\/pre>\n<p>\u0648 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f import \u062f\u0631 \u0645\u0627\u0698\u0648\u0644 src\/store\/index.js \u0628\u0647 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { fetchSurveys, fetchSurvey, saveSurveyResponse } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/api'<\/span>\n<\/code><\/pre>\n<p>\u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u067e\u0627\u06cc\u06cc\u0646 \u062f\u0631 <code>actions<\/code> \u0645\u062a\u062f\u0647\u0627\u06cc \u0645\u0627\u0698\u0648\u0644 store\/index.js \u0628\u0627\u06cc\u062f \u0631\u0648\u0634 \u062c\u062f\u06cc\u062f\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u0645 <code>addSurveyResponse<\/code>\u060c \u06a9\u0647 \u062a\u0645\u0627\u0633 \u062e\u0648\u0627\u0647\u062f \u06af\u0631\u0641\u062a <code>saveSurveyResponse<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f AJAX \u0648 \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0633\u0631\u0648\u0631 \u0627\u062f\u0627\u0645\u0647 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> actions = {\n  <span class=\"hljs-function\"><span class=\"hljs-title\">loadSurveys<\/span>(<span class=\"hljs-params\">context<\/span>)<\/span> {\n    <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">loadSurvey<\/span>(<span class=\"hljs-params\">context, { id }<\/span>)<\/span> {\n    <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">addSurveyResponse<\/span>(<span class=\"hljs-params\">context<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> saveSurveyResponse(context.state.currentSurvey)\n  }\n}\n<\/code><\/pre>\n<p>\u0628\u0631\u06af\u0634\u062a \u062f\u0631 <code>Survey.vue<\/code> \u0641\u0627\u06cc\u0644 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a\u060c \u0628\u0627\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u0645 <code>handleSubmit<\/code> \u0631\u0648\u0634\u06cc \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0627\u06cc\u0646 \u0645\u062a\u062f \u0639\u0645\u0644 \u0628\u0647 \u062c\u0627\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u0633\u062a\u0642\u06cc\u0645 <code>saveSurveyResponse<\/code> \u0645\u0627\u0646\u0646\u062f:<\/p>\n<pre><code class=\"hljs\">methods: {\n    <span class=\"hljs-function\"><span class=\"hljs-title\">goToNextQuestion<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n    },\n    <span class=\"hljs-function\"><span class=\"hljs-title\">goToPreviousQuestion<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-comment\">\/\/ omitted for brevity<\/span>\n    },\n    <span class=\"hljs-function\"><span class=\"hljs-title\">handleSubmit<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-built_in\">this<\/span>.$store.dispatch(<span class=\"hljs-string\">'addSurveyResponse'<\/span>)\n        .then(<span class=\"hljs-function\">() =&gt;<\/span> <span class=\"hljs-built_in\">this<\/span>.$router.push(<span class=\"hljs-string\">'\/'<\/span>))\n    }\n}\n<\/code><\/pre>\n<h2 id=\"addingtheabilitytocreatenewsurveys\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86_%d9%82%d8%a7%d8%a8%d9%84%db%8c%d8%aa_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%86%d8%b8%d8%b1%d8%b3%d9%86%d8%ac%db%8c_%d8%ac%d8%af%db%8c%d8%af\"><\/span>\u0627\u0641\u0632\u0648\u062f\u0646 \u0642\u0627\u0628\u0644\u06cc\u062a \u0627\u06cc\u062c\u0627\u062f \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u0627\u0642\u06cc\u200c\u0645\u0627\u0646\u062f\u0647 \u0627\u06cc\u0646 \u067e\u0633\u062a \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u0642\u0627\u0628\u0644\u06cc\u062a \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f \u0628\u0627 \u0646\u0627\u0645\u060c \u0633\u0624\u0627\u0644\u0627\u062a \u0648 \u0627\u0646\u062a\u062e\u0627\u0628\u200c\u0647\u0627\u06cc \u0647\u0631 \u0633\u0624\u0627\u0644 \u0627\u062e\u062a\u0635\u0627\u0635 \u062e\u0648\u0627\u0647\u062f \u06cc\u0627\u0641\u062a.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0628\u0647 \u0646\u0627\u0645 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u0645 <code>NewSurvey.vue<\/code> \u062f\u0627\u062e\u0644 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0647\u0627  \u0628\u0639\u062f \u0645\u0646 \u0645\u06cc \u062e\u0648\u0627\u0647\u0645 import \u0648 \u06cc\u06a9 \u0645\u0633\u06cc\u0631 \u062c\u062f\u06cc\u062f \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f <code>router\/index.js<\/code> \u0645\u0627\u0698\u0648\u0644 \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ other import omitted for brevity<\/span>\n<span class=\"hljs-keyword\">import<\/span> NewSurvey <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/components\/NewSurvey'<\/span>\n\nVue.use(Router)\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-keyword\">new<\/span> Router({\n  <span class=\"hljs-attr\">routes<\/span>: (\n    {\n      <span class=\"hljs-attr\">path<\/span>: <span class=\"hljs-string\">'\/'<\/span>,\n      <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'Home'<\/span>,\n      <span class=\"hljs-attr\">component<\/span>: Home\n    }, {\n      <span class=\"hljs-attr\">path<\/span>: <span class=\"hljs-string\">'\/surveys\/:id'<\/span>,\n      <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'Survey'<\/span>,\n      <span class=\"hljs-attr\">component<\/span>: Survey\n    }, {\n      <span class=\"hljs-attr\">path<\/span>: <span class=\"hljs-string\">'\/surveys'<\/span>,\n      <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'NewSurvey'<\/span>,\n      <span class=\"hljs-attr\">component<\/span>: NewSurvey\n    }\n  )\n})\n<\/code><\/pre>\n<p>\u062f\u0631\u0648\u0646 <code>Header.vue<\/code> \u0641\u0627\u06cc\u0644\u060c \u0645\u0646 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u067e\u06cc\u0648\u0646\u062f \u0646\u0627\u0648 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u0645 \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u0645 \u0628\u0647 \u0646\u0645\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062d\u0631\u06a9\u062a \u06a9\u0646\u0645.<\/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\">nav<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"navbar is-light\"<\/span> <span class=\"hljs-attr\">role<\/span>=<span class=\"hljs-string\">\"navigation\"<\/span> <span class=\"hljs-attr\">aria-label<\/span>=<span class=\"hljs-string\">\"main navigation\"<\/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\">\"navbar-menu\"<\/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\">\"navbar-start\"<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">router-link<\/span> <span class=\"hljs-attr\">to<\/span>=<span class=\"hljs-string\">\"\/\"<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"navbar-item\"<\/span>&gt;<\/span>\n        Home\n      <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">router-link<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">router-link<\/span> <span class=\"hljs-attr\">to<\/span>=<span class=\"hljs-string\">\"\/surveys\"<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"navbar-item\"<\/span>&gt;<\/span>\n        Create Survey\n      <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">router-link<\/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>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">nav<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u062f\u0631 <code>NewSurvey.vue<\/code> \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a\u060c \u0645\u0646 \u0633\u0627\u062e\u062a\u0627\u0631 \u0627\u0635\u0644\u06cc \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0627\u06cc\u062c\u0627\u062f \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0631\u0627 \u062f\u0627\u0631\u0628\u0633\u062a \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\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\">section<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"hero is-primary\"<\/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\">\"hero-body\"<\/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\">\"container has-text-centered\"<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h2<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"title\"<\/span>&gt;<\/span>{{ name }}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h2<\/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>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">section<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">section<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"section\"<\/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\">\"container\"<\/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\">\"tabs is-centered is-fullwidth is-large\"<\/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\">li<\/span> <span class=\"hljs-attr\">:class<\/span>=<span class=\"hljs-string\">\"{'is-active': step == 'name'}\"<\/span> @<span class=\"hljs-attr\">click<\/span>=<span class=\"hljs-string\">\"step = 'name'\"<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span>&gt;<\/span>Name<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/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\">li<\/span> <span class=\"hljs-attr\">:class<\/span>=<span class=\"hljs-string\">\"{'is-active': step == 'questions'}\"<\/span> @<span class=\"hljs-attr\">click<\/span>=<span class=\"hljs-string\">\"step = 'questions'\"<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span>&gt;<\/span>Questions<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/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\">li<\/span> <span class=\"hljs-attr\">:class<\/span>=<span class=\"hljs-string\">\"{'is-active': step == 'review'}\"<\/span> @<span class=\"hljs-attr\">click<\/span>=<span class=\"hljs-string\">\"step = 'review'\"<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span>&gt;<\/span>Review<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/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\">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\">\"columns\"<\/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\">\"column is-half is-offset-one-quarter\"<\/span>&gt;<\/span>\n\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"name\"<\/span> <span class=\"hljs-attr\">v-show<\/span>=<span class=\"hljs-string\">\"step === 'name'\"<\/span>&gt;<\/span>\n              <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h2<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">'is-large'<\/span>&gt;<\/span>Add name<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h2<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"questions\"<\/span> <span class=\"hljs-attr\">v-show<\/span>=<span class=\"hljs-string\">\"step === 'questions'\"<\/span>&gt;<\/span>\n              <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h2<\/span>&gt;<\/span>Add Questions<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h2<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"review\"<\/span> <span class=\"hljs-attr\">v-show<\/span>=<span class=\"hljs-string\">\"step === 'review'\"<\/span>&gt;<\/span>\n              <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h2<\/span>&gt;<\/span>Review and Submit<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h2<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\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>&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\">section<\/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\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">step<\/span>: <span class=\"hljs-string\">'name'<\/span>\n    }\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=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">style<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p><img decoding=\"async\" class=\"img-responsive\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/single-page-apps-vue-and-flask-state-management-vuex-1.png\" alt=\"\u0633\u0627\u062e\u062a\u0627\u0631 \u062c\u062f\u06cc\u062f \u0646\u0638\u0631\u0633\u0646\u062c\u06cc\" title=\"\"><\/p>\n<p>\u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u062f\u0631 \u062a\u0635\u0648\u06cc\u0631 \u0628\u0627\u0644\u0627 \u0645\u06cc \u0628\u06cc\u0646\u06cc\u062f\u060c \u0633\u0647 \u062a\u0628 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0646\u0645\u0627\u06cc\u0634 \u0627\u062c\u0632\u0627\u06cc \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0646\u0627\u0645\u060c \u0633\u0624\u0627\u0644\u0627\u062a \u0648 \u0628\u0631\u0631\u0633\u06cc \u0642\u0628\u0644 \u0627\u0632 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0631\u062f\u0646 \u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0639\u0645\u0644\u06a9\u0631\u062f\u06cc \u06a9\u0647 \u0628\u0627\u0639\u062b \u062a\u0639\u0627\u0645\u0644 \u0627\u06cc\u0646 \u0645\u06cc \u0634\u0648\u062f page \u0628\u0631 \u0627\u0633\u0627\u0633 \u062f\u06cc\u06a9\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0648\u06cc \u0627\u0631\u0632\u0634 a <code>step<\/code> \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u06a9\u0647 \u062a\u0639\u06cc\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u062f\u0627\u0645 \u0628\u0631\u06af\u0647 \u0628\u0627\u06cc\u062f \u0641\u0639\u0627\u0644 \u0628\u0627\u0634\u062f. <code>step<\/code> \u0628\u0647 \u0635\u0648\u0631\u062a \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u0631\u0648\u06cc \u0628\u0631\u06af\u0647 \u00ab\u0646\u0627\u0645\u00bb \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f\u060c \u0627\u0645\u0627 \u0628\u0627 \u06a9\u0644\u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0645\u06cc\u200c\u0634\u0648\u062f \u0631\u0648\u06cc \u06cc\u06a9\u06cc \u0627\u0632 \u0628\u0631\u06af\u0647 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631  \u0646\u0647 \u062a\u0646\u0647\u0627 \u0627\u0631\u0632\u0634 <code>step<\/code> \u062a\u0639\u06cc\u06cc\u0646 \u06a9\u0646\u06cc\u062f \u06a9\u062f\u0627\u0645 \u0628\u0631\u06af\u0647 \u0628\u0627\u06cc\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f <code>is-active<\/code> \u06a9\u0644\u0627\u0633\u060c \u0627\u0645\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0648 \u067e\u0646\u0647\u0627\u0646 \u06a9\u0631\u062f\u0646 \u0622\u0646 \u0631\u0627 \u0646\u06cc\u0632 \u0647\u062f\u0627\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f <code>divs<\/code> \u06a9\u0647 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u0641\u0632\u0648\u062f\u0646 \u0646\u0627\u0645\u060c \u0633\u0624\u0627\u0644 \u0648 \u0628\u0631\u0631\u0633\u06cc \u0642\u0628\u0644 \u0627\u0632 \u0627\u0631\u0633\u0627\u0644 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u0645\u0646 \u0628\u0627 \u0646\u0627\u0645 UI \u0634\u0631\u0648\u0639 \u0645\u06cc \u06a9\u0646\u0645 <code>div<\/code> \u06a9\u0647 \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc \u062d\u0627\u0648\u06cc \u06cc\u06a9 \u0648\u0631\u0648\u062f\u06cc \u0645\u062a\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 a \u06af\u0631\u0647 \u062e\u0648\u0631\u062f\u0647 \u0627\u0633\u062a <code>name<\/code> \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 <code>v-model<\/code>\u060c \u0645\u0627\u0646\u0646\u062f:<\/p>\n<p><em>\u0628\u062e\u0634 \u0642\u0627\u0644\u0628<\/em><\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"name\"<\/span> <span class=\"hljs-attr\">v-show<\/span>=<span class=\"hljs-string\">\"step === 'name'\"<\/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\">\"field\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">label<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"label\"<\/span> <span class=\"hljs-attr\">for<\/span>=<span class=\"hljs-string\">\"name\"<\/span>&gt;<\/span>Survey name:<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">label<\/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\">\"control\"<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"text\"<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"input is-large\"<\/span> <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"name\"<\/span> <span class=\"hljs-attr\">v-model<\/span>=<span class=\"hljs-string\">\"name\"<\/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>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p><em>\u0628\u062e\u0634 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<\/em><\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n  <span class=\"hljs-keyword\">return<\/span> {\n    <span class=\"hljs-attr\">step<\/span>: <span class=\"hljs-string\">'name'<\/span>,\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">''<\/span>\n  }\n}\n<\/code><\/pre>\n<p>UI \u0633\u0648\u0627\u0644\u0627\u062a \u0648 \u067e\u0627\u0633\u062e \u0647\u0627 \u06a9\u0645\u06cc \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631\u06af\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0634\u062f.  \u0628\u0631\u0627\u06cc \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 <code>NewSurvey<\/code> \u062c\u0632\u0621 \u0633\u0627\u0632\u0645\u0627\u0646\u062f\u0647\u06cc \u0634\u062f\u0647 \u0648 \u06a9\u0627\u0647\u0634 \u067e\u06cc\u0686\u06cc\u062f\u06af\u06cc \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>NewQuestion.vue<\/code> \u062c\u0632\u0621 \u0641\u0627\u06cc\u0644 \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0648 \u0631\u0641\u062a\u0627\u0631 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0627\u0641\u0632\u0648\u062f\u0646 \u0633\u0624\u0627\u0644\u0627\u062a \u062c\u062f\u06cc\u062f \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u062a\u0639\u062f\u0627\u062f \u0645\u062a\u063a\u06cc\u0631\u06cc \u0627\u0632 \u067e\u0627\u0633\u062e \u0647\u0627.<\/p>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0627\u06cc\u062f \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0645 \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0645\u0624\u0644\u0641\u0647\u200c\u0647\u0627\u06cc NewSurvey \u0648 NewQuestion \u0627\u0632 \u062d\u0627\u0644\u062a \u0633\u0637\u062d \u0645\u0624\u0644\u0641\u0647 \u0628\u0631\u0627\u06cc \u062c\u062f\u0627 \u06a9\u0631\u062f\u0646 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 \u0627\u0632 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f \u0648\u0627\u0633\u0637\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0645 \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f \u0631\u0627 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u062f.  \u067e\u0633 \u0627\u0632 \u0627\u0631\u0633\u0627\u0644\u060c \u0645\u0646 \u0634\u0631\u06a9\u062a \u062e\u0648\u0627\u0647\u0645 \u06a9\u0631\u062f <code>Vuex<\/code>\u0630\u062e\u06cc\u0631\u0647 \u0648 \u0627\u0644\u06af\u0648\u06cc \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0627\u0631\u0633\u0627\u0644 \u06cc\u06a9 \u0627\u0642\u062f\u0627\u0645 \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f \u0628\u0647 \u0633\u0631\u0648\u0631 \u0648 \u0633\u067e\u0633 \u0628\u0647 \u0645\u0624\u0644\u0641\u0647 Home \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u062f\u0647\u06cc\u062f.  \u0633\u067e\u0633 \u0645\u0624\u0644\u0641\u0647 Home \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0647\u0645\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc\u200c\u0647\u0627 \u0627\u0632 \u062c\u0645\u0644\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f \u0631\u0627 \u0648\u0627\u06a9\u0634\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 <code>NewQuestion.vue<\/code> \u0641\u0627\u06cc\u0644\u060c \u0645\u0646 \u0627\u06a9\u0646\u0648\u0646 \u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u062f\u0627\u0631\u0645:<\/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\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"field\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">label<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"label is-large\"<\/span>&gt;<\/span>Question<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">label<\/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\">\"control\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"text\"<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"input is-large\"<\/span> <span class=\"hljs-attr\">v-model<\/span>=<span class=\"hljs-string\">\"question\"<\/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>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"field\"<\/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\">\"control\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"button is-large is-info\"<\/span> @<span class=\"hljs-attr\">click<\/span>=<span class=\"hljs-string\">\"addChoice\"<\/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\">\"icon is-small\"<\/span>&gt;<\/span>\n                <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">i<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"fa fa-plus-square-o fa-align-left\"<\/span> <span class=\"hljs-attr\">aria-hidden<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">i<\/span>&gt;<\/span>\n                <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>\n                <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span>&gt;<\/span>Add choice<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"button is-large is-primary @click=\"<\/span><span class=\"hljs-attr\">saveQuestion<\/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\">\"icon is-small\"<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">i<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"fa fa-check\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">i<\/span>&gt;<\/span>\n                <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>\n                <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span>&gt;<\/span>Save<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/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>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h2<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"label is-large\"<\/span> <span class=\"hljs-attr\">v-show<\/span>=<span class=\"hljs-string\">\"choices.length &gt; 0\"<\/span>&gt;<\/span>Question Choices<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h2<\/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\">\"field has-addons\"<\/span> <span class=\"hljs-attr\">v-for<\/span>=<span class=\"hljs-string\">\"(choice, idx) in choices\"<\/span> <span class=\"hljs-attr\">v-bind:key<\/span>=<span class=\"hljs-string\">\"idx\"<\/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\">\"control choice\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"text\"<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"input is-large\"<\/span> <span class=\"hljs-attr\">v-model<\/span>=<span class=\"hljs-string\">\"choices(idx)\"<\/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\">\"control\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"button is-large\"<\/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\">\"icon is-small\"<\/span> @<span class=\"hljs-attr\">click.stop<\/span>=<span class=\"hljs-string\">\"removeChoice(choice)\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">i<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"fa fa-times\"<\/span> <span class=\"hljs-attr\">aria-hidden<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">i<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/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>&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\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">question<\/span>: <span class=\"hljs-string\">''<\/span>,\n      <span class=\"hljs-attr\">choices<\/span>: ()\n    }\n  },\n  <span class=\"hljs-attr\">methods<\/span>: {\n    <span class=\"hljs-function\"><span class=\"hljs-title\">removeChoice<\/span>(<span class=\"hljs-params\">choice<\/span>)<\/span> {\n      <span class=\"hljs-keyword\">const<\/span> idx = <span class=\"hljs-built_in\">this<\/span>.choices.findIndex(<span class=\"hljs-function\"><span class=\"hljs-params\">c<\/span> =&gt;<\/span> c === choice)\n      <span class=\"hljs-built_in\">this<\/span>.choices.splice(idx, <span class=\"hljs-number\">1<\/span>)\n    },\n    <span class=\"hljs-function\"><span class=\"hljs-title\">saveQuestion<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-built_in\">this<\/span>.$emit(<span class=\"hljs-string\">'questionComplete'<\/span>, {\n        <span class=\"hljs-attr\">question<\/span>: <span class=\"hljs-built_in\">this<\/span>.question,\n        <span class=\"hljs-attr\">choices<\/span>: <span class=\"hljs-built_in\">this<\/span>.choices.filter(<span class=\"hljs-function\"><span class=\"hljs-params\">c<\/span> =&gt;<\/span> !!c)\n      })\n      <span class=\"hljs-built_in\">this<\/span>.question = <span class=\"hljs-string\">''<\/span>\n      <span class=\"hljs-built_in\">this<\/span>.choices = ()\n    },\n    <span class=\"hljs-function\"><span class=\"hljs-title\">addChoice<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n      <span class=\"hljs-built_in\">this<\/span>.choices.push(<span class=\"hljs-string\">''<\/span>)\n    }\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-selector-class\">.choice<\/span> {\n  <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">90%<\/span>;\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">style<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0628\u06cc\u0634\u062a\u0631 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627 \u0642\u0628\u0644\u0627\u064b \u0645\u0648\u0631\u062f \u0628\u062d\u062b \u0642\u0631\u0627\u0631 \u06af\u0631\u0641\u062a\u0647 \u0627\u0646\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0646 \u0641\u0642\u0637 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0644\u0627\u0635\u0647 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc \u06a9\u0646\u0645.  \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639\u060c \u0645\u0646 \u06cc\u06a9 <code>question<\/code> \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0628\u0647 \u0648\u0631\u0648\u062f\u06cc \u0645\u062a\u0646\u06cc \u0645\u062a\u0635\u0644 \u0645\u06cc \u0634\u0648\u062f <code>v-model=\"question\"<\/code> \u0627\u0631\u0627\u0626\u0647 \u0627\u062a\u0635\u0627\u0644 \u062f\u0627\u062f\u0647 \u062f\u0648 \u0637\u0631\u0641\u0647 \u0628\u06cc\u0646 \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 <code>question<\/code> \u0648 \u0639\u0646\u0635\u0631 \u0648\u0631\u0648\u062f\u06cc UI.<\/p>\n<p>\u062f\u0631 \u0632\u06cc\u0631 \u0648\u0631\u0648\u062f\u06cc \u0645\u062a\u0646 \u0633\u0648\u0627\u0644 \u062f\u0648 \u062f\u06a9\u0645\u0647 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.  \u06cc\u06a9\u06cc \u0627\u0632 \u062f\u06a9\u0645\u0647 \u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u0641\u0632\u0648\u062f\u0646 \u06cc\u06a9 \u0627\u0646\u062a\u062e\u0627\u0628 \u0627\u0633\u062a \u0648 \u0634\u0627\u0645\u0644 \u0634\u0646\u0648\u0646\u062f\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u0627\u0633\u062a <code>@click=\"addChoice\"<\/code> \u06a9\u0647 \u06cc\u06a9 \u0631\u0634\u062a\u0647 \u062e\u0627\u0644\u06cc \u0631\u0627 \u0631\u0648\u06cc <code>choices<\/code> \u0622\u0631\u0627\u06cc\u0647.  \u0631\u0627 <code>choices<\/code> \u0622\u0631\u0627\u06cc\u0647 \u0628\u0631\u0627\u06cc \u0647\u062f\u0627\u06cc\u062a \u0646\u0645\u0627\u06cc\u0634 \u0648\u0631\u0648\u062f\u06cc \u0647\u0627\u06cc \u0645\u062a\u0646 \u0627\u0646\u062a\u062e\u0627\u0628\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u0647\u0631 \u06a9\u062f\u0627\u0645 \u0628\u0647 \u0639\u0646\u0635\u0631 \u0645\u0631\u0628\u0648\u0637\u0647 \u062e\u0648\u062f \u06af\u0631\u0647 \u062e\u0648\u0631\u062f\u0647 \u0627\u0646\u062f <code>choices<\/code> \u0622\u0631\u0627\u06cc\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 <code>v-model=\"choices(idx)\"<\/code>.  \u0647\u0631 \u0648\u0631\u0648\u062f\u06cc \u0645\u062a\u0646 \u0627\u0646\u062a\u062e\u0627\u0628\u06cc \u0628\u0627 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 \u062c\u0641\u062a \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u0622\u0646 \u0631\u0627 \u0628\u0647 \u062f\u0644\u06cc\u0644 \u062d\u0636\u0648\u0631 \u0634\u0646\u0648\u0646\u062f\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f \u06a9\u0644\u06cc\u06a9 \u062d\u0630\u0641 \u06a9\u0646\u062f. <code>@click=\"removeChoice(choice)\"<\/code>.<\/p>\n<p>\u0622\u062e\u0631\u06cc\u0646 \u0642\u0637\u0639\u0647 UI \u062f\u0631 \u0645\u0624\u0644\u0641\u0647 NewQuestion \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0645\u0648\u0631\u062f \u0628\u062d\u062b \u0642\u0631\u0627\u0631 \u06af\u06cc\u0631\u062f\u060c \u062f\u06a9\u0645\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0627\u0633\u062a.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0633\u0624\u0627\u0644 \u062e\u0648\u062f \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f \u0648 \u062a\u0639\u062f\u0627\u062f \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u0645\u0648\u0631\u062f \u0646\u0638\u0631 \u062e\u0648\u062f \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0631\u0627\u06cc \u0630\u062e\u06cc\u0631\u0647 \u0633\u0624\u0627\u0644 \u0631\u0648\u06cc \u0622\u0646 \u06a9\u0644\u06cc\u06a9 \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0634\u0646\u0648\u0646\u062f\u0647 \u06a9\u0644\u06cc\u06a9 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f <code>@click=\"saveQuestion\"<\/code>.<\/p>\n<p>\u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u062f\u0631 \u062f\u0627\u062e\u0644 <code>saveQuestion<\/code> \u0631\u0648\u0634 \u0645\u0646 \u0645\u0648\u0636\u0648\u0639 \u062c\u062f\u06cc\u062f\u06cc \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u06a9\u0631\u062f\u0647 \u0627\u0645.  \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0645\u0646 \u0627\u0632 \u0631\u0648\u0634 \u062f\u06cc\u06af\u0631\u06cc \u0645\u062a\u0635\u0644 \u0628\u0647 \u0646\u0645\u0648\u0646\u0647 Vue \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0645.  \u0627\u06cc\u0646 \u0627\u0633\u062a <code>this.$emit(...)<\/code> \u0631\u0648\u0634 \u0633\u0627\u0637\u0639 \u06a9\u0646\u0646\u062f\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f  \u062f\u0631 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0627\u06cc\u0646\u060c \u0645\u0646 \u062f\u0631 \u062d\u0627\u0644 \u067e\u062e\u0634 \u0628\u0647 \u0645\u0624\u0644\u0641\u0647 \u0627\u0635\u0644\u06cc\u060c NewSurvey\u060c \u0631\u0648\u06cc\u062f\u0627\u062f \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>questionComplete<\/code> \u0648 \u0647\u0645\u0631\u0627\u0647 \u0628\u0627 \u0622\u0646 \u06cc\u06a9 \u0634\u06cc \u0645\u062d\u0645\u0648\u0644\u0647 \u0628\u0627 <code>question<\/code> \u0648 <code>choices<\/code>.<\/p>\n<p>\u0628\u0631\u06af\u0634\u062a \u062f\u0631 <code>NewSurvey.vue<\/code> \u0641\u0627\u06cc\u0644\u060c \u0645\u0646 \u0645\u06cc \u062e\u0648\u0627\u0647\u0645 import \u0627\u06cc\u0646 <code>NewQuestion<\/code> \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0646\u0645\u0648\u0646\u0647 Vue \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0628\u0647 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u062b\u0628\u062a \u06a9\u0646\u06cc\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> NewQuestion <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'@\/components\/NewQuestion'<\/span>\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-attr\">components<\/span>: { NewQuestion },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">step<\/span>: <span class=\"hljs-string\">'name'<\/span>,\n      <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">''<\/span>\n    }\n  }\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0633\u067e\u0633 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0639\u0646\u0635\u0631 \u0645\u0624\u0644\u0641\u0647 \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646 \u062f\u0631 \u0642\u0627\u0644\u0628 \u0642\u0631\u0627\u0631 \u062f\u0647\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"questions\"<\/span> <span class=\"hljs-attr\">v-show<\/span>=<span class=\"hljs-string\">\"step === 'questions'\"<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">new-question<\/span> <span class=\"hljs-attr\">v-\u0631\u0648\u06cc:questionComplete<\/span>=<span class=\"hljs-string\">\"appendQuestion\"<\/span>\/&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0645\u0646 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0647 \u0627\u0645 <code>v-\u0631\u0648\u06cc<\/code> \u062f\u0633\u062a\u0648\u0631\u0627\u0644\u0639\u0645\u0644 \u06af\u0648\u0634 \u062f\u0627\u062f\u0646 \u0628\u0647 <code>questionComplete<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0627\u0632 \u0645\u0624\u0644\u0641\u0647 NewQuestion \u0633\u0627\u0637\u0639 \u0634\u0648\u062f \u0648 \u06cc\u06a9 \u0641\u0631\u0627\u062e\u0648\u0627\u0646 \u0627\u0632 \u0622\u0646 \u062b\u0628\u062a \u0634\u0648\u062f <code>appendQuestion<\/code>.  \u0627\u06cc\u0646 \u0647\u0645\u0627\u0646 \u0645\u0641\u0647\u0648\u0645\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0628\u0627 \u0622\u0646 \u062f\u06cc\u062f\u06cc\u0645 <code>@click=\"someCallbackFunction\"<\/code> \u0634\u0646\u0648\u0646\u062f\u0647 \u0631\u0648\u06cc\u062f\u0627\u062f\u060c \u0627\u0645\u0627 \u0627\u06cc\u0646 \u0628\u0627\u0631 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0631\u0648\u06cc\u062f\u0627\u062f \u0633\u0641\u0627\u0631\u0634\u06cc \u0627\u0633\u062a.  \u0627\u062a\u0641\u0627\u0642\u0627 \u0645\u0646 \u0645\u06cc\u062a\u0648\u0646\u0633\u062a\u0645 \u0627\u0632 \u06a9\u0648\u062a\u0627\u0647\u062a\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0645 <code>@questionComplete=\"appendQuestion\"<\/code> \u0646\u062d\u0648\u060c \u0627\u0645\u0627 \u0645\u0646 \u0641\u06a9\u0631 \u06a9\u0631\u062f\u0645 \u06a9\u0647 \u062a\u0646\u0648\u0639\u06cc \u062f\u0631 \u0622\u0646 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u0645\u060c \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0647 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a \u0648\u0627\u0636\u062d \u062a\u0631 \u0627\u0633\u062a.<\/p>\n<p>\u0646\u06a9\u062a\u0647 \u0645\u0646\u0637\u0642\u06cc \u0628\u0639\u062f\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0622\u0646 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f <code>appendQuestion<\/code> \u0631\u0648\u0634 \u0628\u0647 <code>NewSurvey<\/code> \u062c\u0632\u0621 \u0647\u0645\u0631\u0627\u0647 \u0628\u0627 \u0627\u0644\u0641 <code>questions<\/code> \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u062d\u0641\u0638 \u0645\u062c\u0645\u0648\u0639\u0647 \u0633\u0648\u0627\u0644\u0627\u062a \u0648 \u067e\u0627\u0633\u062e \u0647\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f \u0634\u062f\u0647 \u062f\u0631 <code>NewQuestion<\/code> \u062c\u0632\u0621 \u0648 \u0633\u0627\u0637\u0639 \u0634\u062f\u0647 \u0628\u0647 <code>NewSurvey<\/code>.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n  <span class=\"hljs-attr\">components<\/span>: { NewQuestion },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">data<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> {\n      <span class=\"hljs-attr\">step<\/span>: <span class=\"hljs-string\">'name'<\/span>,\n      <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">''<\/span>,\n      <span class=\"hljs-attr\">question<\/span>: ()\n    }\n  },\n  <span class=\"hljs-attr\">methods<\/span>: {\n    <span class=\"hljs-function\"><span class=\"hljs-title\">appendQuestion<\/span>(<span class=\"hljs-params\">newQuestion<\/span>)<\/span> {\n      <span class=\"hljs-built_in\">this<\/span>.questions.push(newQuestion)\n    }\n  }\n}\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0645 \u0628\u0627 \u0645\u0631\u0648\u0631\u06af\u0631 \u062f\u0631 URL \u0630\u062e\u06cc\u0631\u0647 \u0648 \u0628\u0627\u0632\u062e\u0648\u0627\u0646\u06cc \u06a9\u0646\u0645 <code>localhost:8080\/#\/surveys<\/code> \u0633\u067e\u0633 \u06a9\u0644\u06cc\u06a9 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0628\u0631\u06af\u0647 \u0633\u0624\u0627\u0644\u0627\u062a\u060c \u0645\u062a\u0646 \u0633\u0624\u0627\u0644 \u0648 \u0686\u0646\u062f \u06af\u0632\u06cc\u0646\u0647 \u0631\u0627 \u0645\u0627\u0646\u0646\u062f \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p><img decoding=\"async\" class=\"img-responsive\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/single-page-apps-vue-and-flask-state-management-vuex-2.png\" alt=\"\u067e\u0631\u0633\u0634 \u0647\u0627 \u0648 \u067e\u0627\u0633\u062e \u0647\u0627\u06cc \u062c\u062f\u06cc\u062f \u0646\u0638\u0631\u0633\u0646\u062c\u06cc\" title=\"\"><\/p>\n<p>\u0622\u062e\u0631\u06cc\u0646 \u0628\u0631\u06af\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u062a\u06a9\u0645\u06cc\u0644 \u0634\u0648\u062f\u060c \u062a\u0628 Review \u0627\u0633\u062a.  \u0627\u06cc\u0646 page \u0633\u0648\u0627\u0644\u0627\u062a \u0648 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627 \u0631\u0627 \u0644\u06cc\u0633\u062a \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u062d\u0630\u0641 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.  \u0627\u06af\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627\u0636\u06cc \u0628\u0627\u0634\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u0631\u0627 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u062f \u0648 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0647 \u0645\u0624\u0644\u0641\u0647 Home \u0647\u062f\u0627\u06cc\u062a \u0645\u06cc\u200c\u0634\u0648\u062f.<\/p>\n<p>\u0628\u062e\u0634 \u0642\u0627\u0644\u0628 \u06a9\u062f \u0628\u0631\u0627\u06cc UI \u0628\u0631\u0631\u0633\u06cc \u0628\u0647 \u0634\u0631\u062d \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"review\"<\/span> <span class=\"hljs-attr\">v-show<\/span>=<span class=\"hljs-string\">\"step === 'review'\"<\/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\">li<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"question\"<\/span> <span class=\"hljs-attr\">v-for<\/span>=<span class=\"hljs-string\">\"(question, qIdx) in questions\"<\/span> <span class=\"hljs-attr\">:key<\/span>=<span class=\"hljs-string\">\"`question-${qIdx}`\"<\/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\">\"title\"<\/span>&gt;<\/span>\n        {{ question.question }}\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"icon is-medium is-pulled-right delete-question\"<\/span>\n          @<span class=\"hljs-attr\">click.stop<\/span>=<span class=\"hljs-string\">\"removeQuestion(question)\"<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">i<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"fa fa-times\"<\/span> <span class=\"hljs-attr\">aria-hidden<\/span>=<span class=\"hljs-string\">\"true\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">i<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/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\">ul<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">li<\/span> <span class=\"hljs-attr\">v-for<\/span>=<span class=\"hljs-string\">\"(choice , cIdx) in question.choices\"<\/span> <span class=\"hljs-attr\">:key<\/span>=<span class=\"hljs-string\">\"`choice-${cIdx}`\"<\/span>&gt;<\/span>\n          {{ cIdx + 1 }}. {{ choice }}\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\">li<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">ul<\/span>&gt;<\/span>\n\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"control\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"button is-large is-primary\"<\/span> @<span class=\"hljs-attr\">click<\/span>=<span class=\"hljs-string\">\"submitSurvey\"<\/span>&gt;<\/span>Submit<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0628\u062e\u0634 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u06a9\u0646\u0648\u0646 \u0641\u0642\u0637 \u0628\u0627\u06cc\u062f \u0628\u0627 \u0627\u0641\u0632\u0648\u062f\u0646 \u0622\u0646 \u0628\u0647 \u0631\u0648\u0632 \u0634\u0648\u062f <code>removeQuestion<\/code> \u0648 <code>submitSurvey<\/code> \u0631\u0648\u0634 \u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u0634\u0646\u0648\u0646\u062f\u06af\u0627\u0646 \u0631\u0648\u06cc\u062f\u0627\u062f \u06a9\u0644\u06cc\u06a9 \u0645\u0631\u0628\u0648\u0637\u0647 \u062e\u0648\u062f.<\/p>\n<pre><code class=\"hljs\">methods: {\n  <span class=\"hljs-function\"><span class=\"hljs-title\">appendQuestion<\/span>(<span class=\"hljs-params\">newQuestion<\/span>)<\/span> {\n    <span class=\"hljs-built_in\">this<\/span>.questions.push(newQuestion)\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">removeQuestion<\/span>(<span class=\"hljs-params\">question<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">const<\/span> idx = <span class=\"hljs-built_in\">this<\/span>.questions.findIndex(<span class=\"hljs-function\"><span class=\"hljs-params\">q<\/span> =&gt;<\/span> q.question === question.question)\n    <span class=\"hljs-built_in\">this<\/span>.questions.splice(idx, <span class=\"hljs-number\">1<\/span>)\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">submitSurvey<\/span>(<span class=\"hljs-params\"><\/span>)<\/span> {\n    <span class=\"hljs-built_in\">this<\/span>.$store.dispatch(<span class=\"hljs-string\">'submitNewSurvey'<\/span>, {\n      <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-built_in\">this<\/span>.name,\n      <span class=\"hljs-attr\">questions<\/span>: <span class=\"hljs-built_in\">this<\/span>.questions\n    }).then(<span class=\"hljs-function\">() =&gt;<\/span> <span class=\"hljs-built_in\">this<\/span>.$router.push(<span class=\"hljs-string\">'\/'<\/span>))\n  }\n}\n<\/code><\/pre>\n<p>\u0631\u0627 <code>removeQuestion(question)<\/code> \u0631\u0648\u0634 \u0633\u0648\u0627\u0644 \u0631\u0627 \u0627\u0632 \u0631\u0648\u06cc \u062d\u0630\u0641 \u0645\u06cc \u06a9\u0646\u062f <code>questions<\/code> \u0622\u0631\u0627\u06cc\u0647 \u0627\u06cc \u062f\u0631 \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u06a9\u0647 \u0628\u0647 \u0635\u0648\u0631\u062a \u0648\u0627\u06a9\u0646\u0634\u06cc \u0644\u06cc\u0633\u062a \u0633\u0648\u0627\u0644\u0627\u062a \u062a\u0634\u06a9\u06cc\u0644 \u062f\u0647\u0646\u062f\u0647 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0627\u0644\u0627 \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u06a9\u0646\u062f.  \u0631\u0627 <code>submitSurvey<\/code> \u0645\u062a\u062f \u06cc\u06a9 \u0631\u0648\u0634 \u0627\u0642\u062f\u0627\u0645 \u0628\u0647 \u0632\u0648\u062f\u06cc \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u062f <code>submitNewSurvey<\/code> \u0648 \u0645\u062d\u062a\u0648\u0627\u06cc \u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0633\u067e\u0633 \u0627\u0632 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f <code>this.$router.push(...)<\/code> \u0628\u0631\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0647 \u0645\u0624\u0644\u0641\u0647 Home.<\/p>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u062a\u0646\u0647\u0627 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f \u0627\u06cc\u062c\u0627\u062f \u0622\u0646 \u0627\u0633\u062a <code>submitNewSurvey<\/code> \u0631\u0648\u0634 \u0639\u0645\u0644 \u0648 \u062a\u0627\u0628\u0639 \u0633\u0627\u062e\u062a\u06af\u06cc AJAX \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0627\u0631\u0633\u0627\u0644 \u062c\u0639\u0644\u06cc \u0628\u0647 \u0633\u0631\u0648\u0631.  \u062f\u0631 \u0641\u0631\u0648\u0634\u06af\u0627\u0647 <code>actions<\/code> \u0634\u06cc \u0645\u0646 \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u0645.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> actions = {\n  <span class=\"hljs-comment\">\/\/ asynchronous operations<\/span>\n  <span class=\"hljs-function\"><span class=\"hljs-title\">loadSurveys<\/span>(<span class=\"hljs-params\">context<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> fetchSurveys()\n      .then(<span class=\"hljs-function\">(<span class=\"hljs-params\">response<\/span>) =&gt;<\/span> context.commit(<span class=\"hljs-string\">'setSurveys'<\/span>, { <span class=\"hljs-attr\">surveys<\/span>: response }))\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">loadSurvey<\/span>(<span class=\"hljs-params\">context, { id }<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> fetchSurvey(id)\n      .then(<span class=\"hljs-function\">(<span class=\"hljs-params\">response<\/span>) =&gt;<\/span> context.commit(<span class=\"hljs-string\">'setSurvey'<\/span>, { <span class=\"hljs-attr\">survey<\/span>: response }))\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">addSurveyResponse<\/span>(<span class=\"hljs-params\">context<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> saveSurveyResponse(context.state.currentSurvey)\n  },\n  <span class=\"hljs-function\"><span class=\"hljs-title\">submitNewSurvey<\/span>(<span class=\"hljs-params\">context, survey<\/span>)<\/span> {\n    <span class=\"hljs-keyword\">return<\/span> postNewSurvey(survey)\n  }\n}\n<\/code><\/pre>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u062f\u0631 <code>api\/index.js<\/code> \u0645\u0627\u0698\u0648\u0644 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u0645 <code>postNewSurvey(survey)<\/code> \u0639\u0645\u0644\u06a9\u0631\u062f AJAX \u0628\u0631\u0627\u06cc \u062a\u0645\u0633\u062e\u0631 POST \u0628\u0647 \u0633\u0631\u0648\u0631.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">postNewSurvey<\/span>(<span class=\"hljs-params\">survey<\/span>) <\/span>{\n  <span class=\"hljs-keyword\">return<\/span> <span class=\"hljs-keyword\">new<\/span> <span class=\"hljs-built_in\">Promise<\/span>(<span class=\"hljs-function\">(<span class=\"hljs-params\">resolve, reject<\/span>) =&gt;<\/span> {\n    <span class=\"hljs-built_in\">setTimeout<\/span>(<span class=\"hljs-function\">() =&gt;<\/span> {\n      <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">'Saving survey ...'<\/span>, survey)\n      resolve()\n    }, <span class=\"hljs-number\">300<\/span>)\n  })\n}\n<\/code><\/pre>\n<p>\u0645\u0646 \u062a\u0645\u0627\u0645 \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u067e\u0631\u0648\u0698\u0647 \u0627\u0645 \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u06a9\u0646\u0645 \u0648 URL \u0631\u0627 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0645\u06cc \u06a9\u0646\u0645 <code>localhost:8080\/#\/surveys<\/code>.  \u0633\u067e\u0633 \u06cc\u06a9 \u0646\u0627\u0645\u060c \u0686\u0646\u062f \u0633\u0648\u0627\u0644 \u0628\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u0648 \u0645\u06a9\u062b \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u062f\u0631 \u0628\u0631\u06af\u0647 \u0628\u0631\u0631\u0633\u06cc\u060c \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0632\u06cc\u0631 \u0631\u0627 \u0645\u06cc \u0628\u06cc\u0646\u0645:<\/p>\n<p><img decoding=\"async\" class=\"img-responsive\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/single-page-apps-vue-and-flask-state-management-vuex-3.png\" alt=\"\u0646\u0638\u0631\u0633\u0646\u062c\u06cc \u062c\u062f\u06cc\u062f \u0631\u0627 \u0645\u0631\u0648\u0631 \u06a9\u0646\u06cc\u062f\" title=\"\"><\/p>\n<h2 id=\"resources\"><span class=\"ez-toc-section\" id=\"%d9%85%d9%86%d8%a7%d8%a8%d8%b9\"><\/span>\u0645\u0646\u0627\u0628\u0639<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0631 \u0645\u0648\u0631\u062f \u0622\u0646 \u0628\u06cc\u0634\u062a\u0631 \u0628\u062f\u0627\u0646\u06cc\u062f <code>Vue.js<\/code> \u0648 \u0633\u0627\u062e\u062a\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u062c\u0644\u0648\u06cc\u06cc\u061f  \u0633\u0639\u06cc \u06a9\u0646\u06cc\u062f \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0639\u0645\u06cc\u0642\u200c\u062a\u0631 \u062f\u0631 \u0627\u06cc\u0646 \u0686\u0627\u0631\u0686\u0648\u0628 \u0638\u0627\u0647\u0631\u06cc \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<ul>\n<li><a class=\"udemy-link\" rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/stackabu.se\/vue-js-2-complete-guide\">Vue.js 2 &#8211; \u0631\u0627\u0647\u0646\u0645\u0627\u06cc \u06a9\u0627\u0645\u0644<\/a><\/li>\n<li><a class=\"udemy-link\" rel=\"nofollow noopener\" target=\"_blank\" href=\"http:\/\/stackabu.se\/ultimate-vue-js-2-developers-course\">\u062f\u0648\u0631\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 Ultimate Vue JS 2<\/a><\/li>\n<\/ul>\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 \u0637\u0648\u0644 \u0627\u06cc\u0646 \u067e\u0633\u062a \u0633\u0639\u06cc \u06a9\u0631\u062f\u0645 \u0622\u0646\u0686\u0647 \u0631\u0627 \u06a9\u0647 \u0641\u06a9\u0631 \u0645\u06cc \u06a9\u0646\u0645 \u0645\u0647\u0645\u062a\u0631\u06cc\u0646 \u062c\u0646\u0628\u0647 \u0647\u0627\u06cc \u06cc\u06a9 \u0645\u0648\u0636\u0648\u0639 \u0646\u0633\u0628\u062a\u0627\u064b \u0628\u0632\u0631\u06af \u0627\u0633\u062a \u067e\u0648\u0634\u0634 \u062f\u0647\u0645. <code>Vuex<\/code>. <code>Vuex<\/code> \u06cc\u06a9 \u0627\u0641\u0632\u0648\u062f\u0646\u06cc \u0628\u0633\u06cc\u0627\u0631 \u0642\u062f\u0631\u062a\u0645\u0646\u062f \u0628\u0647 a \u0627\u0633\u062a <code>Vue.js<\/code> \u067e\u0631\u0648\u0698\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0627\u0644\u06af\u0648\u06cc\u06cc \u0628\u0635\u0631\u06cc \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0633\u0627\u0632\u0645\u0627\u0646\u062f\u0647\u06cc \u0648 \u0627\u0633\u062a\u062d\u06a9\u0627\u0645 \u062a\u06a9 \u062a\u06a9 \u062f\u0627\u062f\u0647 \u0645\u062d\u0648\u0631 \u0645\u062a\u0648\u0633\u0637 \u200b\u200b\u062a\u0627 \u0628\u0632\u0631\u06af \u0631\u0627 \u0628\u0647\u0628\u0648\u062f \u0645\u06cc \u0628\u062e\u0634\u062f. page \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc.<\/p>\n<p>\u0645\u062b\u0644 \u0647\u0645\u06cc\u0634\u0647\u060c \u0645\u0645\u0646\u0648\u0646 \u06a9\u0647 \u062e\u0648\u0627\u0646\u062f\u06cc\u062f \u0648 \u0627\u0632 \u0646\u0638\u0631 \u062f\u0627\u062f\u0646 \u06cc\u0627 \u0627\u0646\u062a\u0642\u0627\u062f \u062f\u0631 \u0632\u06cc\u0631 \u062e\u062c\u0627\u0644\u062a \u0646\u06a9\u0634\u06cc\u062f.<\/p>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-27 03:49: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;16566&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;\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062a\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc \u0628\u0627 Vue.js \u0648 Flask: \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u06cc\u0627\u0644\u062a \u0628\u0627 Vuex. \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u0631\u0627\u06cc \u067e\u0633\u062a \u0633\u0648\u0645 \u0628\u0647 \u0645\u0646 \u067e\u06cc\u0648\u0633\u062a\u06cc\u062f \u0645\u062a\u0634\u06a9\u0631\u06cc\u0645 \u0631\u0648\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vue.js \u0648 Flask \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u062a\u0645\u0627\u0645 \u067e\u0634\u062a\u0647.  \u0645\u0648\u0636\u0648\u0639 \u0627\u0635\u0644\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f \u0631\u0648\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Vuex \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0648\u0636\u0639\u06cc\u062a \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627.  \u0628\u0631\u0627\u06cc \u0645\u0639\u0631\u0641\u06cc Vuex\u060c \u0631\u0648\u0634 \u0628\u0627\u0632\u0633\u0627\u0632\u06cc \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0647\u0627\u06cc Home \u0648 Survey \u0631\u0627 \u0627\u0632...&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\"> 15<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0648\u0644\u062a\u06cc \u0628\u0627 Vuex \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u0631\u0627\u06cc \u067e\u0633\u062a \u0633\u0648\u0645 \u0628\u0647 \u0645\u0646 \u067e\u06cc\u0648\u0633\u062a\u06cc\u062f \u0645\u062a\u0634\u06a9\u0631\u0645 \u0631\u0648\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0646 Vue.js \u0648 Flask \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 \u0648\u0628 \u062a\u0645\u0627\u0645 \u067e\u0634\u062a\u0647. \u0645\u0648\u0636\u0648\u0639 \u0627\u0635\u0644\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f \u0631\u0648\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u0646 Vuex \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0648\u0636\u0639\u06cc\u062a \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627. \u0645\u0639\u0631\u0641\u06cc Vuex\u060c \u0645\u0646 \u0646\u0634\u0627\u0646 \u062e\u0648\u0627\u0647\u0645 \u062f\u0627\u062f \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0645\u0648\u0644\u0641\u0647 \u0647\u0627\u06cc Home \u0648 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[3292,2054,2632,4605,3294,4037,1840,2341,1776,1786,2271,1967,2051,4039,1789,2140,1779,4604,1814,1909,1841,1807,2276,2917,1766,4601,3561,2843,1881,1103,2275,2750,1803,2123,2667,1859,4600,2376,3293,1969,4602,432,3372,2321,4603,2322,2250,1785,2829,4043],"class_list":["post-16566","post","type-post","status-publish","format-standard","hentry","category-javascript","category-programming","tag-vue","tag-flask","tag-home","tag-survey","tag-vue-js","tag-vuex","tag-1840","tag-2341","tag-1776","tag-1786","tag-2271","tag----nodejs","tag-2051","tag-4039","tag-1789","tag-2140","tag-1779","tag-4604","tag-1814","tag-1909","tag-1841","tag-1807","tag-2276","tag-2917","tag-1766","tag-4601","tag-3561","tag-2843","tag-1881","tag-1103","tag-2275","tag-2750","tag-1803","tag-2123","tag-2667","tag---nodejs","tag-4600","tag-2376","tag-3293","tag-1969","tag-4602","tag-432","tag-3372","tag-2321","tag-4603","tag-2322","tag--nodejs","tag-1785","tag-2829","tag-4043"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16566","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=16566"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16566\/revisions"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=16566"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=16566"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=16566"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}