{"id":16457,"date":"2024-01-25T10:00:11","date_gmt":"2024-01-25T06:30:11","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/"},"modified":"2024-01-25T10:00:11","modified_gmt":"2024-01-25T06:30:11","slug":"%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/","title":{"rendered":"\u0633\u0627\u062e\u062a\u0646 API \u0647\u0627\u06cc GraphQL \u0628\u0627 Vue.js \u0648 Apollo ClientGraphQL \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u06af\u0631\u0627\u0641\u06af\u0631\u0627 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 \u0641\u06cc\u0633 \u0628\u0648\u06a9 \u0646\u0648\u0634\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0628\u0631\u062e\u0644\u0627\u0641 REST API \u0647\u0627\u060c GraphQL \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 API \u0631\u0627 \u06a9\u0627\u0631\u0622\u0645\u062f\u062a\u0631 \u0648 \u0647\u0645\u0627\u0647\u0646\u06af \u0628\u0627 \u0645\u062f\u0644 \u0647\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f.  \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc GraphQL \u0628\u0631\u062e\u0644\u0627\u0641 REST\u060c \u062a\u0646\u0647\u0627 \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0642\u0631\u0627\u0631 \u0627\u0633\u062a \u062a\u0645\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627 \u0628\u0647 \u0622\u0646\u062c\u0627 \u0627\u0631\u0633\u0627\u0644 \u0634\u0648\u0646\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0628\u0647 \u062c\u0627\u06cc &#8230;"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c\" >\u0645\u0639\u0631\u0641\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d9%88%db%8c%da%98%da%af%db%8c_%d9%87%d8%a7%db%8c_graphql\" >\u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc GraphQL<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d9%be%d8%b1%d8%b3_%d9%88_%d8%ac%d9%88%d9%87%d8%a7\" >\u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%ac%d9%87%d8%b4_%d9%87%d8%a7\" >\u062c\u0647\u0634 \u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%a7%d8%b4%d8%aa%d8%b1%d8%a7%da%a9_%d9%87%d8%a7\" >\u0627\u0634\u062a\u0631\u0627\u06a9 \u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%a7%d9%86%d9%88%d8%a7%d8%b9_%d9%88_%d9%88%d8%b1%d9%88%d8%af%db%8c_%d9%87%d8%a7\" >\u0627\u0646\u0648\u0627\u0639 \u0648 \u0648\u0631\u0648\u062f\u06cc \u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%ad%d9%84_%da%a9%d9%86%d9%86%d8%af%d9%87_%d9%87%d8%a7\" >\u062d\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0647\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%be%d8%b1%d9%88%da%98%d9%87_%d9%85%d8%a7\" >\u0627\u06cc\u062c\u0627\u062f \u067e\u0631\u0648\u0698\u0647 \u0645\u0627<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d9%85%d8%b4%d8%aa%d8%b1%db%8c_%d8%a2%d9%be%d9%88%d9%84%d9%88\" >\u0645\u0634\u062a\u0631\u06cc \u0622\u067e\u0648\u0644\u0648<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d9%be%db%8c%da%a9%d8%b1%d8%a8%d9%86%d8%af%db%8c_%d8%a2%d9%be%d9%88%d9%84%d9%88\" >\u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0622\u067e\u0648\u0644\u0648<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa_%d8%a7%db%8c%d8%a7%d9%84%d8%aa_%d8%a8%d8%a7_apollo_client\" >\u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u06cc\u0627\u0644\u062a \u0628\u0627 Apollo Client<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-12\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%be%d8%b1%d8%b3_%d9%88_%d8%ac%d9%88\" >\u0627\u06cc\u062c\u0627\u062f \u067e\u0631\u0633 \u0648 \u062c\u0648<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_%d8%ac%d9%87%d8%b4\" >\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062c\u0647\u0634<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-14\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_graphql_%d8%af%d8%b1_%d8%a7%d8%ac%d8%b2%d8%a7%db%8c_vue\" >\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 GraphQL \u062f\u0631 \u0627\u062c\u0632\u0627\u06cc Vue<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-15\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%b4%db%8c_%d8%a2%d9%be%d9%88%d9%84%d9%88\" >\u0634\u06cc \u0622\u067e\u0648\u0644\u0648<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-16\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d8%a7%d8%ac%d8%b2%d8%a7%db%8c_%d8%a2%d9%be%d9%88%d9%84%d9%88\" >\u0627\u062c\u0632\u0627\u06cc \u0622\u067e\u0648\u0644\u0648<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-17\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b3%d8%a7%d8%ae%d8%aa%d9%86-api-%d9%87%d8%a7%db%8c-graphql-%d8%a8%d8%a7-vue-js-%d9%88-apollo-clientgraphql-%db%8c%da%a9-%d8%b2%d8%a8%d8%a7%d9%86-%d9%be%d8%b1%d8%b3-%d9%88-%d8%ac%d9%88-%da%af%d8%b1\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 9<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<h2 id=\"introduction\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c\"><\/span>\u0645\u0639\u0631\u0641\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/graphql.org\/learn\/\">GraphQL<\/a> \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u06af\u0631\u0627\u0641 \u0645\u062d\u0648\u0631 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 \u0641\u06cc\u0633 \u0628\u0648\u06a9 \u0646\u0648\u0634\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0628\u0631\u062e\u0644\u0627\u0641 REST API \u0647\u0627\u060c GraphQL \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 API \u0631\u0627 \u06a9\u0627\u0631\u0622\u0645\u062f\u062a\u0631 \u0648 \u0647\u0645\u0627\u0647\u0646\u06af \u0628\u0627 \u0645\u062f\u0644 \u0647\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<h2 id=\"graphqlfeatures\"><span class=\"ez-toc-section\" id=\"%d9%88%db%8c%da%98%da%af%db%8c_%d9%87%d8%a7%db%8c_graphql\"><\/span>\u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc GraphQL<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<ul>\n<li>\u0628\u0631 \u062e\u0644\u0627\u0641 <strong>\u0628\u0627\u0642\u06cc \u0645\u0627\u0646\u062f\u0647<\/strong>\u060c \u062a\u0646\u0647\u0627 \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0642\u0631\u0627\u0631 \u0627\u0633\u062a \u062a\u0645\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627 \u0628\u0647 \u0622\u0646\u062c\u0627 \u0627\u0631\u0633\u0627\u0644 \u0634\u0648\u0646\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0628\u0647 \u062c\u0627\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648 <code>\/users<\/code> \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646\u060c \u06cc\u0627 <code>\/user\/:id<\/code> \u0628\u0631\u0627\u06cc \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u062e\u0627\u0635\u060c \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 \u0622\u0646 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f <code>\/graphql<\/code> \u0628\u0631\u0627\u06cc \u062a\u0645\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627<\/li>\n<li>\u062f\u0631 GraphQL\u060c \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u0632 \u06cc\u06a9 \u067e\u0627\u0633\u062e \u0628\u0631\u0645\u06cc\u200c\u06af\u0631\u062f\u0646\u062f\u060c \u062a\u0648\u0633\u0637 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0628\u06cc\u0627\u0646 \u0634\u062f\u0647 \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0648 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646 \u0622\u0646 \u0631\u0627 \u0637\u0648\u0631\u06cc \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f \u06a9\u0647 \u0641\u0642\u0637 \u0686\u0646\u062f \u0648\u06cc\u0698\u06af\u06cc \u062f\u0627\u062f\u0647 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u067e\u0631\u0633\u200c\u0648\u200c\u062c\u0648\u0647\u0627 \u062f\u0631 GraphQL \u0639\u0645\u0644\u06a9\u0631\u062f \u0628\u0647\u062a\u0631\u06cc \u062f\u0627\u0631\u0646\u062f.<\/li>\n<li>\u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u062a\u0646\u0638\u06cc\u0645 \u0627\u0641\u0639\u0627\u0644 \u0645\u062a\u062f \u062f\u0631 GraphQL \u0646\u06cc\u0633\u062a.  \u06a9\u0644\u0645\u0627\u062a \u06a9\u0644\u06cc\u062f\u06cc \u0645\u0627\u0646\u0646\u062f <strong>\u067e\u0631\u0633 \u0648 \u062c\u0648<\/strong> \u06cc\u0627 <strong>\u062c\u0647\u0634<\/strong> \u062a\u0635\u0645\u06cc\u0645 \u062e\u0648\u0627\u0647\u062f \u06af\u0631\u0641\u062a \u06a9\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0686\u0647 \u06a9\u0627\u0631\u06cc \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u062f.<\/li>\n<li>\u0645\u0633\u06cc\u0631\u0647\u0627\u06cc REST API \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u062a\u0648\u0633\u0637 \u06cc\u06a9 \u06a9\u0646\u062a\u0631\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0645\u0633\u06cc\u0631 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u0634\u0648\u0646\u062f.  \u062f\u0631 GraphQL \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u067e\u0631\u0633\u200c\u0648\u062c\u0648 \u062c\u0647\u0634\u200c\u0647\u0627\u06cc \u0645\u062a\u0639\u062f\u062f \u0631\u0627 \u0631\u0627\u0647\u200c\u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u062f \u0648 \u06cc\u06a9 \u067e\u0627\u0633\u062e \u062a\u0631\u06a9\u06cc\u0628\u06cc \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u0645\u062a\u0639\u062f\u062f \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u06cc\u062f.<\/li>\n<\/ul>\n<h3 id=\"queries\"><span class=\"ez-toc-section\" id=\"%d9%be%d8%b1%d8%b3_%d9%88_%d8%ac%d9%88%d9%87%d8%a7\"><\/span>\u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0622 <em>\u067e\u0631\u0633 \u0648 \u062c\u0648<\/em> \u06cc\u06a9 \u0631\u0648\u0634 GraphQL \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0645\u0627 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f <strong>\u06af\u0631\u0641\u062a\u0646<\/strong> \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 API \u0645\u0627  \u062d\u062a\u06cc \u0627\u06af\u0631 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0641\u06cc\u0644\u062a\u0631 \u06a9\u0631\u062f\u0646\u060c \u0633\u0641\u0627\u0631\u0634 \u062f\u0627\u062f\u0646 \u06cc\u0627 \u062c\u0633\u062a\u062c\u0648\u06cc \u0633\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0633\u0646\u062f \u062e\u0627\u0635 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u062f\u060c \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0646\u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0627\u06cc\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u062f.<\/p>\n<h3 id=\"mutations\"><span class=\"ez-toc-section\" id=\"%d8%ac%d9%87%d8%b4_%d9%87%d8%a7\"><\/span>\u062c\u0647\u0634 \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p><strong>\u062c\u0647\u0634 \u0647\u0627<\/strong> \u0647\u0645\u0647 \u0686\u06cc\u0632 \u0647\u0633\u062a\u0646\u062f <em>\u0646\u0647<\/em> \u0686\u0647 \u0686\u06cc\u0632\u06cc \u0628\u0647 \u06cc\u06a9 \u0641\u0639\u0644 GET \u062f\u0631 API\u0647\u0627\u06cc \u0645\u0639\u0645\u0648\u0644\u06cc \u0627\u0634\u0627\u0631\u0647 \u062f\u0627\u0631\u062f.  \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc\u060c \u0627\u06cc\u062c\u0627\u062f \u06cc\u0627 \u062d\u0630\u0641 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 API \u0645\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u062c\u0647\u0634 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f<\/p>\n<h3 id=\"subscriptions\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b4%d8%aa%d8%b1%d8%a7%da%a9_%d9%87%d8%a7\"><\/span>\u0627\u0634\u062a\u0631\u0627\u06a9 \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0633\u0648\u06a9\u062a \u0647\u0627\u06cc \u0648\u0628\u060c \u0627\u0634\u062a\u0631\u0627\u06a9 \u0628\u0647 \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u06cc\u0646 \u0645\u0634\u062a\u0631\u06cc \u0648 \u0633\u0631\u0648\u0631 \u0627\u0634\u0627\u0631\u0647 \u062f\u0627\u0631\u062f.<\/p>\n<p>\u0633\u0631\u0648\u0631 \u062f\u0627\u0626\u0645\u0627\u064b \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u062c\u0647\u0634 \u0647\u0627 \u06cc\u0627 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u06cc\u06a9 \u0627\u0634\u062a\u0631\u0627\u06a9 \u062e\u0627\u0635 \u0645\u062a\u0635\u0644 \u0645\u06cc \u0634\u0648\u0646\u062f \u0648 \u0647\u0631\u06af\u0648\u0646\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0631\u0627 \u062f\u0631 \u0632\u0645\u0627\u0646 \u0648\u0627\u0642\u0639\u06cc \u0628\u0647 \u0645\u0634\u062a\u0631\u06cc \u0645\u0646\u062a\u0642\u0644 \u0645\u06cc \u06a9\u0646\u0646\u062f.  \u0627\u0634\u062a\u0631\u0627\u06a9 \u0647\u0627 \u0628\u06cc\u0634\u062a\u0631 \u0628\u0631\u0627\u06cc \u0648\u06cc\u062c\u062a \u0647\u0627\/\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0628\u0644\u0627\u062f\u0631\u0646\u06af \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/p>\n<h3 id=\"typesandinputs\"><span class=\"ez-toc-section\" id=\"%d8%a7%d9%86%d9%88%d8%a7%d8%b9_%d9%88_%d9%88%d8%b1%d9%88%d8%af%db%8c_%d9%87%d8%a7\"><\/span>\u0627\u0646\u0648\u0627\u0639 \u0648 \u0648\u0631\u0648\u062f\u06cc \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u0645 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627 \u0648 \u062c\u0647\u0634 \u0647\u0627\u06cc \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f process \u062f\u0627\u062f\u0647 \u0647\u0627 \u0628\u0631\u0627\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0627\u0632 \u06cc\u06a9 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647\u060c <code>types<\/code> \u0628\u0633\u06cc\u0627\u0631 \u0634\u0628\u06cc\u0647 \u06cc\u06a9 ORM \u0645\u062f\u0644 \u0628\u0631\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u0647\u0627\u06cc \u062f\u0627\u062f\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f.  \u0628\u0627 \u062a\u0646\u0638\u06cc\u0645 <strong>\u0627\u0646\u0648\u0627\u0639<\/strong> \u062a\u0627 \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0646\u0648\u0639 \u0645\u062a\u063a\u06cc\u0631\u06cc \u0631\u0627 \u06a9\u0647 \u0631\u0632\u0648\u0644\u0648\u0631\u0647\u0627\u06cc \u0645\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0646\u062f \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u0645\u0634\u0627\u0628\u0647\u060c \u0645\u0627 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645 \u06a9\u0647 \u0627\u0646\u0648\u0627\u0639 \u0648\u0631\u0648\u062f\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u062d\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0647\u0627\u06cc \u062e\u0648\u062f \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0645\u062b\u0644\u0627 \u0632\u0648\u062c \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>types<\/code> \u0648 <code>inputs<\/code>:<\/p>\n<pre><code class=\"hljs\">type User {\n  id: ID\n  name: String!\n  age: Int!\n  address: Address\n  followers: (ID)\n}\n\ntype Address {\n  street: String\n  city: String\n  country: String\n}\n\ninput UserInput {\n  name: String!\n  age: Int!\n}\n\ntype Query {\n  getAllUsers: (User)\n}\n\ntype Mutation {\n  createUser(user: UserInput!): ID\n}\n<\/code><\/pre>\n<p>\u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647\u200c\u0639\u0646\u0648\u0627\u0646 \u0646\u0648\u0639 \u062e\u0648\u062f\u060c \u062c\u062f\u0627 \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647\u060c \u0646\u0648\u0639 \u0633\u0641\u0627\u0631\u0634\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f\u060c \u0645\u0627\u0646\u0646\u062f:<\/p>\n<ul>\n<li>\u0631\u0634\u062a\u0647<\/li>\n<li>\u0628\u06cc\u0646 \u0627\u0644\u0645\u0644\u0644\u06cc<\/li>\n<li>\u0634\u0646\u0627\u0648\u0631<\/li>\n<li>\u0628\u0648\u0644\u06cc<\/li>\n<li>\u0634\u0646\u0627\u0633\u0647<\/li>\n<\/ul>\n<p>\u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0622\u0631\u0627\u06cc\u0647 \u0627\u06cc \u0627\u0632 \u0646\u0648\u0639 \u062e\u0627\u0635\u06cc \u0628\u0627\u0634\u0646\u062f \u06a9\u0647 \u062a\u0648\u0633\u0637 \u0628\u0631\u0627\u06a9\u062a \u0647\u0627 \u062a\u0639\u06cc\u06cc\u0646 \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u062f\u0631 \u0645\u062b\u0627\u0644 \u0628\u0627\u0644\u0627 \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u0648\u0636\u0639\u06cc\u062a \u0627\u062c\u0628\u0627\u0631\u06cc \u06cc\u06a9 \u0645\u0644\u06a9 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f <code>!<\/code>\u060c \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u06a9\u0647 \u0645\u0644\u06a9 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.<\/p>\n<h3 id=\"resolvers\"><span class=\"ez-toc-section\" id=\"%d8%ad%d9%84_%da%a9%d9%86%d9%86%d8%af%d9%87_%d9%87%d8%a7\"><\/span>\u062d\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u06cc\u0646\u0647\u0627 \u0627\u0642\u062f\u0627\u0645\u0627\u062a\u06cc \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u0647\u0646\u06af\u0627\u0645 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u06a9\u0648\u0626\u0631\u06cc \u0647\u0627 \u0648 \u062c\u0647\u0634 \u0647\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u0646\u062f.<\/p>\n<p><code>getAllUsers<\/code>  \u0648 <code>createUser<\/code> \u0642\u0631\u0627\u0631 \u0627\u0633\u062a \u0628\u0647 \u06cc\u06a9 \u062d\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0645\u062a\u0635\u0644 \u0634\u0648\u0646\u062f \u06a9\u0647 \u0645\u062d\u0627\u0633\u0628\u0627\u062a \u0648\u0627\u0642\u0639\u06cc \u0648 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<h3 id=\"creatingourproject\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%be%d8%b1%d9%88%da%98%d9%87_%d9%85%d8%a7\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u067e\u0631\u0648\u0698\u0647 \u0645\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634\u060c \u0645\u0627 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 Vue.js \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <strong>Vue CLI 3.0<\/strong>\u060c \u06a9\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u0628\u0627 \u0633\u0627\u062e\u062a\u0627\u0631 \u067e\u0648\u0634\u0647 \u0627\u06cc \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0628\u0648\u062a \u0627\u0633\u062a\u0631\u067e \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<p><img decoding=\"async\" class=\"img-responsive\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/building-graphql-apis-vuejs-apollo-client-1.png\" alt=\"\" title=\"\"><\/p>\n<p>\u0627\u06af\u0631 \u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u067e\u0631\u0648\u0698\u0647 \u0628\u0647 \u06a9\u0645\u06a9 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0628\u0631\u0627\u06cc \u0631\u0627\u0628\u0637 \u062e\u0637 \u0641\u0631\u0645\u0627\u0646 \u0646\u06af\u0627\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0627 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0633\u0631\u0648\u06cc\u0633 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm run serve<\/span>\n<\/code><\/pre>\n<h2 id=\"apolloclient\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b4%d8%aa%d8%b1%db%8c_%d8%a2%d9%be%d9%88%d9%84%d9%88\"><\/span>\u0645\u0634\u062a\u0631\u06cc \u0622\u067e\u0648\u0644\u0648<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.apollographql.com\/\">\u0645\u0634\u062a\u0631\u06cc \u0622\u067e\u0648\u0644\u0648<\/a> \u0627\u0628\u0632\u0627\u0631\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 front-end \u0628\u0647 \u0627\u0631\u0645\u063a\u0627\u0646 \u0645\u06cc \u0622\u0648\u0631\u062f \u062a\u0627 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\/\u062c\u0647\u0634 \u0647\u0627\u06cc GraphQL \u0631\u0627 \u0622\u0633\u0627\u0646 \u062a\u0631 \u06a9\u0646\u062f.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u06a9\u0644\u0627\u06cc\u0646\u062a HTTP \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0628\u0647 GraphQL API \u0645\u062a\u0635\u0644 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0642\u0627\u0628\u0644\u06cc\u062a \u0647\u0627\u06cc \u06a9\u0634\u060c \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627 \u0648 \u062d\u062a\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062d\u0627\u0644\u062a \u0631\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634\u060c <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/Akryum\/vue-apollo\">Vue-Apollo<\/a> \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u062f \u0634\u062f\u060c \u06a9\u0647 \u0627\u062f\u063a\u0627\u0645 Apollo \u0627\u0633\u062a \u06a9\u0647 \u0645\u062e\u0635\u0648\u0635 Vue.js \u0637\u0631\u0627\u062d\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<h3 id=\"apolloconfiguration\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%da%a9%d8%b1%d8%a8%d9%86%d8%af%db%8c_%d8%a2%d9%be%d9%88%d9%84%d9%88\"><\/span>\u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0622\u067e\u0648\u0644\u0648<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0622\u067e\u0648\u0644\u0648\u060c \u0628\u0627\u06cc\u062f \u0686\u0646\u062f \u0628\u0633\u062a\u0647 \u0646\u0635\u0628 \u0634\u0648\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install apollo-client apollo-link-http apollo-cache-inmemory vue-apollo graphql graphql-tag<\/span>\n<\/code><\/pre>\n<p>\u062f\u0627\u062e\u0644 a <code>\/graphql<\/code> \u067e\u0648\u0634\u0647 \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <code>apollo.js<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ apollo.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> { ApolloClient } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'apollo-client'<\/span>\n<span class=\"hljs-keyword\">import<\/span> { HttpLink } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'apollo-link-http'<\/span>\n<span class=\"hljs-keyword\">import<\/span> { InMemoryCache } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'apollo-cache-inmemory'<\/span>\n<span class=\"hljs-keyword\">import<\/span> VueApollo <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'vue-apollo'<\/span>\n\n<span class=\"hljs-keyword\">const<\/span> httpLink = <span class=\"hljs-keyword\">new<\/span> HttpLink({\n    <span class=\"hljs-attr\">uri<\/span>: process.env.VUE_APP_GRAPHQL_ENDPOINT\n})\n\n<span class=\"hljs-comment\">\/\/ Create the apollo client<\/span>\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">const<\/span> apolloClient = <span class=\"hljs-keyword\">new<\/span> ApolloClient({\n    <span class=\"hljs-attr\">link<\/span>: httpLink,\n    <span class=\"hljs-attr\">cache<\/span>: <span class=\"hljs-keyword\">new<\/span> InMemoryCache(),\n    <span class=\"hljs-attr\">connectToDevTools<\/span>: <span class=\"hljs-literal\">true<\/span>\n})\n\n<span class=\"hljs-comment\">\/\/ Install the Vue plugin<\/span>\n\nVue.use(VueApollo)\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">const<\/span> apolloProvider = <span class=\"hljs-keyword\">new<\/span> VueApollo({\n    <span class=\"hljs-attr\">defaultClient<\/span>: apolloClient\n})\n<\/code><\/pre>\n<p><code>HttpLink<\/code>  \u06cc\u06a9 \u0634\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0646\u06cc\u0627\u0632 \u0628\u0647 a <code>uri<\/code> \u0648\u06cc\u0698\u06af\u06cc\u060c \u06a9\u0647 \u0628\u0647 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc GraphQL \u0627\u0632 API \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0634\u0627\u0631\u0647 \u062f\u0627\u0631\u062f.  \u0633\u0627\u0628\u0642: <code>localhost:8081\/graphql<\/code><\/p>\n<p>\u0633\u067e\u0633\u060c \u06cc\u06a9 \u062c\u062f\u06cc\u062f <code>ApolloClient<\/code> \u0646\u0645\u0648\u0646\u0647 \u0628\u0627\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u0634\u0648\u062f\u060c \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646 \u067e\u06cc\u0648\u0646\u062f\u060c \u0646\u0645\u0648\u0646\u0647 \u062d\u0627\u0641\u0638\u0647 \u067e\u0646\u0647\u0627\u0646 \u0648 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0645\u0627 \u0631\u0627 \u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>ApolloClient<\/code> \u062f\u0627\u062e\u0644 a <code>VueApollo<\/code> \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0642\u0644\u0627\u0628 \u0647\u0627\u06cc \u0622\u0646 \u062f\u0631 \u062f\u0627\u062e\u0644 \u0627\u062c\u0632\u0627\u06cc Vue \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<h4 id=\"globalerrorhandling\">\u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627\u06cc \u062c\u0647\u0627\u0646\u06cc<\/h4>\n<p>\u0631\u0627\u0647\u06cc \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u062e\u0637\u0627\u0647\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0633\u0631\u0627\u0633\u0631\u06cc \u062f\u0631 \u062f\u0627\u062e\u0644 \u0641\u0627\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0628\u0633\u062a\u0647 npm \u0628\u0647 \u0646\u0627\u0645 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u0645 <code>apollo-link-error<\/code>\u060c \u06a9\u0647 \u062e\u0637\u0627\u0647\u0627\u06cc \u0634\u0628\u06a9\u0647 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u0648 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ apollo.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> { ApolloClient } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'apollo-client'<\/span>\n<span class=\"hljs-keyword\">import<\/span> { HttpLink } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'apollo-link-http'<\/span>\n<span class=\"hljs-keyword\">import<\/span> { onError } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"apollo-link-error\"<\/span>\n<span class=\"hljs-keyword\">import<\/span> { InMemoryCache } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'apollo-cache-inmemory'<\/span>\n<span class=\"hljs-keyword\">import<\/span> VueApollo <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'vue-apollo'<\/span>\n\n<span class=\"hljs-keyword\">const<\/span> httpLink = <span class=\"hljs-keyword\">new<\/span> HttpLink({\n    <span class=\"hljs-attr\">uri<\/span>: process.env.VUE_APP_GRAPHQL_ENDPOINT\n})\n\n<span class=\"hljs-comment\">\/\/ Error Handling<\/span>\n<span class=\"hljs-keyword\">const<\/span> errorLink = onError(<span class=\"hljs-function\">(<span class=\"hljs-params\">{ graphQLErrors, networkError }<\/span>) =&gt;<\/span> {\n    <span class=\"hljs-keyword\">if<\/span> (graphQLErrors)\n        graphQLErrors.map(<span class=\"hljs-function\">(<span class=\"hljs-params\">{ message, locations, path }<\/span>) =&gt;<\/span>\n            <span class=\"hljs-built_in\">console<\/span>.log(\n                <span class=\"hljs-string\">`(GraphQL error): Message: <span class=\"hljs-subst\">${message}<\/span>, Location: <span class=\"hljs-subst\">${locations}<\/span>, Path: <span class=\"hljs-subst\">${path}<\/span>`<\/span>\n            )\n        )\n    <span class=\"hljs-keyword\">if<\/span> (networkError) <span class=\"hljs-built_in\">console<\/span>.log(<span class=\"hljs-string\">`(Network error): <span class=\"hljs-subst\">${networkError}<\/span>`<\/span>)\n})\n\n<span class=\"hljs-comment\">\/\/ Create the apollo client<\/span>\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">const<\/span> apolloClient = <span class=\"hljs-keyword\">new<\/span> ApolloClient({\n    <span class=\"hljs-attr\">link<\/span>: errorLink.concat(httpLink),\n    <span class=\"hljs-attr\">cache<\/span>: <span class=\"hljs-keyword\">new<\/span> InMemoryCache(),\n    <span class=\"hljs-attr\">connectToDevTools<\/span>: <span class=\"hljs-literal\">true<\/span>\n})\n\n<span class=\"hljs-comment\">\/\/ Install the Vue plugin<\/span>\nVue.use(VueApollo)\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">const<\/span> apolloProvider = <span class=\"hljs-keyword\">new<\/span> VueApollo({\n    <span class=\"hljs-attr\">defaultClient<\/span>: apolloClient\n})\n<\/code><\/pre>\n<p>\u067e\u0633 \u0627\u0632 \u0648\u0627\u0631\u062f\u0627\u062a <code>onError<\/code> \u062a\u0627\u0628\u0639 \u0627\u0632 \u0628\u0633\u062a\u0647\u060c \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0646\u0648\u0639\u06cc \u0645\u06cc\u0627\u0646 \u0627\u0641\u0632\u0627\u0631 Apollo Client \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645.  \u0647\u0631 \u06af\u0648\u0646\u0647 \u062e\u0637\u0627\u06cc \u0634\u0628\u06a9\u0647 \u06cc\u0627 GraphQL \u0631\u0627 \u0634\u0646\u0627\u0633\u0627\u06cc\u06cc \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0647 \u0645\u0627 \u0627\u06cc\u0646 \u0634\u0627\u0646\u0633 \u0631\u0627 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u0633\u0637\u062d \u062c\u0647\u0627\u0646\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0647\u0631 \u0632\u0645\u0627\u0646 \u06a9\u0647 \u062e\u0637\u0627\u06cc\u06cc \u0631\u062e \u062f\u0647\u062f\u060c callback \u0628\u0627 \u06cc\u06a9 \u0634\u06cc \u0628\u0627 \u0628\u0631\u062e\u06cc \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f:<\/p>\n<ul>\n<li><strong>\u0639\u0645\u0644<\/strong>: \u0639\u0645\u0644\u06cc\u0627\u062a\u06cc \u06a9\u0647 \u0628\u0647 \u062f\u0644\u06cc\u0644 \u06cc\u0627\u0641\u062a\u0646 \u062e\u0637\u0627\u06cc\u06cc \u0628\u0627\u0639\u062b \u0628\u0627\u0632\u06af\u0634\u062a \u062a\u0645\u0627\u0633 \u0634\u062f.<\/li>\n<li><strong>\u0648\u0627\u06a9\u0646\u0634<\/strong>: \u0646\u062a\u06cc\u062c\u0647 \u0639\u0645\u0644.<\/li>\n<li><strong>\u062e\u0637\u0627\u0647\u0627\u06cc graphQLE<\/strong>: \u0622\u0631\u0627\u06cc\u0647 \u0627\u06cc \u0627\u0632 \u062e\u0637\u0627\u0647\u0627 \u0627\u0632 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc GraphQL<\/li>\n<li><strong>\u062e\u0637\u0627\u06cc \u0634\u0628\u06a9\u0647<\/strong>: \u0647\u0631 \u06af\u0648\u0646\u0647 \u062e\u0637\u0627 \u062f\u0631 \u062d\u06cc\u0646 \u0627\u062c\u0631\u0627\u06cc \u0639\u0645\u0644\u06cc\u0627\u062a \u06cc\u0627 \u062e\u0637\u0627\u06cc \u0633\u0631\u0648\u0631.<\/li>\n<li><strong>\u0631\u0648 \u0628\u0647 \u062c\u0644\u0648<\/strong>: \u0644\u06cc\u0646\u06a9 \u0628\u0639\u062f\u06cc \u06a9\u0647 \u062f\u0631 \u0632\u0646\u062c\u06cc\u0631\u0647 \u0627\u0631\u062c\u0627\u0639 \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/li>\n<\/ul>\n<h3 id=\"managingstatewithapolloclient\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%af%db%8c%d8%b1%db%8c%d8%aa_%d8%a7%db%8c%d8%a7%d9%84%d8%aa_%d8%a8%d8%a7_apollo_client\"><\/span>\u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u06cc\u0627\u0644\u062a \u0628\u0627 Apollo Client<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062c\u0627\u06cc\u06af\u0632\u06cc\u0646\u06cc \u0645\u062a\u0641\u0627\u0648\u062a \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/vuex.vuejs.org\/\">Vuex<\/a> \u0628\u0627 \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc Vue\u060c \u0648 \u0647\u0646\u06af\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Apollo Client \u0628\u0627\u06cc\u062f \u0627\u0632 \u0628\u0633\u062a\u0647 \u0627\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>apollo-link-state<\/code>.<\/p>\n<p>\u0627\u06cc\u0646 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0627\u0628\u0632\u0627\u0631 \u0645\u062f\u06cc\u0631\u06cc\u062a \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u062d\u0644\u06cc \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0628\u0647 \u06af\u0648\u0646\u0647 \u0627\u06cc \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u06af\u0648\u06cc\u06cc \u062f\u0631 \u062d\u0627\u0644 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0627\u0632 \u06cc\u06a9 \u0633\u0631\u0648\u0631 \u0647\u0633\u062a\u06cc\u062f\u060c \u0627\u0645\u0627 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062d\u0644\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646\u060c \u0627\u06cc\u0646 \u06cc\u06a9 \u0631\u0627\u0647 \u0639\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0634 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0627\u0633\u062a\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 Apollo Client \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u06a9\u0644\u0627\u06cc\u0646\u062a HTTP \u0648 \u0627\u0628\u0632\u0627\u0631 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0648\u0636\u0639\u06cc\u062a\/\u06a9\u0634 \u062a\u0628\u062f\u06cc\u0644 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0633\u0646\u0627\u062f \u0631\u0633\u0645\u06cc \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.apollographql.com\/docs\/link\/links\/state\">\u0622\u067e\u0648\u0644\u0648-\u067e\u06cc\u0648\u0646\u062f-\u0648\u0636\u0639\u06cc\u062a<\/a>.<\/p>\n<h3 id=\"creatingqueries\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%be%d8%b1%d8%b3_%d9%88_%d8%ac%d9%88\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u067e\u0631\u0633 \u0648 \u062c\u0648<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0648\u0626\u0631\u06cc \u0647\u0627 \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u0628\u0631\u0686\u0633\u0628 \u0631\u0634\u062a\u0647 \u0627\u06cc \u0628\u0627 \u0628\u0633\u062a\u0647 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645 <strong>graphql-tag<\/strong>.  \u0628\u0631\u0627\u06cc \u0645\u0631\u062a\u0628 \u0648 \u0645\u0646\u0638\u0645 \u0646\u06af\u0647 \u062f\u0627\u0634\u062a\u0646 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647\u060c \u067e\u0648\u0634\u0647 \u0627\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>queries<\/code> \u062f\u0627\u062e\u0644 \u067e\u0648\u0634\u0647 graphql<\/p>\n<p>\u0628\u0627 \u0641\u0631\u0636 \u0627\u06cc\u0646\u06a9\u0647 \u0633\u0631\u0648\u0631 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u0646\u062f\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u062a\u0646\u0638\u06cc\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a \u062a\u0627 \u0627\u06cc\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u062a\u0641\u0633\u06cc\u0631 \u06a9\u0646\u062f\u060c \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u062d\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0627\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645 <code>getAllUsers<\/code>:<\/p>\n<pre><code class=\"hljs\">import gql from 'graphql-tag'\n\nexport const GET_ALL_USERS_QUERY = gql`\n  query getAllUsers {\n    getAllUsers {\n      \/\/ Fields to retrieve\n      name\n      age\n    }\n  }\n`\n<\/code><\/pre>\n<p>\u0639\u0645\u0644\u06cc\u0627\u062a \u067e\u06cc\u0634 \u0641\u0631\u0636 \u062f\u0631 GraphQL \u0627\u0633\u062a <code>query<\/code>\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 <code>query<\/code> \u06a9\u0644\u0645\u0647 \u06a9\u0644\u06cc\u062f\u06cc \u0627\u062e\u062a\u06cc\u0627\u0631\u06cc \u0627\u0633\u062a<\/p>\n<p>\u0627\u06af\u0631 \u06cc\u06a9 \u0641\u06cc\u0644\u062f \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u0634\u062f\u0647 \u062f\u0627\u0631\u0627\u06cc \u0632\u06cc\u0631\u0641\u06cc\u0644\u062f\u0647\u0627\u06cc\u06cc \u0628\u0627\u0634\u062f\u060c \u062d\u062f\u0627\u0642\u0644 \u06cc\u06a9\u06cc \u0627\u0632 \u0622\u0646\u0647\u0627 \u0628\u0627\u06cc\u062f \u0628\u0631\u0627\u06cc \u0645\u0648\u0641\u0642\u06cc\u062a \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0648\u0627\u06a9\u0634\u06cc \u0634\u0648\u062f.<\/p>\n<h3 id=\"usingmutations\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_%d8%ac%d9%87%d8%b4\"><\/span>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062c\u0647\u0634<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0645\u0627\u0646\u0646\u062f \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u060c \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0627 \u0627\u06cc\u062c\u0627\u062f a \u0627\u0632 \u062c\u0647\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>gql-string<\/code>.<\/p>\n<pre><code class=\"hljs\">import gql from 'graphql-tag'\n\nexport const CREATE_USER_MUTATION = gql`\n  mutation createUser($user: UserInput!) {\n    createUser(user: $user)\n  }\n`\n<\/code><\/pre>\n<p>\u0645\u0627 <code>createUser<\/code> \u062c\u0647\u0634 \u0627\u0646\u062a\u0638\u0627\u0631 \u062f\u0627\u0631\u062f a <code>UserInput<\/code> \u0648\u0631\u0648\u062f\u06cc\u060c \u0648\u060c \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u0647\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u062a\u0648\u0633\u0637 \u0622\u067e\u0648\u0644\u0648.  \u0627\u0628\u062a\u062f\u0627 \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u0628\u0627 the \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>$<\/code> \u062a\u0645\u0627\u0633 \u06af\u0631\u0641\u062a <code>user<\/code>.  \u0633\u067e\u0633\u060c wrapper \u062e\u0627\u0631\u062c\u06cc \u0645\u062a\u063a\u06cc\u0631 \u0631\u0627 \u0628\u0647 the \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f <code>createUser<\/code> \u062c\u0647\u0634\u060c \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u062a\u0648\u0633\u0637 \u0633\u0631\u0648\u0631 \u0627\u0646\u062a\u0638\u0627\u0631 \u0645\u06cc \u0631\u0648\u062f.<\/p>\n<h4 id=\"fragments\">\u0642\u0637\u0639\u0627\u062a<\/h4>\n<p>\u0628\u0647 \u0645\u0646\u0638\u0648\u0631 \u062d\u0641\u0638 \u0645\u0627 <code>gql-type<\/code> \u0631\u0634\u062a\u0647 \u0647\u0627\u06cc \u0645\u0631\u062a\u0628 \u0648 \u062e\u0648\u0627\u0646\u0627\u060c \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <strong>\u0642\u0637\u0639\u0627\u062a<\/strong> \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u0627\u0632 \u0645\u0646\u0637\u0642 \u067e\u0631\u0633 \u0648 \u062c\u0648<\/p>\n<pre><code class=\"hljs\">fragment UserFragment \u0631\u0648\u06cc User {\n  name: String!\n  age: Int!\n}\n\nquery getAllUsers {\n  getAllUsers {\n    ...UserFragment\n  }\n}\n<\/code><\/pre>\n<h3 id=\"usinggraphqlinvuecomponents\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_graphql_%d8%af%d8%b1_%d8%a7%d8%ac%d8%b2%d8%a7%db%8c_vue\"><\/span>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 GraphQL \u062f\u0631 \u0627\u062c\u0632\u0627\u06cc Vue<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631\u0648\u0646 <code>main.js<\/code> \u0641\u0627\u06cc\u0644\u060c \u0628\u0631\u0627\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0622\u067e\u0648\u0644\u0648 \u06a9\u0644\u0627\u06cc\u0646\u062a\u060c \u0628\u0627\u06cc\u062f import \u0648 \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u0628\u0647 \u0646\u0645\u0648\u0646\u0647 \u0645\u0627 \u0645\u062a\u0635\u0644 \u06a9\u0646\u06cc\u062f.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ main.js<\/span>\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> { apolloProvider } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'.\/graphql\/apollo'<\/span>\n\nVue.config.productionTip = <span class=\"hljs-literal\">false<\/span>\n\n<span class=\"hljs-comment\">\/* eslint-disable no-new *\/<\/span>\n<span class=\"hljs-keyword\">new<\/span> Vue({\n    <span class=\"hljs-attr\">el<\/span>: <span class=\"hljs-string\">'#app'<\/span>,\n    apolloProvider,\n    <span class=\"hljs-attr\">render<\/span>: <span class=\"hljs-function\"><span class=\"hljs-params\">h<\/span> =&gt;<\/span> h(App)\n})\n<\/code><\/pre>\n<p>\u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u0627 \u062e\u0648\u062f \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <strong>ApolloProvider<\/strong> \u0628\u0647 \u0646\u0645\u0648\u0646\u0647 Vue\u060c \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0628\u0647 \u0645\u0634\u062a\u0631\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645 <code>$apollo<\/code> \u06a9\u0644\u0645\u0647 \u06a9\u0644\u06cc\u062f\u06cc:<\/p>\n<pre><code class=\"hljs\">\/\/ GraphQLTest.vue\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"graphql-test\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h3<\/span> <span class=\"hljs-attr\">v-if<\/span>=<span class=\"hljs-string\">\"loading\"<\/span>&gt;<\/span>Loading...<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h3<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h4<\/span> <span class=\"hljs-attr\">v-if<\/span>=<span class=\"hljs-string\">\"!loading\"<\/span>&gt;<\/span>{{ getAllUsers }}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h4<\/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\">import<\/span> { GET_ALL_USERS_QUERY } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'..\/graphl\/queries\/userQueries'<\/span>\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'GraphQLTest'<\/span>,\n    data () {\n        <span class=\"hljs-keyword\">return<\/span> {\n            <span class=\"hljs-attr\">users<\/span>: ()\n        }\n    },\n    <span class=\"hljs-keyword\">async<\/span> mounted () {\n        <span class=\"hljs-built_in\">this<\/span>.loading = <span class=\"hljs-literal\">true<\/span>\n        <span class=\"hljs-built_in\">this<\/span>.users = <span class=\"hljs-keyword\">await<\/span> <span class=\"hljs-built_in\">this<\/span>.$apollo.query({ <span class=\"hljs-attr\">query<\/span>: GET_ALL_USERS_QUERY })\n        <span class=\"hljs-built_in\">this<\/span>.loading = <span class=\"hljs-literal\">false<\/span>\n    }\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u0628\u062e\u0648\u0627\u0647\u06cc\u0645 \u06cc\u06a9 \u06a9\u0627\u0631\u0628\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>mutation<\/code>:<\/p>\n<pre><code class=\"hljs\">\/\/ GraphQLTest.vue\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"graphql-test\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">v-model<\/span>=<span class=\"hljs-string\">\"user.name\"<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"text\"<\/span> <span class=\"hljs-attr\">placeholder<\/span>=<span class=\"hljs-string\">\"Name\"<\/span> \/&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">v-model<\/span>=<span class=\"hljs-string\">\"user.age\"<\/span> <span class=\"hljs-attr\">placeholder<\/span>=<span class=\"hljs-string\">\"Age\"<\/span> \/&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> @<span class=\"hljs-attr\">click<\/span>=<span class=\"hljs-string\">\"createUser\"<\/span>&gt;<\/span>Create User<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/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\">import<\/span> { CREATE_USER_MUTATION } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'..\/graphl\/queries\/userQueries'<\/span>\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'GraphQLTest'<\/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\">user<\/span>: {\n                <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-literal\">null<\/span>,\n                <span class=\"hljs-attr\">age<\/span>: <span class=\"hljs-literal\">null<\/span>\n            }\n        }\n    },\n    <span class=\"hljs-attr\">methods<\/span>: {\n        <span class=\"hljs-keyword\">async<\/span> createUser () {\n            <span class=\"hljs-keyword\">const<\/span> userCreated = <span class=\"hljs-keyword\">await<\/span> <span class=\"hljs-built_in\">this<\/span>.$apollo.mutate({\n                <span class=\"hljs-attr\">mutation<\/span>: CREATE_USER_MUTATION,\n                <span class=\"hljs-attr\">variables<\/span>: {\n                    <span class=\"hljs-attr\">user<\/span>: <span class=\"hljs-built_in\">this<\/span>.user <span class=\"hljs-comment\">\/\/ this should be the same name as the one the server is expecting<\/span>\n                }\n            })\n            <span class=\"hljs-comment\">\/\/ We log the created user ID<\/span>\n            <span class=\"hljs-built_in\">console<\/span>.log(userCreated.data.createUser)\n        }\n    }\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u06cc\u0646 \u0631\u0648\u06cc\u06a9\u0631\u062f \u0628\u0647 \u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0632\u0645\u0627\u0646 \u0648 \u0645\u06a9\u0627\u0646 \u0627\u062c\u0631\u0627\u06cc \u062c\u0647\u0634 \u0647\u0627 \u0648 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc \u0645\u0627 \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0631\u06cc\u0632 \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0646\u06cc\u0645.  \u0627\u06a9\u0646\u0648\u0646 \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u062f\u06cc\u06af\u0631\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u06cc\u0646 \u0631\u0648\u0634\u200c\u0647\u0627 \u06a9\u0647 Vue Apollo \u062f\u0631 \u0627\u062e\u062a\u06cc\u0627\u0631 \u0645\u0627 \u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u062f\u0647\u062f\u060c \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u06cc\u062f.<\/p>\n<h3 id=\"theapolloobject\"><span class=\"ez-toc-section\" id=\"%d8%b4%db%8c_%d8%a2%d9%be%d9%88%d9%84%d9%88\"><\/span>\u0634\u06cc \u0622\u067e\u0648\u0644\u0648<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u062f\u0627\u062e\u0644 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0647\u0627\u06cc Vue\u060c \u0645\u0627 \u0628\u0647 \u0622\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0631\u06cc\u0645 <code>Apollo<\/code> \u0634\u06cc\u060c \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0622\u0633\u0627\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627 \u0648 \u0627\u0634\u062a\u0631\u0627\u06a9 \u0647\u0627\u06cc \u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0634\u0648\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"graphql-test\"<\/span>&gt;<\/span>\n        {{ getAllUsers }}\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">import<\/span> { GET_ALL_USERS_QUERY } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'..\/graphl\/queries\/userQueries'<\/span>\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'GraphQL-Test'<\/span>,\n    <span class=\"hljs-attr\">apollo<\/span>: {\n        <span class=\"hljs-attr\">getAllUsers<\/span>: {\n            <span class=\"hljs-attr\">query<\/span>: GET_ALL_USERS_QUERY\n        }\n    }\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<h4 id=\"refetchingqueries\">\u0648\u0627\u06a9\u0634\u06cc \u0645\u062c\u062f\u062f \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627<\/h4>\n<p>\u0647\u0646\u06af\u0627\u0645 \u062a\u0639\u0631\u06cc\u0641 \u06cc\u06a9 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u062f\u0631 \u062f\u0627\u062e\u0644 \u0634\u06cc Apollo\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a <strong>\u0648\u0627\u06a9\u0634\u06cc \u0645\u062c\u062f\u062f<\/strong> \u0627\u06cc\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0647\u0646\u06af\u0627\u0645 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u06cc\u06a9 \u062c\u0647\u0634 \u06cc\u0627 \u067e\u0631\u0633 \u0648 \u062c\u0648\u06cc \u062f\u06cc\u06af\u0631 \u0628\u0627 <code>refetch<\/code> \u0631\u0648\u0634 \u06cc\u0627 <code>refetchQueries<\/code> \u0648\u06cc\u0698\u06af\u06cc:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">class<\/span>=<span class=\"hljs-string\">\"graphql-test\"<\/span>&gt;<\/span>\n        {{ getAllUsers }}\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span>&gt;<\/span><span class=\"javascript\">\n<span class=\"hljs-keyword\">import<\/span> { GET_ALL_USERS_QUERY, CREATE_USER_MUTATION } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'..\/graphl\/queries\/userQueries'<\/span>\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> {\n    <span class=\"hljs-attr\">name<\/span>: <span class=\"hljs-string\">'GraphQL-Test'<\/span>,\n    <span class=\"hljs-attr\">apollo<\/span>: {\n        <span class=\"hljs-attr\">getAllUsers<\/span>: {\n            <span class=\"hljs-attr\">query<\/span>: GET_ALL_USERS_QUERY\n        }\n    },\n    <span class=\"hljs-attr\">methods<\/span>: {\n        refetch () {\n            <span class=\"hljs-built_in\">this<\/span>.$apollo.queries.getAllUsers.refetch()\n        },\n        queryUsers () {\n            <span class=\"hljs-keyword\">const<\/span> user = { <span class=\"hljs-attr\">name<\/span>: Lucas, <span class=\"hljs-attr\">age<\/span>: <span class=\"hljs-number\">26<\/span> }\n            <span class=\"hljs-built_in\">this<\/span>.$apollo.mutate({\n                <span class=\"hljs-attr\">mutation<\/span>: CREATE_USER_MUTATION,\n                <span class=\"hljs-attr\">variables<\/span>: {\n                    user\n                }\n                <span class=\"hljs-attr\">refetchQueries<\/span>: (\n                    { <span class=\"hljs-attr\">query<\/span>: GET_ALL_USERS_QUERY }\n                )\n            })\n        }\n    }\n}\n<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>Apollo<\/code> \u0634\u06cc\u060c \u062a\u0648\u0633\u0637 <em>Vue-Apollo<\/em>\u060c \u062f\u06cc\u06af\u0631 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0641\u0639\u0627\u0644\u0627\u0646\u0647 \u0627\u0632 \u0631\u0648\u0634 \u06a9\u0644\u0627\u06cc\u0646\u062a \u0622\u067e\u0648\u0644\u0648 \u0628\u0631\u0627\u06cc \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\/\u0627\u0634\u062a\u0631\u0627\u06a9 \u0647\u0627 \u0646\u062f\u0627\u0631\u06cc\u0645 \u0648 \u0628\u0631\u062e\u06cc \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627 \u0648 \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u0645\u0641\u06cc\u062f \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0645\u0627 \u0642\u0631\u0627\u0631 \u0645\u06cc \u06af\u06cc\u0631\u0646\u062f.<\/p>\n<h4 id=\"apolloobjectproperties\">\u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u062c\u0633\u0645 \u0622\u067e\u0648\u0644\u0648<\/h4>\n<ul>\n<li><strong>\u067e\u0631\u0633 \u0648 \u062c\u0648<\/strong>: \u0627\u06cc\u0646 \u0627\u0633\u062a <code>gql<\/code> \u0631\u0634\u062a\u0647 \u0631\u0627 \u0628\u0627 \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648\u06cc \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0634\u0648\u062f \u062a\u0627\u06cc\u067e \u06a9\u0646\u06cc\u062f.<\/li>\n<li><strong>\u0645\u062a\u063a\u06cc\u0631\u0647\u0627<\/strong>: \u0634\u06cc\u0626\u06cc \u06a9\u0647 \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u0647\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u0634\u062f\u0647 \u0628\u0647 \u06cc\u06a9 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0631\u0627 \u0645\u06cc \u067e\u0630\u06cc\u0631\u062f.<\/li>\n<li><strong>fetchPolicy<\/strong>: \u062e\u0635\u0648\u0635\u06cc\u062a\u06cc \u06a9\u0647 \u0631\u0648\u0634 \u062a\u0639\u0627\u0645\u0644 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0628\u0627 \u062d\u0627\u0641\u0638\u0647 \u067e\u0646\u0647\u0627\u0646 \u0631\u0627 \u062a\u0639\u06cc\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f.  \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627 \u0647\u0633\u062a\u0646\u062f <code>cache-and-network<\/code>\u060c <code>network-only<\/code>\u060c <code>cache-only<\/code>\u060c <code>no-cache<\/code>\u060c <code>standby<\/code> \u0648 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0627\u0633\u062a <code>cache-first<\/code>.<\/li>\n<li><strong>\u0641\u0627\u0635\u0644\u0647 \u0646\u0638\u0631\u0633\u0646\u062c\u06cc<\/strong>: \u0632\u0645\u0627\u0646 \u0628\u0631 \u062d\u0633\u0628 \u0645\u06cc\u0644\u06cc \u062b\u0627\u0646\u06cc\u0647 \u06a9\u0647 \u062a\u0639\u06cc\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f \u06cc\u06a9 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0686\u0646\u062f \u0628\u0627\u0631 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0634\u0648\u062f.<\/li>\n<\/ul>\n<h4 id=\"specialoptions\">\u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u0648\u06cc\u0698\u0647<\/h4>\n<ul>\n<li><strong>\u062e\u0637\u0627\u06cc $<\/strong> \u0628\u0631\u0627\u06cc \u06af\u0631\u0641\u062a\u0646 \u062e\u0637\u0627\u0647\u0627 \u062f\u0631 \u06cc\u06a9 \u06a9\u0646\u062a\u0631\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0645\u062c\u0645\u0648\u0639\u0647.<\/li>\n<li><strong>$ \u0639\u0645\u06cc\u0642<\/strong> \u0639\u0645\u06cc\u0642\u0627\u064b \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u062f\u0631 \u06cc\u06a9 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0627\u0633\u062a.<\/li>\n<li><strong>$ \u0631\u062f \u0634\u062f\u0646<\/strong>: \u0647\u0645\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627 \u0648 \u0627\u0634\u062a\u0631\u0627\u06a9 \u0647\u0627 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u062c\u0632\u0621 \u0645\u0639\u06cc\u0646 \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li><strong>$skipAllQueries<\/strong>: \u0647\u0645\u0647 \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc \u06cc\u06a9 \u062c\u0632\u0621 \u0631\u0627 \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li><strong>$skipAllSubscriptions<\/strong>: \u0628\u0631\u0627\u06cc \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0647\u0645\u0647 \u0627\u0634\u062a\u0631\u0627\u06a9 \u0647\u0627 \u062f\u0631 \u06cc\u06a9 \u062c\u0632\u0621.<\/li>\n<\/ul>\n<h3 id=\"apollocomponents\"><span class=\"ez-toc-section\" id=\"%d8%a7%d8%ac%d8%b2%d8%a7%db%8c_%d8%a2%d9%be%d9%88%d9%84%d9%88\"><\/span>\u0627\u062c\u0632\u0627\u06cc \u0622\u067e\u0648\u0644\u0648<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0627 \u0627\u0644\u0647\u0627\u0645 \u0627\u0632 \u0631\u0648\u0634\u06cc \u06a9\u0647 Apollo Client \u0628\u0631\u0627\u06cc \u0622\u0646 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/reactjs.org\/\">\u0648\u0627\u06a9\u0646\u0634 \u0646\u0634\u0627\u0646 \u062f\u0647\u06cc\u062f<\/a> (<a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/github.com\/apollographql\/react-apollo\">\u0648\u0627\u06a9\u0646\u0634 &#8211; \u0622\u067e\u0648\u0644\u0648<\/a>Vue-Apollo \u0686\u0646\u062f \u0645\u0624\u0644\u0641\u0647 \u0631\u0627 \u062f\u0631 \u0627\u062e\u062a\u06cc\u0627\u0631 \u0645\u0627 \u0642\u0631\u0627\u0631 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0648 \u0648\u0636\u0639\u06cc\u062a \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627 \u0648 \u062c\u0647\u0634 \u0647\u0627\u06cc \u062e\u0648\u062f \u0628\u0627 \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 Vue \u062f\u0631 \u062f\u0627\u062e\u0644 \u0642\u0627\u0644\u0628 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<h4 id=\"apolloquery\">ApolloQuery<\/h4>\n<p>\u0631\u0648\u0634\u06cc \u0633\u0627\u062f\u0647 \u062a\u0631 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627\u06cc \u0645\u0627 \u0628\u0647 \u0634\u06cc\u0648\u0647 \u0627\u06cc \u0634\u0647\u0648\u062f\u06cc \u062a\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">ApolloQuery<\/span>\n  <span class=\"hljs-attr\">:query<\/span>=<span class=\"hljs-string\">\"GET_ALL_USERS_QUERY\"<\/span>\n&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span> <span class=\"hljs-attr\">slot-scope<\/span>=<span class=\"hljs-string\">\"{ result: { loading, error, data } }\"<\/span>&gt;<\/span>\n        <span class=\"hljs-comment\">&lt;!-- Loading --&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">v-if<\/span>=<span class=\"hljs-string\">\"loading\"<\/span>&gt;<\/span>Query is loading.<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n        <span class=\"hljs-comment\">&lt;!-- Error --&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">v-else-if<\/span>=<span class=\"hljs-string\">\"error\"<\/span>&gt;<\/span>We got an error!<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n        <span class=\"hljs-comment\">&lt;!-- Result --&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">v-else-if<\/span>=<span class=\"hljs-string\">\"data\"<\/span>&gt;<\/span>{{ data.getAllUsers }}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n        <span class=\"hljs-comment\">&lt;!-- No result (if the query succeed but there's no data) --&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">v-else<\/span>&gt;<\/span>No result from the server<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<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">ApolloQuery<\/span>&gt;<\/span>\n<\/code><\/pre>\n<h4 id=\"apollomutation\">\u0622\u067e\u0648\u0644\u0648 \u062c\u0647\u0634<\/h4>\n<p>\u0628\u0633\u06cc\u0627\u0631 \u0634\u0628\u06cc\u0647 \u0628\u0647 \u0645\u062b\u0627\u0644 \u0628\u0627\u0644\u0627 \u0627\u0633\u062a\u060c \u0627\u0645\u0627 \u0628\u0627\u06cc\u062f \u062c\u0647\u0634 \u0631\u0627 \u0628\u0627 the \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u0645 <code>mutate<\/code> \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u062a\u0627\u0628\u0639:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">ApolloMutation<\/span>\n  <span class=\"hljs-attr\">:mutation<\/span>=<span class=\"hljs-string\">\"CREATE_USER_MUTATION\"<\/span>\n  <span class=\"hljs-attr\">:variables<\/span>=<span class=\"hljs-string\">\"{\n    name,\n    age\n  }\"<\/span>\n  @<span class=\"hljs-attr\">done<\/span>=<span class=\"hljs-string\">\"mutationFinished\"<\/span>\n&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">template<\/span> <span class=\"hljs-attr\">slot-scope<\/span>=<span class=\"hljs-string\">\"{ mutate, loading, error }\"<\/span>&gt;<\/span>\n        <span class=\"hljs-comment\">&lt;!-- Loading --&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h4<\/span> <span class=\"hljs-attr\">v-if<\/span>=<span class=\"hljs-string\">\"loading\"<\/span>&gt;<\/span>The mutation is loading!<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h4<\/span>&gt;<\/span>\n\n        <span class=\"hljs-comment\">&lt;!-- Mutation Trigger --&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> @<span class=\"hljs-attr\">click<\/span>=<span class=\"hljs-string\">\"mutate()\"<\/span>&gt;<\/span>Create User<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n\n        <span class=\"hljs-comment\">&lt;!-- Error --&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span> <span class=\"hljs-attr\">v-if<\/span>=<span class=\"hljs-string\">\"error\"<\/span>&gt;<\/span>An error has occurred!<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">template<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">ApolloMutation<\/span>&gt;<\/span>\n<\/code><\/pre>\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>GraphQL \u0627\u0646\u0639\u0637\u0627\u0641\u200c\u067e\u0630\u06cc\u0631\u06cc \u0632\u06cc\u0627\u062f\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 API \u0628\u0647 \u0627\u0631\u0645\u063a\u0627\u0646 \u0645\u06cc\u200c\u0622\u0648\u0631\u062f\u060c \u0627\u0632 \u0639\u0645\u0644\u06a9\u0631\u062f\u060c \u0633\u0647\u0648\u0644\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0648 \u062f\u06cc\u062f\u06af\u0627\u0647 \u06a9\u0644\u06cc \u0645\u062a\u0641\u0627\u0648\u062a \u0627\u0632 \u0638\u0627\u0647\u0631 \u0648 \u0631\u0641\u062a\u0627\u0631 \u06cc\u06a9 API.  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c ApolloClient \u0648 Vue Apollo \u0645\u062c\u0645\u0648\u0639\u0647 \u0627\u06cc \u0627\u0632 \u0627\u0628\u0632\u0627\u0631\u0647\u0627 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0628\u0647\u062a\u0631 UI\u060c \u0648\u0636\u0639\u06cc\u062a \u0648 \u0639\u0645\u0644\u06cc\u0627\u062a \u0645\u0627\u060c \u062d\u062a\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u062e\u0637\u0627 \u0648 \u062d\u0627\u0641\u0638\u0647 \u067e\u0646\u0647\u0627\u0646 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u0646\u062f!<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f GraphQL \u0648 Apollo Client \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0622\u062f\u0631\u0633 \u0632\u06cc\u0631 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<ul>\n<li><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/graphql.org\">\u0635\u0641\u062d\u0647 \u0631\u0633\u0645\u06cc GraphQL<\/a><\/li>\n<li><a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/apollographql.com\">\u0635\u0641\u062d\u0647 \u0631\u0633\u0645\u06cc \u0645\u0634\u062a\u0631\u06cc \u0622\u067e\u0648\u0644\u0648<\/a><\/li>\n<\/ul>\n<\/div>\n<p>    (\u0628\u0631\u0686\u0633\u0628\u200c\u0647\u0627 \u0628\u0647 \u062a\u0631\u062c\u0645\u0647)# \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a<br \/>\n<br \/><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-25 10:00: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;16457&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;\u0633\u0627\u062e\u062a\u0646 API \u0647\u0627\u06cc GraphQL \u0628\u0627 Vue.js \u0648 Apollo ClientGraphQL \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u06af\u0631\u0627\u0641\u06af\u0631\u0627 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 \u0641\u06cc\u0633 \u0628\u0648\u06a9 \u0646\u0648\u0634\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0628\u0631\u062e\u0644\u0627\u0641 REST API \u0647\u0627\u060c GraphQL \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 API \u0631\u0627 \u06a9\u0627\u0631\u0622\u0645\u062f\u062a\u0631 \u0648 \u0647\u0645\u0627\u0647\u0646\u06af \u0628\u0627 \u0645\u062f\u0644 \u0647\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f.  \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc GraphQL \u0628\u0631\u062e\u0644\u0627\u0641 REST\u060c \u062a\u0646\u0647\u0627 \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0642\u0631\u0627\u0631 \u0627\u0633\u062a \u062a\u0645\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627 \u0628\u0647 \u0622\u0646\u062c\u0627 \u0627\u0631\u0633\u0627\u0644 \u0634\u0648\u0646\u062f.  \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0628\u0647 \u062c\u0627\u06cc ...&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 9<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc GraphQL \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u067e\u0631\u0633 \u0648 \u062c\u0648 \u06af\u0631\u0627\u0641 \u0645\u062d\u0648\u0631 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 \u0641\u06cc\u0633 \u0628\u0648\u06a9 \u0646\u0648\u0634\u062a\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a. \u0628\u0631\u062e\u0644\u0627\u0641 REST API \u0647\u0627\u060c GraphQL \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 API \u0631\u0627 \u06a9\u0627\u0631\u0622\u0645\u062f\u062a\u0631 \u0648 \u0647\u0645\u0627\u0647\u0646\u06af \u0628\u0627 \u0645\u062f\u0644 \u0647\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f. \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc GraphQL \u0628\u0631 \u062e\u0644\u0627\u0641 \u0628\u0627\u0642\u06cc \u0645\u0627\u0646\u062f\u0647\u060c \u062a\u0646\u0647\u0627 \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":16458,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[],"class_list":["post-16457","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16457","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=16457"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/16457\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/16458"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=16457"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=16457"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=16457"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}