{"id":15794,"date":"2024-06-30T00:21:23","date_gmt":"2024-06-29T20:51:23","guid":{"rendered":"https:\/\/www.itpiran.net\/blog\/?p=15794"},"modified":"2024-06-30T00:21:23","modified_gmt":"2024-06-29T20:51:23","slug":"how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04","status":"publish","type":"post","link":"https:\/\/www.itpiran.net\/blog\/es\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/","title":{"rendered":"C\u00f3mo crear una aplicaci\u00f3n web moderna para la gesti\u00f3n de informaci\u00f3n de clientes con Django y React en Ubuntu 18.04"},"content":{"rendered":"<h2 id=\"%d9%85%d9%82%d8%af%d9%85%d9%87\">\u0645\u0642\u062f\u0645\u0647<\/h2>\n<p>\u0645\u0631\u062f\u0645 \u0627\u0632 \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641\u06cc \u0627\u0632 \u062f\u0633\u062a\u06af\u0627\u0647 \u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 \u0627\u06cc\u0646\u062a\u0631\u0646\u062a \u0648 \u0645\u0631\u0648\u0631 \u0648\u0628 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f. \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644\u060c \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627 \u0628\u0627\u06cc\u062f \u0627\u0632 \u0645\u06a9\u0627\u0646 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0642\u0627\u0628\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0627\u0634\u0646\u062f. \u0628\u0631\u0627\u06cc \u0648\u0628 \u0633\u0627\u06cc\u062a \u0647\u0627\u06cc \u0633\u0646\u062a\u06cc\u060c \u062f\u0627\u0634\u062a\u0646 \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0648\u0627\u06a9\u0646\u0634 \u06af\u0631\u0627 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u06a9\u0627\u0641\u06cc \u0627\u0633\u062a\u060c \u0627\u0645\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u067e\u06cc\u0686\u06cc\u062f\u0647 \u062a\u0631 \u0627\u063a\u0644\u0628 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u06a9\u0646\u06cc\u06a9 \u0647\u0627 \u0648 \u0645\u0639\u0645\u0627\u0631\u06cc \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u062f\u0627\u0631\u0646\u062f. \u0627\u06cc\u0646\u0647\u0627 \u0634\u0627\u0645\u0644 \u062f\u0627\u0634\u062a\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc REST back-end \u0648 front-end \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc\u060c \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u067e\u06cc\u0634\u0631\u0648 (PWA) \u06cc\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062a\u0644\u0641\u0646 \u0647\u0645\u0631\u0627\u0647 \u0628\u0648\u0645\u06cc \u0627\u062c\u0631\u0627 \u0634\u0648\u0646\u062f.<\/p>\n<p>\u0628\u0631\u062e\u06cc \u0627\u0632 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0646\u06af\u0627\u0645 \u0633\u0627\u062e\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u067e\u06cc\u0686\u06cc\u062f\u0647 \u062a\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u0639\u0628\u0627\u0631\u062a\u0646\u062f \u0627\u0632:<\/p>\n<ul>\n<li>React\u060c \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0627\u06cc\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0631\u0627 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0628\u0631\u0627\u06cc \u067e\u0634\u062a\u06cc\u0628\u0627\u0646 \u0647\u0627\u06cc REST API \u062e\u0648\u062f\u060c \u0635\u0641\u062d\u0627\u062a \u0648\u0628 \u0648 \u0628\u0648\u0645\u06cc \u0628\u0633\u0627\u0632\u0646\u062f.<\/li>\n<li>\u062c\u0646\u06af\u0648\u060c \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u0648\u0628 \u0631\u0627\u06cc\u06af\u0627\u0646 \u0648 \u0645\u0646\u0628\u0639 \u0628\u0627\u0632 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0627\u0632 \u0627\u0644\u06af\u0648\u06cc \u0645\u0639\u0645\u0627\u0631\u06cc \u0646\u0631\u0645 \u0627\u0641\u0632\u0627\u0631 \u06a9\u0646\u062a\u0631\u0644\u0631 \u0646\u0645\u0627\u06cc \u0645\u062f\u0644 (MVC) \u067e\u06cc\u0631\u0648\u06cc \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li>\u0686\u0627\u0631\u0686\u0648\u0628 Django REST\u060c \u06cc\u06a9 \u062c\u0639\u0628\u0647 \u0627\u0628\u0632\u0627\u0631 \u0642\u062f\u0631\u062a\u0645\u0646\u062f \u0648 \u0627\u0646\u0639\u0637\u0627\u0641 \u067e\u0630\u06cc\u0631 \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a API \u0647\u0627\u06cc REST \u062f\u0631 \u062c\u0646\u06af\u0648.<\/li>\n<\/ul>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634\u060c \u0634\u0645\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 React\u060c Django \u0648 Django REST Framework\u060c \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0627 \u067e\u0634\u062a\u0648\u0627\u0646\u0647 \u0648 \u0641\u0631\u0627\u0646\u062a \u0627\u0646\u062f \u062c\u062f\u0627\u06af\u0627\u0646\u0647 REST API \u062e\u0648\u0627\u0647\u06cc\u062f \u0633\u0627\u062e\u062a. \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 React with Django\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0622\u062e\u0631\u06cc\u0646 \u067e\u06cc\u0634\u0631\u0641\u062a\u200c\u0647\u0627\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0648 \u062a\u0648\u0633\u0639\u0647 front-end \u0628\u0647\u0631\u0647 \u0628\u0628\u0631\u06cc\u062f. \u0628\u0647 \u062c\u0627\u06cc \u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u0646\u06af\u0648 \u06a9\u0647 \u0627\u0632 \u0645\u0648\u062a\u0648\u0631 \u0642\u0627\u0644\u0628 \u062f\u0627\u062e\u0644\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u0632 React \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 UI \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f \u06a9\u0647 \u0627\u0632 \u0645\u062f\u0644 \u0645\u062c\u0627\u0632\u06cc \u0634\u06cc \u0633\u0646\u062f (DOM)\u060c \u0631\u0648\u06cc\u06a9\u0631\u062f \u0627\u0639\u0644\u0627\u0646\u06cc \u0648 \u0645\u0624\u0644\u0641\u0647 \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0628\u0647 \u0633\u0631\u0639\u062a \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u062f\u0631 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u0646\u062f\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u06a9\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0633\u0627\u062e\u062a\u060c \u0633\u0648\u0627\u0628\u0642 \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0622\u0646 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0646\u0642\u0637\u0647 \u0634\u0631\u0648\u0639 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 CRM \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f. \u0648\u0642\u062a\u06cc \u06a9\u0627\u0631\u062a\u0627\u0646 \u062a\u0645\u0627\u0645 \u0634\u062f\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0631\u0627\u0628\u0637 React \u06a9\u0647 \u0628\u0627 \u0628\u0648\u062a \u0627\u0633\u062a\u0631\u067e \u06f4 \u0627\u0633\u062a\u0627\u06cc\u0644 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647\u060c \u0628\u062e\u0648\u0627\u0646\u06cc\u062f\u060c \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0648 \u062d\u0630\u0641 \u06a9\u0646\u06cc\u062f.<\/p>\n<h5 id=\"%d9%be%db%8c%d8%b4-%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7\">\u067e\u06cc\u0634 \u0646\u06cc\u0627\u0632\u0647\u0627<\/h5>\n<p>\u0628\u0631\u0627\u06cc \u062a\u06a9\u0645\u06cc\u0644 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634\u060c \u0634\u0645\u0627 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f:<\/p>\n<ul>\n<li>\u06cc\u06a9 \u0645\u0627\u0634\u06cc\u0646 \u062a\u0648\u0633\u0639\u0647 \u0628\u0627 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04.<\/li>\n<li>\u067e\u0627\u06cc\u062a\u0648\u0646 3\u060c \u067e\u06cc\u067e \u0648 venv \u0628\u0627 \u062f\u0646\u0628\u0627\u0644 \u06a9\u0631\u062f\u0646 \u0645\u0631\u0627\u062d\u0644 1 \u0648 2 \u0646\u062d\u0648\u0647 \u0646\u0635\u0628 \u067e\u0627\u06cc\u062a\u0648\u0646 3 \u0648 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06cc\u06a9 \u0645\u062d\u06cc\u0637 \u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc \u0645\u062d\u0644\u06cc \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04 \u0631\u0648\u06cc \u062f\u0633\u062a\u06af\u0627\u0647 \u0634\u0645\u0627 \u0646\u0635\u0628 \u0634\u062f\u0647 \u0627\u0633\u062a.<\/li>\n<li>Node.js 6+ \u0648 npm 5.2 \u06cc\u0627 \u0628\u0627\u0644\u0627\u062a\u0631 \u0631\u0648\u06cc \u062f\u0633\u062a\u06af\u0627\u0647 \u0634\u0645\u0627 \u0646\u0635\u0628 \u0634\u062f\u0647 \u0627\u0633\u062a. \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0631 \u062f\u0648\u06cc \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0627 \u062f\u0646\u0628\u0627\u0644 \u06a9\u0631\u062f\u0646 \u062f\u0633\u062a\u0648\u0631\u0627\u0644\u0639\u0645\u0644 \u0647\u0627\u06cc \u0646\u062d\u0648\u0647 \u0646\u0635\u0628 Node.js \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04 \u062f\u0631 \u0646\u0635\u0628 \u0627\u0632 PPA \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f.<\/li>\n<\/ul>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-1-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d9%85%d8%ad%db%8c%d8%b7-%d9%85%d8%ac%d8%a7%d8%b2%db%8c-%d9%be%d8%a7%db%8c%d8%aa%d9%88%d9%86-%d9%88-%d9%86%d8%b5\">\u0645\u0631\u062d\u0644\u0647 1 &#8211; \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u062d\u06cc\u0637 \u0645\u062c\u0627\u0632\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u0648 \u0646\u0635\u0628 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647\u060c \u0645\u0627 \u06cc\u06a9 \u0645\u062d\u06cc\u0637 \u0645\u062c\u0627\u0632\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0646\u0635\u0628 \u0645\u06cc \u06a9\u0646\u06cc\u0645\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u062c\u0646\u06af\u0648\u060c \u0641\u0631\u06cc\u0645 \u0648\u0631\u06a9 Django REST \u0648 Django-cors-headers.<\/p>\n<p>\u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0627\u0632 \u062f\u0648 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u0645\u062e\u062a\u0644\u0641 \u0628\u0631\u0627\u06cc Django \u0648 React \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u062f \u06a9\u0631\u062f. \u0622\u0646\u0647\u0627 \u0628\u0631 \u0631\u0648\u06cc \u067e\u0648\u0631\u062a \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u0646\u062f \u0648 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062f\u0648 \u062f\u0627\u0645\u0646\u0647 \u062c\u062f\u0627\u06af\u0627\u0646\u0647 \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u0646\u062f. \u0628\u0647 \u0647\u0645\u06cc\u0646 \u062f\u0644\u06cc\u0644\u060c \u0645\u0627 \u0628\u0627\u06cc\u062f \u0627\u0634\u062a\u0631\u0627\u06a9\u200c\u06af\u0630\u0627\u0631\u06cc \u0645\u0646\u0627\u0628\u0639 \u0645\u062a\u0642\u0627\u0637\u0639 (CORS) \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u0631\u0633\u0627\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc HTTP \u0627\u0632 React \u0628\u0647 \u062c\u0646\u06af\u0648 \u0628\u062f\u0648\u0646 \u0645\u0633\u062f\u0648\u062f \u0634\u062f\u0646 \u062a\u0648\u0633\u0637 \u0645\u0631\u0648\u0631\u06af\u0631 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0628\u0647 \u0641\u0647\u0631\u0633\u062a \u0627\u0635\u0644\u06cc \u062e\u0648\u062f \u0628\u0631\u0648\u06cc\u062f \u0648 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0645\u0627\u0698\u0648\u0644 venv Python 3 \u06cc\u06a9 \u0645\u062d\u06cc\u0637 \u0645\u062c\u0627\u0632\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\r\npython3 -m venv .\/env<\/code><\/pre>\n<\/div>\n<p>\u0645\u062d\u06cc\u0637 \u0645\u062c\u0627\u0632\u06cc \u0627\u06cc\u062c\u0627\u062f \u0634\u062f\u0647 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0645\u0646\u0628\u0639 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>source env\/bin\/activate<\/code><\/pre>\n<\/div>\n<p>\u0628\u0639\u062f\u060c \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u0628\u0627 pip \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f. \u0627\u06cc\u0646 \u0645\u0648\u0627\u0631\u062f \u0634\u0627\u0645\u0644 \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<ul>\n<li>\u062c\u0646\u06af\u0648: \u0686\u0627\u0631\u0686\u0648\u0628 \u0648\u0628 \u0628\u0631\u0627\u06cc \u067e\u0631\u0648\u0698\u0647.<\/li>\n<li>\u0686\u0627\u0631\u0686\u0648\u0628 Django REST: \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u062e\u0635 \u062b\u0627\u0644\u062b \u06a9\u0647 API \u0647\u0627\u06cc REST \u0631\u0627 \u0628\u0627 \u062c\u0646\u06af\u0648 \u0645\u06cc \u0633\u0627\u0632\u062f.<\/li>\n<li>django-cors-headers: \u0628\u0633\u062a\u0647 \u0627\u06cc \u06a9\u0647 CORS \u0631\u0627 \u0641\u0639\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<\/ul>\n<p>\u0641\u0631\u06cc\u0645 \u0648\u0631\u06a9 \u062c\u0646\u06af\u0648 \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>pip install django djangorestframework django-cors-headers<\/code><\/pre>\n<\/div>\n<p>\u0628\u0627 \u0646\u0635\u0628 \u0648\u0627\u0628\u0633\u062a\u06af\u06cc \u0647\u0627\u06cc \u067e\u0631\u0648\u0698\u0647\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u0648 \u0641\u0631\u0627\u0646\u062a \u0627\u0646\u062f React \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-2-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%d9%be%d8%b1%d9%88%da%98%d9%87-%d8%ac%d9%86%da%af%d9%88\">\u0645\u0631\u062d\u0644\u0647 2 &#8211; \u0627\u06cc\u062c\u0627\u062f \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647\u060c \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631\u0627\u062a \u0648 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u0632\u06cc\u0631 \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<p>django-admin startproject-name: django-admin \u06cc\u06a9 \u0627\u0628\u0632\u0627\u0631 \u062e\u0637 \u0641\u0631\u0645\u0627\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0648\u0638\u0627\u06cc\u0641 \u0628\u0627 \u062c\u0646\u06af\u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f. \u062f\u0633\u062a\u0648\u0631 startproject \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>python manager.py startapp myapp: manager.py \u06cc\u06a9 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0628\u0647 \u0647\u0631 \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u0634\u0648\u062f \u0648 \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u0648\u0638\u0627\u06cc\u0641 \u0627\u062f\u0627\u0631\u06cc \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f: \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062c\u062f\u06cc\u062f\u060c \u0627\u0646\u062a\u0642\u0627\u0644 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0648 \u0627\u0631\u0627\u0626\u0647 \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062d\u0644\u06cc. \u062f\u0633\u062a\u0648\u0631 startapp \u0622\u0646 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u0646\u06af\u0648 \u0631\u0627 \u062f\u0631 \u062f\u0627\u062e\u0644 \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f. \u062f\u0631 \u062c\u0646\u06af\u0648\u060c \u0627\u0635\u0637\u0644\u0627\u062d \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u06cc\u06a9 \u0628\u0633\u062a\u0647 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0631\u0627 \u062a\u0648\u0635\u06cc\u0641 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0645\u062c\u0645\u0648\u0639\u0647\u200c\u0627\u06cc \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627 \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639\u060c \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u0631\u0627 \u0628\u0627 django-admin startproject \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f. \u0645\u0627 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0631\u0627 djangoreactproject \u0645\u06cc \u0646\u0627\u0645\u06cc\u0645:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>django-admin startproject djangoreactproject<\/code><\/pre>\n<\/div>\n<p>\u0642\u0628\u0644 \u0627\u0632 \u062d\u0631\u06a9\u062a\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0628\u0647 \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 \u062f\u0631\u062e\u062a \u0646\u06af\u0627\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0628\u0647 \u067e\u0648\u0634\u0647 djangoreactproject \u062f\u0631 \u0631\u06cc\u0634\u0647 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0628\u0631\u0648\u06cc\u062f \u0648 \u062f\u0633\u062a\u0648\u0631 \u062f\u0631\u062e\u062a \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject\r\ntree<\/code><\/pre>\n<\/div>\n<p>\u062e\u0631\u0648\u062c\u06cc \u0632\u06cc\u0631 \u0631\u0627 \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>Output\r\n\u251c\u2500\u2500 djangoreactproject\r\n\u2502 \u251c\u2500\u2500 __init__.py\r\n\u2502 \u251c\u2500\u2500 settings.py\r\n\u2502 \u251c\u2500\u2500 urls.py\r\n\u2502 \u2514\u2500\u2500 wsgi.py\r\n\u2514\u2500\u2500 manage.py<\/code><\/pre>\n<\/div>\n<p>\u067e\u0648\u0634\u0647 ~\/djangoreactproject \u0631\u06cc\u0634\u0647 \u067e\u0631\u0648\u0698\u0647 \u0627\u0633\u062a. \u062f\u0631 \u0627\u06cc\u0646 \u067e\u0648\u0634\u0647\u060c \u0686\u0646\u062f\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0634\u0645\u0627 \u0645\u0647\u0645 \u0647\u0633\u062a\u0646\u062f:<\/p>\n<ul>\n<li>manager.py: \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u0628\u0632\u0627\u0631\u06cc \u06a9\u0647 \u062a\u0639\u062f\u0627\u062f\u06cc \u06a9\u0627\u0631 \u0627\u062f\u0627\u0631\u06cc \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f.<\/li>\n<li>settings.py: \u0641\u0627\u06cc\u0644 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0627\u0635\u0644\u06cc \u067e\u0631\u0648\u0698\u0647 \u062c\u0646\u06af\u0648 \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u062f. \u0627\u06cc\u0646 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0634\u0627\u0645\u0644 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f INSTALLED_APPS\u060c \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0631\u0634\u062a\u0647\u200c\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u0641\u0639\u0627\u0644 \u0631\u0627 \u0628\u0631\u0627\u06cc \u067e\u0631\u0648\u0698\u0647 \u0634\u0645\u0627 \u062a\u0639\u06cc\u06cc\u0646 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0627\u0633\u0646\u0627\u062f \u062c\u0646\u06af\u0648 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631\u06cc \u062f\u0631 \u0645\u0648\u0631\u062f \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0645\u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f.<\/li>\n<li>urls.py: \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u062d\u0627\u0648\u06cc \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0627\u0644\u06af\u0648\u0647\u0627\u06cc URL \u0648 \u0646\u0645\u0627\u0647\u0627\u06cc \u0645\u0631\u062a\u0628\u0637 \u0627\u0633\u062a. \u0647\u0631 \u0627\u0644\u06af\u0648 \u0627\u0631\u062a\u0628\u0627\u0637\u06cc \u0628\u06cc\u0646 URL \u0648 \u062a\u0627\u0628\u0639\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0631\u0627\u06cc \u0622\u0646 URL \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0634\u0648\u062f \u0631\u0627 \u062a\u0631\u0633\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u062f. \u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f URL \u0647\u0627 \u0648 \u0646\u0645\u0627\u0647\u0627\u060c \u0644\u0637\u0641\u0627\u064b \u0628\u0647 \u0622\u0645\u0648\u0632\u0634 \u0645\u0627 \u062f\u0631 \u0645\u0648\u0631\u062f \u0646\u062d\u0648\u0647 \u0627\u06cc\u062c\u0627\u062f \u0646\u0645\u0627\u0647\u0627\u06cc \u062c\u0646\u06af\u0648 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f.<\/li>\n<\/ul>\n<p>\u0627\u0648\u0644\u06cc\u0646 \u0642\u062f\u0645 \u0645\u0627 \u062f\u0631 \u06a9\u0627\u0631 \u0628\u0627 \u067e\u0631\u0648\u0698\u0647\u060c \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0628\u0633\u062a\u0647 \u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0642\u0628\u0644 \u0646\u0635\u0628 \u06a9\u0631\u062f\u06cc\u0645\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u0686\u0627\u0631\u0686\u0648\u0628 Django REST \u0648 \u0628\u0633\u062a\u0647 Django CORS\u060c \u0628\u0627 \u0627\u0641\u0632\u0648\u062f\u0646 \u0622\u0646\u0647\u0627 \u0628\u0647 settings.py. \u0641\u0627\u06cc\u0644 \u0631\u0627 \u0628\u0627 \u0646\u0627\u0646\u0648 \u06cc\u0627 \u0648\u06cc\u0631\u0627\u06cc\u0634\u06af\u0631 \u0645\u0648\u0631\u062f \u0639\u0644\u0627\u0642\u0647 \u062e\u0648\u062f \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano ~\/djangoreactproject\/djangoreactproject\/settings.py<\/code><\/pre>\n<\/div>\n<p>\u0628\u0647 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a INSTALLED_APPS \u0628\u0631\u0648\u06cc\u062f \u0648 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc rest_framework \u0648 corsheaders \u0631\u0627 \u0628\u0647 \u0627\u0646\u062a\u0647\u0627\u06cc \u0644\u06cc\u0633\u062a \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\nINSTALLED_APPS = [\r\n'django.contrib.admin',\r\n'django.contrib.auth',\r\n'django.contrib.contenttypes',\r\n'django.contrib.sessions',\r\n'django.contrib.messages',\r\n'django.contrib.staticfiles',\r\n'rest_framework',\r\n'corsheaders'\r\n]<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633\u060c \u0645\u06cc\u0627\u0646\u200c\u0627\u0641\u0632\u0627\u0631 corsheaders.middleware.CorsMiddleware \u0631\u0627 \u0627\u0632 \u0628\u0633\u062a\u0647 CORS \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u0646\u0635\u0628 \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0628\u0647 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a MIDDLEWARE \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f. \u0627\u06cc\u0646 \u062a\u0646\u0638\u06cc\u0645 \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0645\u06cc\u0627\u0646 \u0627\u0641\u0632\u0627\u0631\u0647\u0627 \u0627\u0633\u062a\u060c \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u067e\u0627\u06cc\u062a\u0648\u0646 \u06a9\u0647 \u062d\u0627\u0648\u06cc \u06a9\u062f\u0647\u0627\u06cc\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0647\u0631 \u0628\u0627\u0631 \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0634\u0645\u0627 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06cc\u0627 \u067e\u0627\u0633\u062e\u06cc \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f \u067e\u0631\u062f\u0627\u0632\u0634 \u0645\u06cc \u0634\u0648\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\nMIDDLEWARE = [\r\n...\r\n'django.contrib.messages.middleware.MessageMiddleware',\r\n'django.middleware.clickjacking.XFrameOptionsMiddleware',\r\n'corsheaders.middleware.CorsMiddleware'\r\n]<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f CORS \u0631\u0627 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f. \u062a\u0646\u0638\u06cc\u0645 CORS_ORIGIN_ALLOW_ALL \u0645\u0634\u062e\u0635 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0622\u06cc\u0627 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f CORS \u0631\u0627 \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 \u062f\u0627\u0645\u0646\u0647\u200c\u0647\u0627 \u0645\u062c\u0627\u0632 \u06a9\u0646\u06cc\u062f \u06cc\u0627 \u0646\u0647\u060c \u0648 CORS_ORIGIN_WHITELIST \u06cc\u06a9 \u062a\u0627\u067e\u0644 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0633\u062a \u06a9\u0647 \u062d\u0627\u0648\u06cc URL\u200c\u0647\u0627\u06cc \u0645\u062c\u0627\u0632 \u0627\u0633\u062a. \u062f\u0631 \u0645\u0648\u0631\u062f \u0645\u0627\u060c \u0686\u0648\u0646 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 React \u062f\u0631 http:\/\/localhost:3000 \u0627\u062c\u0631\u0627 \u062e\u0648\u0627\u0647\u062f \u0634\u062f\u060c \u062a\u0646\u0638\u06cc\u0645\u0627\u062a CORS_ORIGIN_ALLOW_ALL = False \u0648 CORS_ORIGIN_WHITELIST(&#8216;localhost:3000&#8217;,) \u062c\u062f\u06cc\u062f \u0631\u0627 \u0628\u0647 \u0641\u0627\u06cc\u0644 settings.py \u062e\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0627\u06cc\u0646 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0631\u0627 \u062f\u0631 \u0647\u0631 \u062c\u0627\u06cc\u06cc \u0627\u0632 \u0641\u0627\u06cc\u0644 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\nCORS_ORIGIN_ALLOW_ALL = False\r\nCORS_ORIGIN_WHITELIST = (\r\n'localhost:3000',\r\n)\r\n...<\/code><\/pre>\n<\/div>\n<p>\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0628\u06cc\u0634\u062a\u0631\u06cc \u0631\u0627 \u062f\u0631 \u0627\u0633\u0646\u0627\u062f django-cors-headers \u0628\u06cc\u0627\u0628\u06cc\u062f.<\/p>\n<p>\u0641\u0627\u06cc\u0644 \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u062f \u0648 \u067e\u0633 \u0627\u0632 \u0627\u062a\u0645\u0627\u0645 \u0627\u0632 \u0648\u06cc\u0631\u0627\u06cc\u0634\u06af\u0631 \u062e\u0627\u0631\u062c \u0634\u0648\u06cc\u062f.<\/p>\n<p>\u0647\u0646\u0648\u0632 \u062f\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc ~\/djangoreactproject\u060c \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u062f\u06cc\u062f \u062c\u0646\u06af\u0648 \u0628\u0647 \u0646\u0627\u0645 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0628\u0633\u0627\u0632\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>python manage.py startapp customers<\/code><\/pre>\n<\/div>\n<p>\u0627\u06cc\u0646 \u0634\u0627\u0645\u0644 \u0645\u062f\u0644\u200c\u0647\u0627 \u0648 \u062f\u06cc\u062f\u06af\u0627\u0647\u200c\u0647\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0627\u0633\u062a. \u0645\u062f\u0644\u200c\u0647\u0627 \u0641\u06cc\u0644\u062f\u0647\u0627 \u0648 \u0631\u0641\u062a\u0627\u0631\u0647\u0627\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0646\u0645\u0627\u0647\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0631\u0627 \u0642\u0627\u062f\u0631 \u0645\u06cc\u200c\u0633\u0627\u0632\u062f \u062a\u0627 \u0628\u0647 \u062f\u0631\u0633\u062a\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc \u0648\u0628 \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u06a9\u0646\u062f \u0648 \u067e\u0627\u0633\u062e\u200c\u0647\u0627\u06cc \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0631\u0627 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u0627\u06cc\u0646 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0647 \u0644\u06cc\u0633\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0646\u0635\u0628 \u0634\u062f\u0647 \u062f\u0631 \u0641\u0627\u06cc\u0644 settings.py \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u062c\u0646\u06af\u0648 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0628\u062e\u0634\u06cc \u0627\u0632 \u067e\u0631\u0648\u0698\u0647 \u062a\u0634\u062e\u06cc\u0635 \u062f\u0647\u062f. \u062a\u0646\u0638\u06cc\u0645\u0627\u062a.py \u0631\u0627 \u062f\u0648\u0628\u0627\u0631\u0647 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano ~\/djangoreactproject\/djangoreactproject\/settings.py<\/code><\/pre>\n<\/div>\n<p>\u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\nINSTALLED_APPS = [\r\n...\r\n'rest_framework',\r\n'corsheaders',\r\n'customers'\r\n]\r\n...<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633\u060c \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0631\u0627 \u0645\u0647\u0627\u062c\u0631\u062a \u06a9\u0631\u062f\u0647 \u0648 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u0645\u062d\u0644\u06cc \u0631\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f. \u0645\u0647\u0627\u062c\u0631\u062a \u0647\u0627 \u0631\u0648\u0634 \u062c\u0646\u06af\u0648 \u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0634\u0627\u0631 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631 \u0645\u062f\u0644 \u0647\u0627\u06cc \u062e\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u062f \u062f\u0631 \u0637\u0631\u062d\u0648\u0627\u0631\u0647 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0634\u0645\u0627. \u0627\u06cc\u0646 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0634\u0627\u0645\u0644 \u0645\u0648\u0627\u0631\u062f\u06cc \u0645\u0627\u0646\u0646\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u06cc\u06a9 \u0641\u06cc\u0644\u062f \u06cc\u0627 \u062d\u0630\u0641 \u06cc\u06a9 \u0645\u062f\u0644 \u0628\u0627\u0634\u062f. \u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f \u0645\u062f\u0644 \u0647\u0627 \u0648 \u0645\u0647\u0627\u062c\u0631\u062a \u0647\u0627\u060c \u0628\u0647 \u0646\u062d\u0648\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0647\u0627\u06cc \u062c\u0646\u06af\u0648 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0627\u0646\u062a\u0642\u0627\u0644 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>python manage.py migrate<\/code><\/pre>\n<\/div>\n<p>\u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u0645\u062d\u0644\u06cc \u0631\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>python manage.py runserver<\/code><\/pre>\n<\/div>\n<\/div>\n<p>\u062e\u0631\u0648\u062c\u06cc \u0645\u0634\u0627\u0628\u0647 \u0632\u06cc\u0631 \u0631\u0627 \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>Output\r\nPerforming system checks...\r\nSystem check identified no issues (0 silenced).\r\nOctober 22, 2018 - 15:14:50\r\nDjango version 2.1.2, using settings 'djangoreactproject.settings'\r\nStarting development server at http:\/\/127.0.0.1:8000\/\r\nQuit the server with CONTROL-C.<\/code><\/pre>\n<\/div>\n<p>\u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0634\u0645\u0627 \u0627\u0632 http:\/\/127.0.0.1:8000 \u0627\u062c\u0631\u0627 \u062e\u0648\u0627\u0647\u062f \u0634\u062f. \u0627\u06af\u0631 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0648\u0628 \u062e\u0648\u062f \u0628\u0647 \u0627\u06cc\u0646 \u0622\u062f\u0631\u0633 \u0628\u0631\u0648\u06cc\u062f\u060c \u0628\u0627\u06cc\u062f \u0635\u0641\u062d\u0647 \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0628\u06cc\u0646\u06cc\u062f:<\/p>\n<p><img  loading=\"lazy\"  decoding=\"async\"  src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAAP+KeNJXAAAAAXRSTlMAQObYZgAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAApJREFUCNdjYAAAAAIAAeIhvDMAAAAASUVORK5CYII=\"  alt=\"\"  width=\"2058\"  height=\"1390\"  class=\"aligncenter wp-image-15795 size-full pk-lazyload\"  data-pk-sizes=\"auto\"  data-ls-sizes=\"auto, (max-width: 2058px) 100vw, 2058px\"  data-pk-src=\"https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10.png\"  data-pk-srcset=\"https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10.png 2058w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-300x203.png 300w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-1024x692.png 1024w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-768x519.png 768w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-1536x1037.png 1536w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-2048x1383.png 2048w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-110x74.png 110w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-200x135.png 200w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-380x257.png 380w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-255x172.png 255w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-550x371.png 550w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-800x540.png 800w, https:\/\/cdn.itpiran.net\/2024\/06\/29200228\/1-10-1160x783.png 1160w\" ><\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647\u060c \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0627\u062c\u0631\u0627 \u0628\u06af\u0630\u0627\u0631\u06cc\u062f \u0648 \u06cc\u06a9 \u062a\u0631\u0645\u06cc\u0646\u0627\u0644 \u062c\u062f\u06cc\u062f \u0628\u0631\u0627\u06cc \u0627\u062f\u0627\u0645\u0647 \u062a\u0648\u0633\u0639\u0647 \u067e\u0631\u0648\u0698\u0647 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-3-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-react-frontend\">\u0645\u0631\u062d\u0644\u0647 3 &#8211; \u0627\u06cc\u062c\u0627\u062f React Frontend<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0628\u062e\u0634\u060c \u0645\u0627 \u0642\u0635\u062f \u062f\u0627\u0631\u06cc\u0645 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 front-end \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 React \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645.<\/p>\n<p>React \u06cc\u06a9 \u0627\u0628\u0632\u0627\u0631 \u0631\u0633\u0645\u06cc \u062f\u0627\u0631\u062f \u06a9\u0647 \u0628\u0647 \u0634\u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0628\u062f\u0648\u0646 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0645\u0633\u062a\u0642\u06cc\u0645 Webpack\u060c \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc React \u0631\u0627 \u0628\u0647 \u0633\u0631\u0639\u062a \u062a\u0648\u0644\u06cc\u062f \u06a9\u0646\u06cc\u062f. Webpack \u06cc\u06a9 \u0628\u0633\u062a\u0647 \u0645\u0627\u0698\u0648\u0644 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc \u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627\u06cc \u0648\u0628 \u0645\u0627\u0646\u0646\u062f \u06a9\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a\u060c CSS \u0648 \u062a\u0635\u0627\u0648\u06cc\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f. \u0628\u0647 \u0637\u0648\u0631 \u0645\u0639\u0645\u0648\u0644\u060c \u0642\u0628\u0644 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u0628\u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 Webpack \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0628\u0627\u06cc\u062f \u06af\u0632\u06cc\u0646\u0647 \u0647\u0627\u06cc \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f\u060c \u0627\u0645\u0627 \u0628\u0647 \u0644\u0637\u0641 \u0627\u0628\u0632\u0627\u0631 Create-react-app\u060c \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u062a\u0635\u0645\u06cc\u0645 \u0646\u06af\u06cc\u0631\u06cc\u062f \u0628\u0647 \u06a9\u0646\u062a\u0631\u0644 \u0628\u06cc\u0634\u062a\u0631\u06cc \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u062c\u0628\u0648\u0631 \u0646\u06cc\u0633\u062a\u06cc\u062f \u0645\u0633\u062a\u0642\u06cc\u0645\u0627\u064b \u0628\u0627 Webpack \u0633\u0631\u0648\u06a9\u0627\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f. \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc Create-react-app \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 npx \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0627\u0628\u0632\u0627\u0631\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u0646\u0631\u06cc \u0647\u0627\u06cc \u0628\u0633\u062a\u0647 npm \u0631\u0627 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u062a\u0631\u0645\u06cc\u0646\u0627\u0644 \u062f\u0648\u0645 \u062e\u0648\u062f\u060c \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u062f\u0631 \u0641\u0647\u0631\u0633\u062a \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0647\u0633\u062a\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject<\/code><\/pre>\n<\/div>\n<p>\u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 create-react-app \u0648 npx \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 React \u0628\u0647 \u0646\u0627\u0645 frontend \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npx create-react-app frontend<\/code><\/pre>\n<\/div>\n<p>\u0628\u0639\u062f\u060c \u062f\u0627\u062e\u0644 \u0628\u0631\u0646\u0627\u0645\u0647 React \u062e\u0648\u062f \u062d\u0631\u06a9\u062a \u06a9\u0646\u06cc\u062f \u0648 \u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 \u0631\u0627 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject\/frontend\r\nnpm start<\/code><\/pre>\n<\/div>\n<p>\u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0627\u0632 http:\/\/localhost:3000\/ \u0627\u062c\u0631\u0627 \u062e\u0648\u0627\u0647\u062f \u0634\u062f:<\/p>\n<p><img  loading=\"lazy\"  decoding=\"async\"  src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAAP+KeNJXAAAAAXRSTlMAQObYZgAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAApJREFUCNdjYAAAAAIAAeIhvDMAAAAASUVORK5CYII=\"  alt=\"\"  width=\"2080\"  height=\"1260\"  class=\"aligncenter wp-image-15796 size-full pk-lazyload\"  data-pk-sizes=\"auto\"  data-ls-sizes=\"auto, (max-width: 2080px) 100vw, 2080px\"  data-pk-src=\"https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8.png\"  data-pk-srcset=\"https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8.png 2080w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-300x182.png 300w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-1024x620.png 1024w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-768x465.png 768w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-1536x930.png 1536w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-2048x1241.png 2048w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-110x67.png 110w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-200x121.png 200w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-380x230.png 380w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-255x154.png 255w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-550x333.png 550w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-800x485.png 800w, https:\/\/cdn.itpiran.net\/2024\/06\/29200517\/2-8-1160x703.png 1160w\" ><\/p>\n<p>\u0633\u0631\u0648\u0631 \u062a\u0648\u0633\u0639\u0647 React \u0631\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0627\u062c\u0631\u0627 \u0628\u06af\u0630\u0627\u0631\u06cc\u062f \u0648 \u067e\u0646\u062c\u0631\u0647 \u062a\u0631\u0645\u06cc\u0646\u0627\u0644 \u062f\u06cc\u06af\u0631\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u062f\u0627\u0645\u0647 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0645\u0634\u0627\u0647\u062f\u0647 \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u06a9\u0644 \u067e\u0631\u0648\u0698\u0647 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647\u060c \u0628\u0647 \u067e\u0648\u0634\u0647 \u0631\u06cc\u0634\u0647 \u0628\u0631\u0648\u06cc\u062f \u0648 \u062f\u0648\u0628\u0627\u0631\u0647 \u062f\u0631\u062e\u062a \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject\r\ntree<\/code><\/pre>\n<\/div>\n<p>\u0633\u0627\u062e\u062a\u0627\u0631\u06cc \u0645\u0627\u0646\u0646\u062f \u0627\u06cc\u0646 \u0631\u0627 \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>Output\r\n\u251c\u2500\u2500 customers\r\n\u2502 \u251c\u2500\u2500 admin.py\r\n\u2502 \u251c\u2500\u2500 apps.py\r\n\u2502 \u251c\u2500\u2500 __init__.py\r\n\u2502 \u251c\u2500\u2500 migrations\r\n\u2502 \u2502 \u2514\u2500\u2500 __init__.py\r\n\u2502 \u251c\u2500\u2500 models.py\r\n\u2502 \u251c\u2500\u2500 tests.py\r\n\u2502 \u2514\u2500\u2500 views.py\r\n\u251c\u2500\u2500 djangoreactproject\r\n\u2502 \u251c\u2500\u2500 __init__.py\r\n\u2502 \u251c\u2500\u2500 __pycache__\r\n\u2502 \u251c\u2500\u2500 settings.py\r\n\u2502 \u251c\u2500\u2500 urls.py\r\n\u2502 \u2514\u2500\u2500 wsgi.py\r\n\u251c\u2500\u2500 frontend\r\n\u2502 \u251c\u2500\u2500 package.json\r\n\u2502 \u251c\u2500\u2500 public\r\n\u2502 \u2502 \u251c\u2500\u2500 favicon.ico\r\n\u2502 \u2502 \u251c\u2500\u2500 index.html\r\n\u2502 \u2502 \u2514\u2500\u2500 manifest.json\r\n\u2502 \u251c\u2500\u2500 README.md\r\n\u2502 \u251c\u2500\u2500 src\r\n\u2502 \u2502 \u251c\u2500\u2500 App.css\r\n\u2502 \u2502 \u251c\u2500\u2500 App.js\r\n\u2502 \u2502 \u251c\u2500\u2500 App.test.js\r\n\u2502 \u2502 \u251c\u2500\u2500 index.css\r\n\u2502 \u2502 \u251c\u2500\u2500 index.js\r\n\u2502 \u2502 \u251c\u2500\u2500 logo.svg\r\n\u2502 \u2502 \u2514\u2500\u2500 registerServiceWorker.js\r\n\u2502 \u2514\u2500\u2500 yarn.lock\r\n\u2514\u2500\u2500 manage.py<\/code><\/pre>\n<\/div>\n<p>\u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0627\u0632 Bootstrap 4 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0627\u06cc\u0644 \u062f\u0627\u062f\u0646 \u0628\u0647 \u0631\u0627\u0628\u0637 React \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0627 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644 frontend\/src\/App.css \u0642\u0631\u0627\u0631 \u0645\u06cc \u062f\u0647\u06cc\u0645 \u06a9\u0647 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a CSS \u0645\u0627 \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f. \u0641\u0627\u06cc\u0644 \u0631\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano ~\/djangoreactproject\/frontend\/src\/App.css<\/code><\/pre>\n<\/div>\n<p>\u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646 \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u0627\u0628\u062a\u062f\u0627\u06cc \u0641\u0627\u06cc\u0644 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f. \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0645\u062d\u062a\u0648\u0627\u06cc \u0645\u0648\u062c\u0648\u062f \u0641\u0627\u06cc\u0644 \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u06cc\u062f\u060c \u0627\u06af\u0631\u0686\u0647 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0644\u0627\u0632\u0645 \u0646\u06cc\u0633\u062a:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>@import 'https:\/\/maxcdn.bootstrapcdn.com\/bootstrap\/4.0.0\/css\/bootstrap.min.css';<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c @import \u06cc\u06a9 \u062f\u0633\u062a\u0648\u0631\u0627\u0644\u0639\u0645\u0644 CSS \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646 \u0642\u0648\u0627\u0646\u06cc\u0646 \u0633\u0628\u06a9 \u0627\u0632 \u0633\u0627\u06cc\u0631 \u0634\u06cc\u0648\u0647 \u0646\u0627\u0645\u0647 \u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u06a9\u0647 \u0647\u0631 \u062f\u0648 \u0628\u0631\u0646\u0627\u0645\u0647 Back-end \u0648 Front-end \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0645\u062f\u0644 Customer \u0648 \u0628\u0631\u062e\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634\u06cc \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%d9%85%d8%af%d9%84-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d9%88-%d8%af%d8%a7%d8%af%d9%87-%d9%87%d8%a7%db%8c-%d8%a7%d9%88%d9%84%db%8c\">\u0645\u0631\u062d\u0644\u0647 4 &#8211; \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u0648 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647<\/h2>\n<p>\u067e\u0633 \u0627\u0632 \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u062c\u0646\u06af\u0648 \u0648 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 React\u060c \u06af\u0627\u0645 \u0628\u0639\u062f\u06cc \u0645\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f \u06a9\u0647 \u0646\u0634\u0627\u0646\u200c\u062f\u0647\u0646\u062f\u0647 \u062c\u062f\u0648\u0644 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647\u200c\u0627\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0627 \u062f\u0631 \u062e\u0648\u062f \u0646\u06af\u0647 \u0645\u06cc\u200c\u062f\u0627\u0631\u062f. \u0634\u0645\u0627 \u0628\u0647 \u0647\u06cc\u0686 SQL \u0646\u06cc\u0627\u0632 \u0646\u062f\u0627\u0631\u06cc\u062f \u0632\u06cc\u0631\u0627 \u0646\u0642\u0634\u0647\u200c\u0628\u0631\u062f\u0627\u0631 \u0631\u0627\u0628\u0637\u0647\u200c\u0627\u06cc \u0634\u06cc \u062c\u0646\u06af\u0648 (ORM) \u0639\u0645\u0644\u06cc\u0627\u062a \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0631\u0627 \u0628\u0627 \u0646\u06af\u0627\u0634\u062a \u06a9\u0644\u0627\u0633\u200c\u0647\u0627 \u0648 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u0628\u0647 \u062c\u062f\u0627\u0648\u0644 \u0648 \u0633\u062a\u0648\u0646\u200c\u0647\u0627\u06cc SQL \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc\u200c\u062f\u0647\u062f. \u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 ORM \u062c\u0646\u06af\u0648 \u062a\u0639\u0627\u0645\u0644\u0627\u062a SQL \u0628\u0627 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06cc\u06a9 \u0631\u0627\u0628\u0637 \u067e\u0627\u06cc\u062a\u0648\u0646 \u062e\u0644\u0627\u0635\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0648\u0628\u0627\u0631\u0647 \u0645\u062d\u06cc\u0637 \u0645\u062c\u0627\u0632\u06cc \u062e\u0648\u062f \u0631\u0627 \u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\r\nsource env\/bin\/activate<\/code><\/pre>\n<\/div>\n<p>\u0628\u0647 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0628\u0631\u0648\u06cc\u062f \u0648 models.py \u0631\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f\u060c \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u067e\u0627\u06cc\u062a\u0648\u0646 \u06a9\u0647 \u0645\u062f\u0644 \u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0631\u0627 \u062f\u0631 \u062e\u0648\u062f \u0646\u06af\u0647 \u0645\u06cc \u062f\u0627\u0631\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject\/customers\/\r\nnano models.py<\/code><\/pre>\n<\/div>\n<p>\u0641\u0627\u06cc\u0644 \u062d\u0627\u0648\u06cc \u0645\u062d\u062a\u0648\u0627\u06cc \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from django.db import models\r\n# Create your models here.<\/code><\/pre>\n<\/div>\n<p>API \u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u0642\u0628\u0644\u0627\u064b \u0628\u0647 \u0644\u0637\u0641 \u0639\u0628\u0627\u0631\u062a import import models from django.db \u062f\u0631 \u0641\u0627\u06cc\u0644 \u0648\u0627\u0631\u062f \u0634\u062f\u0647 \u0627\u0633\u062a. \u0627\u06a9\u0646\u0648\u0646 \u06a9\u0644\u0627\u0633 Customer \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f \u06a9\u0647 models.Model \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u0645\u06cc \u062f\u0647\u062f. \u0647\u0631 \u0645\u062f\u0644 \u062f\u0631 \u062c\u0646\u06af\u0648 \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0633\u062a \u06a9\u0647 django.db.models.Model \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u062f\u0627\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0641\u06cc\u0644\u062f\u0647\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<ul>\n<li><code>first_name<\/code> &#8211; \u0646\u0627\u0645 \u06a9\u0648\u0686\u06a9 \u0645\u0634\u062a\u0631\u06cc.<\/li>\n<li><code>last_name<\/code> &#8211; \u0646\u0627\u0645 \u062e\u0627\u0646\u0648\u0627\u062f\u06af\u06cc \u0645\u0634\u062a\u0631\u06cc.<\/li>\n<li><code>EMAIL<\/code> &#8211; \u0622\u062f\u0631\u0633 \u0627\u06cc\u0645\u06cc\u0644 \u0645\u0634\u062a\u0631\u06cc.<\/li>\n<li><code>phone<\/code> &#8211; \u0634\u0645\u0627\u0631\u0647 \u062a\u0644\u0641\u0646 \u0645\u0634\u062a\u0631\u06cc.<\/li>\n<li><code>ADDRESS<\/code> &#8211; \u0622\u062f\u0631\u0633 \u0645\u0634\u062a\u0631\u06cc.<\/li>\n<li><code>DEScription<\/code> &#8211; \u062a\u0648\u0635\u06cc\u0641 \u0645\u0634\u062a\u0631\u06cc.<\/li>\n<li><code>createAt<\/code> &#8211; \u062a\u0627\u0631\u06cc\u062e\u06cc \u06a9\u0647 \u0645\u0634\u062a\u0631\u06cc \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<\/ul>\n<p>\u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u062a\u0627\u0628\u0639 __str__() \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0646\u062d\u0648\u0647 \u0646\u0645\u0627\u06cc\u0634 \u0645\u062f\u0644 \u0631\u0627 \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u062f. \u062f\u0631 \u0645\u0648\u0631\u062f \u0645\u0627\u060c \u0628\u0627 \u0646\u0627\u0645 \u06a9\u0648\u0686\u06a9 \u0645\u0634\u062a\u0631\u06cc \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f. \u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f \u0633\u0627\u062e\u062a \u06a9\u0644\u0627\u0633 \u0647\u0627 \u0648 \u062a\u0639\u0631\u06cc\u0641 \u0627\u0634\u06cc\u0627\u060c \u0644\u0637\u0641\u0627\u064b \u0628\u0647 \u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06a9\u0644\u0627\u0633 \u0647\u0627 \u0648 \u062a\u0639\u0631\u06cc\u0641 \u0627\u0634\u06cc\u0627\u0621 \u062f\u0631 \u067e\u0627\u06cc\u062a\u0648\u0646 3 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u0641\u0627\u06cc\u0644 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from django.db import models\r\nclass Customer(models.Model):\r\nfirst_name = models.CharField(\"First name\", max_length=255)\r\nlast_name = models.CharField(\"Last name\", max_length=255)\r\nemail = models.EmailField()\r\nphone = models.CharField(max_length=20)\r\naddress = models.TextField(blank=True, null=True)\r\ndescription = models.TextField(blank=True, null=True)\r\ncreatedAt = models.DateTimeField(\"Created At\", auto_now_add=True)\r\n\r\ndef __str__(self):\r\nreturn self.first_name<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062c\u062f\u0627\u0648\u0644 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0645\u0646\u062a\u0642\u0644 \u06a9\u0646\u06cc\u062f. \u062f\u0633\u062a\u0648\u0631 makemigrations \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0645\u0647\u0627\u062c\u0631\u062a \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0645\u062f\u0644 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f\u060c \u0648 migrate \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0641\u0627\u06cc\u0644\u200c\u0647\u0627\u06cc \u0645\u0647\u0627\u062c\u0631\u062a \u0631\u0627 \u0628\u0647 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0627\u0639\u0645\u0627\u0644 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0647 \u067e\u0648\u0634\u0647 \u0631\u06cc\u0634\u0647 \u067e\u0631\u0648\u0698\u0647 \u0628\u0631\u06af\u0631\u062f\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject<\/code><\/pre>\n<\/div>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0641\u0627\u06cc\u0644 \u0647\u0627\u06cc \u0645\u0647\u0627\u062c\u0631\u062a\u060c \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>python manage.py makemigrations<\/code><\/pre>\n<\/div>\n<p>\u062e\u0631\u0648\u062c\u06cc \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u062f\u0631\u06cc\u0627\u0641\u062a \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>Output\r\ncustomers\/migrations\/0001_initial.py\r\n- Create model Customer<\/code><\/pre>\n<\/div>\n<p>\u0627\u06cc\u0646 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0631\u0627 \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>python manage.py migrate<\/code><\/pre>\n<\/div>\n<p>\u062e\u0631\u0648\u062c\u06cc \u0627\u06cc \u0631\u0627 \u0645\u0634\u0627\u0647\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f \u06a9\u0647 \u0627\u0646\u062a\u0642\u0627\u0644 \u0645\u0648\u0641\u0642\u06cc\u062a \u0622\u0645\u06cc\u0632 \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>Output\r\nOperations to perform:\r\nApply all migrations: admin, auth, contenttypes, customers, sessions\r\nRunning migrations:\r\nApplying customers.0001_initial... OK<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u0627\u0632 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0627\u0646\u062a\u0642\u0627\u0644 \u062f\u0627\u062f\u0647 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0645\u0634\u062a\u0631\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f. \u0641\u0627\u06cc\u0644 \u0627\u0646\u062a\u0642\u0627\u0644 \u062f\u0627\u062f\u0647\u060c \u0645\u0647\u0627\u062c\u0631\u062a\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0627\u0636\u0627\u0641\u0647 \u06cc\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u06cc \u062f\u0647\u062f. \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0627\u0646\u062a\u0642\u0627\u0644 \u062f\u0627\u062f\u0647 \u062e\u0627\u0644\u06cc \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>python manage.py makemigrations --empty --name customers customers<\/code><\/pre>\n<\/div>\n<p>\u062a\u0623\u06cc\u06cc\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0627 \u0646\u0627\u0645 \u0641\u0627\u06cc\u0644 \u0645\u0647\u0627\u062c\u0631\u062a \u062e\u0648\u062f \u0645\u0634\u0627\u0647\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0631\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>Output\r\nMigrations for 'customers':\r\ncustomers\/migrations\/0002_customers.py<\/code><\/pre>\n<\/div>\n<p>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0646\u0627\u0645 \u0641\u0627\u06cc\u0644 \u0645\u0647\u0627\u062c\u0631\u062a \u0634\u0645\u0627 0002_customers.py \u0627\u0633\u062a.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u062f\u0627\u062e\u0644 \u067e\u0648\u0634\u0647 migrations \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062d\u0631\u06a9\u062a \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject\/customers\/migrations<\/code><\/pre>\n<\/div>\n<p>\u0641\u0627\u06cc\u0644 \u0645\u0647\u0627\u062c\u0631\u062a \u0627\u06cc\u062c\u0627\u062f \u0634\u062f\u0647 \u0631\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano 0002_customers.py<\/code><\/pre>\n<\/div>\n<p>\u0627\u06cc\u0646 \u0645\u062d\u062a\u0648\u0627\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0641\u0627\u06cc\u0644 \u0627\u0633\u062a:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from django.db import migrations\r\n\r\nclass Migration(migrations.Migration):\r\ndependencies = [\r\n('customers', '0001_initial'),\r\n]\r\noperations = [\r\n]<\/code><\/pre>\n<\/div>\n<p>\u062f\u0633\u062a\u0648\u0631 import\u060c Migrations API \u0631\u0627 \u0648\u0627\u0631\u062f \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u06cc\u06a9 API \u062c\u0646\u06af\u0648 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u0647\u0627\u062c\u0631\u062a\u060c \u0627\u0632 django.db\u060c \u06cc\u06a9 \u0628\u0633\u062a\u0647 \u062f\u0627\u062e\u0644\u06cc \u06a9\u0647 \u0634\u0627\u0645\u0644 \u06a9\u0644\u0627\u0633\u200c\u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631 \u0628\u0627 \u067e\u0627\u06cc\u06af\u0627\u0647\u200c\u0647\u0627\u06cc \u062f\u0627\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u06a9\u0644\u0627\u0633 Migration \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u067e\u0627\u06cc\u062a\u0648\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0639\u0645\u0644\u06cc\u0627\u062a\u06cc \u0631\u0627 \u06a9\u0647 \u0647\u0646\u06af\u0627\u0645 \u0645\u0647\u0627\u062c\u0631\u062a \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f \u0631\u0627 \u062a\u0648\u0635\u06cc\u0641 \u0645\u06cc \u06a9\u0646\u062f. \u0627\u06cc\u0646 \u06a9\u0644\u0627\u0633 migrations.Migration \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u0645\u06cc \u062f\u0647\u062f \u0648 \u062f\u0648 \u0644\u06cc\u0633\u062a \u062f\u0627\u0631\u062f:<\/p>\n<ul>\n<li><code>dependencies<\/code>: \u0634\u0627\u0645\u0644 \u0645\u0647\u0627\u062c\u0631\u062a \u0647\u0627\u06cc \u0648\u0627\u0628\u0633\u062a\u0647 \u0627\u0633\u062a.<\/li>\n<li><code>operations<\/code>: \u0634\u0627\u0645\u0644 \u0639\u0645\u0644\u06cc\u0627\u062a\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u0627\u0639\u0645\u0627\u0644 \u0645\u0647\u0627\u062c\u0631\u062a \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<\/ul>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u0631\u0648\u0634\u06cc \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f. \u0642\u0628\u0644 \u0627\u0632 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0644\u0627\u0633 Migration \u0645\u062a\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\ndef create_data(apps, schema_editor):\r\nCustomer = apps.get_model('customers', 'Customer')\r\nCustomer(first_name=\"Customer 001\", last_name=\"Customer 001\", email=\"customer001@email.com\", phone=\"00000000\", address=\"Customer 000 Address\", description= \"Customer 001 description\").save()\r\n...<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0648\u0634\u060c \u0645\u0627 \u06a9\u0644\u0627\u0633 Customer \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062e\u0648\u062f \u0631\u0627 \u0645\u06cc \u06af\u06cc\u0631\u06cc\u0645 \u0648 \u06cc\u06a9 \u0645\u0634\u062a\u0631\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0628\u0631\u0627\u06cc \u062f\u0631\u062c \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0644\u0627\u0633 Customer\u060c \u06a9\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062c\u062f\u06cc\u062f \u0631\u0627 \u0627\u0645\u06a9\u0627\u0646 \u067e\u0630\u06cc\u0631 \u0645\u06cc \u06a9\u0646\u062f\u060c \u0627\u0632 \u0645\u062a\u062f get_model() \u0634\u06cc apps \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0634\u06cc apps \u0646\u0634\u0627\u0646 \u062f\u0647\u0646\u062f\u0647 \u0631\u062c\u06cc\u0633\u062a\u0631\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0646\u0635\u0628 \u0634\u062f\u0647 \u0648 \u0645\u062f\u0644 \u0647\u0627\u06cc \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0622\u0646\u0647\u0627 \u0627\u0633\u062a.<\/p>\n<p>\u0648\u0642\u062a\u06cc \u0627\u0632 \u0645\u062a\u062f RunPython() \u0628\u0631\u0627\u06cc \u0627\u062c\u0631\u0627\u06cc ()create_data \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645\u060c \u0634\u06cc apps \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f. \u0645\u062a\u062f migrations.RunPython() \u0631\u0627 \u0628\u0647 \u0644\u06cc\u0633\u062a \u0639\u0645\u0644\u06cc\u0627\u062a \u062e\u0627\u0644\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\noperations = [\r\nmigrations.RunPython(create_data),\r\n]<\/code><\/pre>\n<\/div>\n<p>RunPython() \u0628\u062e\u0634\u06cc \u0627\u0632 Migrations API \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0634\u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u06a9\u062f\u0647\u0627\u06cc \u067e\u0627\u06cc\u062a\u0648\u0646 \u0633\u0641\u0627\u0631\u0634\u06cc \u0631\u0627 \u062f\u0631 \u06cc\u06a9 \u0645\u0647\u0627\u062c\u0631\u062a \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f. \u0644\u06cc\u0633\u062a \u0639\u0645\u0644\u06cc\u0627\u062a \u0645\u0627 \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0627\u06cc\u0646 \u0645\u062a\u062f \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0645\u0627 \u0645\u0647\u0627\u062c\u0631\u062a \u0631\u0627 \u0627\u0639\u0645\u0627\u0644 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0627\u062c\u0631\u0627 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0627\u06cc\u0646 \u0647\u0645 \u0641\u0627\u06cc\u0644 \u06a9\u0627\u0645\u0644:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from django.db import migrations\r\n\r\ndef create_data(apps, schema_editor):\r\nCustomer = apps.get_model('customers', 'Customer')\r\nCustomer(first_name=\"Customer 001\", last_name=\"Customer 001\", email=\"customer001@email.com\", phone=\"00000000\", address=\"Customer 000 Address\", description= \"Customer 001 description\").save()\r\n\r\nclass Migration(migrations.Migration):\r\ndependencies = [\r\n('customers', '0001_initial'),\r\n]\r\noperations = [\r\nmigrations.RunPython(create_data),\r\n]<\/code><\/pre>\n<\/div>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f \u0627\u0646\u062a\u0642\u0627\u0644 \u062f\u0627\u062f\u0647 \u0647\u0627\u060c \u0628\u0647 \u0645\u0633\u062a\u0646\u062f\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0627\u0646\u062a\u0642\u0627\u0644 \u062f\u0627\u062f\u0647 \u0647\u0627 \u062f\u0631 \u062c\u0646\u06af\u0648 \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0646\u062a\u0642\u0627\u0644 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u062e\u0648\u062f\u060c \u0627\u0628\u062a\u062f\u0627 \u0628\u0647 \u067e\u0648\u0634\u0647 \u0627\u0635\u0644\u06cc \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0628\u0627\u0632\u06af\u0631\u062f\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject<\/code><\/pre>\n<\/div>\n<p>\u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0622\u0632\u0645\u0627\u06cc\u0634\u06cc \u0645\u0647\u0627\u062c\u0631\u062a \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>python manage.py migrate<\/code><\/pre>\n<\/div>\n<p>\u062e\u0631\u0648\u062c\u06cc \u0631\u0627 \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u06cc\u062f \u06a9\u0647 \u0645\u0647\u0627\u062c\u0631\u062a \u0631\u0627 \u062a\u0623\u06cc\u06cc\u062f \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>Output\r\nOperations to perform:\r\nApply all migrations: admin, auth, contenttypes, customers, sessions\r\nRunning migrations:\r\nApplying customers.0002_customers... OK<\/code><\/pre>\n<\/div>\n<p>\u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u0648 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634\u06cc\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u0633\u0627\u062e\u062a REST API \u0628\u0631\u0648\u06cc\u0645.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-5-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-rest-api\">\u0645\u0631\u062d\u0644\u0647 5 &#8211; \u0627\u06cc\u062c\u0627\u062f REST API<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647 \u0645\u0627 REST API \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0686\u0627\u0631\u0686\u0648\u0628 Django REST \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0645\u0627 \u0686\u0646\u062f\u06cc\u0646 \u0646\u0645\u0627\u06cc API \u0645\u062e\u062a\u0644\u0641 \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f. \u0646\u0645\u0627\u06cc API \u062a\u0627\u0628\u0639\u06cc \u0627\u0633\u062a \u06a9\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06cc\u0627 \u062a\u0645\u0627\u0633 API \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f\u060c \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc API \u06cc\u06a9 URL \u0645\u0646\u062d\u0635\u0631 \u0628\u0647 \u0641\u0631\u062f \u0627\u0633\u062a \u06a9\u0647 \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u062a\u0645\u0627\u0633 \u0631\u0627 \u0628\u0627 \u0633\u06cc\u0633\u062a\u0645 REST \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f. \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a GET \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc API \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f\u060c \u062c\u0646\u06af\u0648 \u062a\u0627\u0628\u0639 \u0645\u0631\u0628\u0648\u0637\u0647 \u06cc\u0627 \u0646\u0645\u0627\u06cc API \u0631\u0627 \u0628\u0631\u0627\u06cc \u0631\u0633\u06cc\u062f\u06af\u06cc \u0628\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0648 \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0646 \u0646\u062a\u0627\u06cc\u062c \u0627\u062d\u062a\u0645\u0627\u0644\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0627\u0632 \u0633\u0631\u06cc\u0627\u0644 \u0633\u0627\u0632\u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f. \u06cc\u06a9 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632 \u062f\u0631 \u0686\u0627\u0631\u0686\u0648\u0628 Django REST \u0628\u0647 \u0646\u0645\u0648\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u062f\u0644 \u067e\u06cc\u0686\u06cc\u062f\u0647 \u0648 QuerySets \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u062a\u0627 \u0628\u0631\u0627\u06cc \u0645\u0635\u0631\u0641 API \u0628\u0647 \u0641\u0631\u0645\u062a JSON \u062a\u0628\u062f\u06cc\u0644 \u0634\u0648\u0646\u062f. \u06a9\u0644\u0627\u0633 \u0633\u0631\u06cc\u0627\u0644 \u0633\u0627\u0632 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u062f\u0631 \u062c\u0647\u062a \u062f\u06cc\u06af\u0631 \u06a9\u0627\u0631 \u06a9\u0646\u062f \u0648 \u0645\u06a9\u0627\u0646\u06cc\u0633\u0645 \u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u062a\u062c\u0632\u06cc\u0647 \u0648 \u062c\u062f\u0627\u0633\u0627\u0632\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627 \u062f\u0631 \u0645\u062f\u0644 \u0647\u0627\u06cc \u062c\u0646\u06af\u0648 \u0648 \u0645\u062c\u0645\u0648\u0639\u0647 \u0647\u0627\u06cc Query \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc API \u0645\u0627 \u0634\u0627\u0645\u0644 \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<ul>\n<li>api\/customers: \u0627\u06cc\u0646 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0648 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0646 \u0645\u062c\u0645\u0648\u0639\u0647 \u0647\u0627\u06cc \u0635\u0641\u062d\u0647 \u0628\u0646\u062f\u06cc \u0634\u062f\u0647 \u0627\u0632 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.<\/li>\n<li>api\/customers\/&lt;pk&gt;: \u0627\u06cc\u0646 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a\u060c \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0648 \u062d\u0630\u0641 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062a\u06a9\u06cc \u0628\u0627 \u06a9\u0644\u06cc\u062f \u0627\u0635\u0644\u06cc \u06cc\u0627 \u0634\u0646\u0627\u0633\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u062f.<\/li>\n<\/ul>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646 \u0622\u062f\u0631\u0633\u200c\u0647\u0627\u06cc\u06cc \u0631\u0627 \u062f\u0631 \u0641\u0627\u06cc\u0644 urls.py \u067e\u0631\u0648\u0698\u0647 \u0628\u0631\u0627\u06cc \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0645\u0631\u0628\u0648\u0637\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 (\u06cc\u0639\u0646\u06cc api\/customers \u0648 api\/customers\/&lt;pk&gt;).<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0644\u0627\u0633 \u0633\u0631\u06cc\u0627\u0644 \u0633\u0627\u0632 \u0628\u0631\u0627\u06cc \u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u062e\u0648\u062f \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u0645.<\/p>\n<h5 id=\"%d8%a7%d8%b6%d8%a7%d9%81%d9%87-%da%a9%d8%b1%d8%af%d9%86-%da%a9%d9%84%d8%a7%d8%b3-%d8%b3%d8%b1%db%8c%d8%a7%d9%84-%d8%b3%d8%a7%d8%b2\">\u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u06a9\u0644\u0627\u0633 \u0633\u0631\u06cc\u0627\u0644 \u0633\u0627\u0632<\/h5>\n<p>\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632 \u0628\u0631\u0627\u06cc \u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u0645\u0627 \u0628\u0631\u0627\u06cc \u062a\u0628\u062f\u06cc\u0644 \u0646\u0645\u0648\u0646\u0647\u200c\u0647\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc \u0648 QuerySets \u0628\u0647 \u0648 \u0627\u0632 JSON \u0636\u0631\u0648\u0631\u06cc \u0627\u0633\u062a. \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0644\u0627\u0633 serializer\u060c \u0627\u0628\u062a\u062f\u0627 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 serializers.py \u062f\u0631 \u062f\u0627\u062e\u0644 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject\/customers\/\r\nnano serializers.py<\/code><\/pre>\n<\/div>\n<p>\u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646 API \u0633\u0631\u06cc\u0627\u0644 \u0648 \u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from rest_framework import serializers\r\nfrom .models import Customer<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632\u0647\u0627 \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u0645\u06cc\u200c\u062f\u0647\u062f.ModelSerializer \u0648 \u0641\u06cc\u0644\u062f\u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632\u06cc \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0631\u0627 \u0645\u0634\u062e\u0635 \u0645\u06cc\u200c\u06a9\u0646\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\nclass CustomerSerializer(serializers.ModelSerializer):\r\n\r\nclass Meta:\r\nmodel = Customer\r\nfields = ('pk','first_name', 'last_name', 'email', 'phone','address','description')<\/code><\/pre>\n<\/div>\n<p>\u06a9\u0644\u0627\u0633 Meta \u0645\u062f\u0644 \u0648 \u0641\u06cc\u0644\u062f\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0633\u0631\u06cc\u0627\u0644 \u0633\u0627\u0632\u06cc \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u062f: pk,first_name, last_name, email, phone, address, description.<\/p>\n<p>\u0627\u06cc\u0646\u0645 \u0645\u062d\u062a\u0648\u0627\u06cc \u06a9\u0627\u0645\u0644 \u0641\u0627\u06cc\u0644:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from rest_framework import serializers\r\nfrom .models import Customer\r\n\r\nclass CustomerSerializer(serializers.ModelSerializer):\r\n\r\nclass Meta:\r\nmodel = Customer\r\nfields = ('pk','first_name', 'last_name', 'email', 'phone','address','description')<\/code><\/pre>\n<\/div>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u06a9\u0647 \u06a9\u0644\u0627\u0633 \u0633\u0631\u06cc\u0627\u0644 \u0633\u0627\u0632 \u062e\u0648\u062f \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0646\u0645\u0627\u0647\u0627\u06cc API \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<h5 id=\"%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86-%d9%86%d9%85%d8%a7%d9%87%d8%a7%db%8c-api\">\u0627\u0641\u0632\u0648\u062f\u0646 \u0646\u0645\u0627\u0647\u0627\u06cc API<\/h5>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0628\u062e\u0634\u060c \u0646\u0645\u0627\u0647\u0627\u06cc API \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0632 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u062a\u0627\u0628\u0639 view \u0628\u0627\u0632\u062f\u06cc\u062f \u0645\u06cc \u06a9\u0646\u062f\u060c \u062a\u0648\u0633\u0637 \u062c\u0646\u06af\u0648 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p><code>~\/djangoreactproject\/customers\/views.py<\/code> \u0631\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano ~\/djangoreactproject\/customers\/views.py<\/code><\/pre>\n<\/div>\n<p>\u0645\u0648\u0627\u0631\u062f \u0645\u0648\u062c\u0648\u062f \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u06cc\u062f \u0648 \u0648\u0627\u0631\u062f\u0627\u062a \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from rest_framework.response import Response\r\nfrom rest_framework.decorators import api_view\r\nfrom rest_framework import status\r\nfrom django.core.paginator import Paginator, EmptyPage, PageNotAnInteger\r\nfrom .models import Customer \r\nfrom .serializers import *<\/code><\/pre>\n<\/div>\n<p>\u0645\u0627 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632\u06cc\u200c\u0627\u06cc \u0631\u0627 \u06a9\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u06cc\u0645\u060c \u0647\u0645\u0631\u0627\u0647 \u0628\u0627 \u0645\u062f\u0644 \u0645\u0634\u062a\u0631\u06cc \u0648 API\u0647\u0627\u06cc \u0686\u0627\u0631\u0686\u0648\u0628 REST \u062c\u0646\u06af\u0648 \u0648 \u062c\u0646\u06af\u0648 \u0648\u0627\u0631\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0633\u067e\u0633\u060c \u0646\u0645\u0627\u06cc \u067e\u0631\u062f\u0627\u0632\u0634 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc POST \u0648 GET HTTP \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\n@api_view(['GET', 'POST'])\r\ndef customers_list(request):\r\n\"\"\"\r\nList customers, or create a new customer.\r\n\"\"\"\r\nif request.method == 'GET':\r\ndata = []\r\nnextPage = 1\r\npreviousPage = 1\r\ncustomers = Customer.objects.all()\r\npage = request.GET.get('page', 1)\r\npaginator = Paginator(customers, 10)\r\ntry:\r\ndata = paginator.page(page)\r\nexcept PageNotAnInteger:\r\ndata = paginator.page(1)\r\nexcept EmptyPage:\r\ndata = paginator.page(paginator.num_pages)\r\nserializer = CustomerSerializer(data,context={'request': request} ,many=True)\r\nif data.has_next():\r\nnextPage = data.next_page_number()\r\nif data.has_previous():\r\npreviousPage = data.previous_page_number()\r\nreturn Response({'data': serializer.data , 'count': paginator.count, 'numpages' : paginator.num_pages, 'nextlink': '\/api\/customers\/?page=' + str(nextPage), 'prevlink': '\/api\/customers\/?page=' + str(previousPage)})\r\nelif request.method == 'POST':\r\nserializer = CustomerSerializer(data=request.data)\r\nif serializer.is_valid():\r\nserializer.save()\r\nreturn Response(serializer.data, status=status.HTTP_201_CREATED)\r\nreturn Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)<\/code><\/pre>\n<\/div>\n<p>\u0627\u0628\u062a\u062f\u0627 \u0627\u0632 \u062f\u06a9\u0648\u0631\u0627\u062a\u0648\u0631 @api_view([&#8216;GET&#8217;, &#8216;POST&#8217;]) \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0646\u0645\u0627\u06cc API \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0628\u062a\u0648\u0627\u0646\u062f \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc GET \u0648 POST \u0631\u0627 \u0628\u067e\u0630\u06cc\u0631\u062f. \u062f\u06a9\u0648\u0631\u0627\u062a\u0648\u0631 \u0639\u0645\u0644\u06a9\u0631\u062f\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0639\u0645\u0644\u06a9\u0631\u062f \u062f\u06cc\u06af\u0631\u06cc \u0631\u0627 \u0628\u0631 \u0639\u0647\u062f\u0647 \u0645\u06cc \u06af\u06cc\u0631\u062f \u0648 \u0628\u0647 \u0635\u0648\u0631\u062a \u067e\u0648\u06cc\u0627 \u0622\u0646 \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u0645\u06cc \u062f\u0647\u062f.<\/p>\n<p>\u062f\u0631 \u0628\u062f\u0646\u0647 \u0645\u062a\u062f\u060c \u0627\u0632 \u0645\u062a\u063a\u06cc\u0631 request.method \u0628\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0631\u0648\u0634 HTTP \u0641\u0639\u0644\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u0645\u0646\u0637\u0642 \u0645\u0631\u0628\u0648\u0637\u0647 \u0631\u0627 \u0628\u0633\u062a\u0647 \u0628\u0647 \u0646\u0648\u0639 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<ul>\n<li>\u0627\u06af\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a GET \u0628\u0627\u0634\u062f\u060c \u0627\u06cc\u0646 \u0631\u0648\u0634 \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Django Paginator \u0635\u0641\u062d\u0647\u200c\u0628\u0646\u062f\u06cc \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u0635\u0641\u062d\u0647 \u0627\u0648\u0644 \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u0631\u0627 \u067e\u0633 \u0627\u0632 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632\u06cc\u060c \u062a\u0639\u062f\u0627\u062f \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633\u060c \u062a\u0639\u062f\u0627\u062f \u0635\u0641\u062d\u0627\u062a \u0645\u0648\u062c\u0648\u062f \u0648 \u067e\u06cc\u0648\u0646\u062f\u0647\u0627\u06cc \u0635\u0641\u062d\u0627\u062a \u0642\u0628\u0644\u06cc \u0648 \u0628\u0639\u062f\u06cc \u0631\u0627 \u0628\u0631\u0645\u06cc\u200c\u06af\u0631\u062f\u0627\u0646\u062f. Paginator \u06cc\u06a9 \u06a9\u0644\u0627\u0633 Django \u062f\u0627\u062e\u0644\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0641\u0647\u0631\u0633\u062a\u06cc \u0627\u0632 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062f\u0631 \u0635\u0641\u062d\u0627\u062a \u0635\u0641\u062d\u0647 \u0628\u0646\u062f\u06cc \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0631\u0648\u0634 \u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u0622\u06cc\u062a\u0645 \u0647\u0627\u06cc \u0647\u0631 \u0635\u0641\u062d\u0647 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f.<\/li>\n<li>\u0627\u06af\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a POST \u0628\u0627\u0634\u062f\u060c \u0645\u062a\u062f \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a\u06cc \u0631\u0627 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632\u06cc \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u0633\u067e\u0633 \u0645\u062a\u062f save() \u0634\u06cc \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632 \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc\u200c\u06a9\u0646\u062f. \u0633\u067e\u0633 \u06cc\u06a9 \u0634\u06cc Response\u060c \u0646\u0645\u0648\u0646\u0647 \u0627\u06cc \u0627\u0632 HttpResponse\u060c \u0628\u0627 \u06a9\u062f \u0648\u0636\u0639\u06cc\u062a 201 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f. \u0647\u0631 \u0646\u0645\u0627\u06cc\u0647 \u0627\u06cc \u06a9\u0647 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u062f \u0645\u0633\u0626\u0648\u0644 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0646 \u06cc\u06a9 \u0634\u06cc HttpResponse \u0627\u0633\u062a. \u0645\u062a\u062f save() \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0633\u0631\u06cc\u0627\u0644 \u0634\u062f\u0647 \u0631\u0627 \u062f\u0631 \u067e\u0627\u06cc\u06af\u0627\u0647 \u062f\u0627\u062f\u0647 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<\/ul>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f HttpResponse \u0648 view \u0647\u0627\u060c \u0628\u0647 \u0627\u06cc\u0646 \u0628\u062d\u062b \u062f\u0631 \u0645\u0648\u0631\u062f \u0627\u06cc\u062c\u0627\u062f \u062a\u0648\u0627\u0628\u0639 view \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0646\u0645\u0627\u06cc API \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0645\u0633\u0626\u0648\u0644 \u067e\u0631\u062f\u0627\u0632\u0634 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc GET\u060c PUT \u0648 DELETE \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a\u060c \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0648 \u062d\u0630\u0641 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062a\u0648\u0633\u0637 pk (\u06a9\u0644\u06cc\u062f \u0627\u0635\u0644\u06cc) \u0627\u0633\u062a:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\n@api_view(['GET', 'PUT', 'DELETE'])\r\ndef customers_detail(request, pk):\r\n\"\"\"\r\nRetrieve, update or delete a customer by id\/pk.\r\n\"\"\"\r\ntry:\r\ncustomer = Customer.objects.get(pk=pk)\r\nexcept Customer.DoesNotExist:\r\nreturn Response(status=status.HTTP_404_NOT_FOUND)\r\n\r\nif request.method == 'GET':\r\nserializer = CustomerSerializer(customer,context={'request': request})\r\nreturn Response(serializer.data)\r\n\r\nelif request.method == 'PUT':\r\nserializer = CustomerSerializer(customer, data=request.data,context={'request': request})\r\nif serializer.is_valid():\r\nserializer.save()\r\nreturn Response(serializer.data)\r\nreturn Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)\r\n\r\nelif request.method == 'DELETE':\r\ncustomer.delete()\r\nreturn Response(status=status.HTTP_204_NO_CONTENT)<\/code><\/pre>\n<\/div>\n<p>\u0627\u06cc\u0646 \u0631\u0648\u0634 \u0628\u0627 @api_view ([&#8216;GET&#8217;, &#8216;PUT&#8217;, &#8216;DELETE&#8217;]) \u062a\u0632\u0626\u06cc\u0646 \u0634\u062f\u0647 \u0627\u0633\u062a \u062a\u0627 \u0646\u0634\u0627\u0646 \u062f\u0647\u062f \u06a9\u0647 \u06cc\u06a9 \u0646\u0645\u0627\u06cc API \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627\u06cc GET\u060c PUT \u0648 DELETE \u0631\u0627 \u0628\u067e\u0630\u06cc\u0631\u062f.<\/p>\n<p>\u0686\u06a9 \u062f\u0631 \u0641\u06cc\u0644\u062f request.method \u0631\u0648\u0634 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0631\u0627 \u062a\u0623\u06cc\u06cc\u062f \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0633\u062a\u0647 \u0628\u0647 \u0645\u0642\u062f\u0627\u0631 \u0622\u0646 \u0645\u0646\u0637\u0642 \u062f\u0631\u0633\u062a \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<ul>\n<li>\u0627\u06af\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a GET \u0628\u0627\u0634\u062f\u060c \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632\u06cc \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0648 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0634\u06cc Response \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f.<\/li>\n<li>\u0627\u06af\u0631 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a PUT \u0628\u0627\u0634\u062f\u060c \u0627\u06cc\u0646 \u0631\u0648\u0634 \u06cc\u06a9 \u0633\u0631\u06cc\u0627\u0644\u200c\u0633\u0627\u0632 \u0628\u0631\u0627\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u062f. \u0633\u067e\u0633\u060c \u0645\u062a\u062f save() \u0634\u06cc \u0633\u0631\u06cc\u0627\u0644 \u0633\u0627\u0632 \u0627\u06cc\u062c\u0627\u062f \u0634\u062f\u0647 \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f. \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u06cc\u06a9 \u0634\u06cc Response \u0631\u0627 \u0628\u0627 \u0645\u0634\u062a\u0631\u06cc \u0628\u0647 \u0631\u0648\u0632 \u0634\u062f\u0647 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li>\u0627\u06af\u0631 \u06cc\u06a9 \u062f\u0631\u062e\u0648\u0627\u0633\u062a DELETE \u0628\u0627\u0634\u062f\u060c \u0645\u062a\u062f \u0645\u062a\u062f ()delete \u0634\u06cc \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0622\u0646 \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u062f\u060c \u0633\u067e\u0633 \u06cc\u06a9 \u0634\u06cc Response \u0628\u062f\u0648\u0646 \u062f\u0627\u062f\u0647 \u0631\u0627 \u0628\u0631\u0645\u06cc \u06af\u0631\u062f\u0627\u0646\u062f.<\/li>\n<\/ul>\n<p>\u0641\u0627\u06cc\u0644 \u062a\u06a9\u0645\u06cc\u0644 \u0634\u062f\u0647 \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from rest_framework.response import Response\r\nfrom rest_framework.decorators import api_view\r\nfrom rest_framework import status\r\n\r\nfrom django.core.paginator import Paginator, EmptyPage, PageNotAnInteger\r\nfrom .models import Customer\r\nfrom .serializers import *\r\n\r\n\r\n@api_view(['GET', 'POST'])\r\ndef customers_list(request):\r\n\"\"\"\r\nList customers, or create a new customer.\r\n\"\"\"\r\nif request.method == 'GET':\r\ndata = []\r\nnextPage = 1\r\npreviousPage = 1\r\ncustomers = Customer.objects.all()\r\npage = request.GET.get('page', 1)\r\npaginator = Paginator(customers, 5)\r\ntry:\r\ndata = paginator.page(page)\r\nexcept PageNotAnInteger:\r\ndata = paginator.page(1)\r\nexcept EmptyPage:\r\ndata = paginator.page(paginator.num_pages)\r\n\r\nserializer = CustomerSerializer(data,context={'request': request} ,many=True)\r\nif data.has_next():\r\nnextPage = data.next_page_number()\r\nif data.has_previous():\r\npreviousPage = data.previous_page_number()\r\n\r\nreturn Response({'data': serializer.data , 'count': paginator.count, 'numpages' : paginator.num_pages, 'nextlink': '\/api\/customers\/?page=' + str(nextPage), 'prevlink': '\/api\/customers\/?page=' + str(previousPage)})\r\n\r\nelif request.method == 'POST':\r\nserializer = CustomerSerializer(data=request.data)\r\nif serializer.is_valid():\r\nserializer.save()\r\nreturn Response(serializer.data, status=status.HTTP_201_CREATED)\r\nreturn Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)\r\n\r\n@api_view(['GET', 'PUT', 'DELETE'])\r\ndef customers_detail(request, pk):\r\n\"\"\"\r\nRetrieve, update or delete a customer by id\/pk.\r\n\"\"\"\r\ntry:\r\ncustomer = Customer.objects.get(pk=pk)\r\nexcept Customer.DoesNotExist:\r\nreturn Response(status=status.HTTP_404_NOT_FOUND)\r\n\r\nif request.method == 'GET':\r\nserializer = CustomerSerializer(customer,context={'request': request})\r\nreturn Response(serializer.data)\r\n\r\nelif request.method == 'PUT':\r\nserializer = CustomerSerializer(customer, data=request.data,context={'request': request})\r\nif serializer.is_valid():\r\nserializer.save()\r\nreturn Response(serializer.data)\r\nreturn Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)\r\n\r\nelif request.method == 'DELETE':\r\ncustomer.delete()\r\nreturn Response(status=status.HTTP_204_NO_CONTENT)<\/code><\/pre>\n<\/div>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u062e\u0648\u062f \u0627\u062f\u0627\u0645\u0647 \u062f\u0647\u06cc\u0645.<\/p>\n<h5 id=\"%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86-%d9%86%d9%82%d8%a7%d8%b7-%d9%be%d8%a7%db%8c%d8%a7%d9%86%db%8c-api\">\u0627\u0641\u0632\u0648\u062f\u0646 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc API<\/h5>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc API \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f: api\/customers\/\u060c \u0628\u0631\u0627\u06cc \u067e\u0631\u0633 \u0648 \u062c\u0648 \u0648 \u0627\u06cc\u062c\u0627\u062f \u0645\u0634\u062a\u0631\u06cc\u0627\u0646\u060c \u0648 api\/customers\/&lt;pk&gt;\u060c \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a\u060c \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u06cc\u0627 \u062d\u0630\u0641 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062a\u06a9\u06cc \u062a\u0648\u0633\u0637 pk \u0622\u0646\u0647\u0627.<\/p>\n<p>~\/djangoreactproject\/djangoreactproject\/urls.py \u0631\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano ~\/djangoreactproject\/djangoreactproject\/urls.py<\/code><\/pre>\n<\/div>\n<p>\u0622\u0646\u0686\u0647 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u0631\u0627 \u0631\u0647\u0627 \u06a9\u0646\u06cc\u062f\u060c \u0627\u0645\u0627 \u0648\u0627\u0631\u062f\u0627\u062a \u0631\u0627 \u0628\u0647 \u0646\u0645\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062f\u0631 \u0628\u0627\u0644\u0627\u06cc \u0641\u0627\u06cc\u0644 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>from django.contrib import admin\r\nfrom django.urls import path\r\nfrom customers import views\r\nfrom django.conf.urls import url<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633\u060c URL \u0647\u0627\u06cc api\/customers\/ \u0648 api\/customers\/&lt;pk&gt; \u0631\u0627 \u0628\u0647 \u0644\u06cc\u0633\u062a \u0627\u0644\u06af\u0648\u0647\u0627\u06cc url \u06a9\u0647 \u062d\u0627\u0648\u06cc URL \u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u0633\u062a \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-python\" data-lang=\"Python\"><code>...\r\n\r\nurlpatterns = [\r\npath('admin\/', admin.site.urls),\r\nurl(r'^api\/customers\/$', views.customers_list),\r\nurl(r'^api\/customers\/(?P&lt;pk&gt;[0-9]+)$', views.customers_detail),\r\n]<\/code><\/pre>\n<\/div>\n<\/div>\n<p>\u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc REST\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0628\u06cc\u0646\u06cc\u0645 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0645\u0635\u0631\u0641 \u06a9\u0646\u06cc\u0645.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-6-%d9%85%d8%b5%d8%b1%d9%81-rest-api-%d8%a8%d8%a7-axios\">\u0645\u0631\u062d\u0644\u0647 6 &#8211; \u0645\u0635\u0631\u0641 REST API \u0628\u0627 Axios<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647\u060c Axios \u0631\u0627 \u0646\u0635\u0628 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645\u060c \u06a9\u0644\u0627\u06cc\u0646\u062a HTTP \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0628\u0631\u0642\u0631\u0627\u0631\u06cc \u062a\u0645\u0627\u0633\u200c\u0647\u0627\u06cc API \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645. \u0647\u0645\u0686\u0646\u06cc\u0646 \u06cc\u06a9 \u06a9\u0644\u0627\u0633 \u0628\u0631\u0627\u06cc \u0645\u0635\u0631\u0641 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc API \u06a9\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u0645 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0627\u0628\u062a\u062f\u0627 \u0645\u062d\u06cc\u0637 \u0645\u062c\u0627\u0632\u06cc \u062e\u0648\u062f \u0631\u0627 \u063a\u06cc\u0631\u0641\u0639\u0627\u0644 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>deactivate<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633 \u0628\u0647 \u067e\u0648\u0634\u0647 frontend \u062e\u0648\u062f \u0628\u0631\u0648\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject\/frontend<\/code><\/pre>\n<\/div>\n<p>\u0646\u0635\u0628 axios \u0627\u0632 npm \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npm install axios --save<\/code><\/pre>\n<\/div>\n<p>\u06af\u0632\u06cc\u0646\u0647 &#8211;save \u0648\u0627\u0628\u0633\u062a\u06af\u06cc axios \u0631\u0627 \u0628\u0647 \u0641\u0627\u06cc\u0644 package.json \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0647 \u0646\u0627\u0645 CustomersService.js \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062d\u0627\u0648\u06cc \u06a9\u062f \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc API \u0647\u0627\u06cc REST \u0627\u0633\u062a. \u0645\u0627 \u0627\u06cc\u0646 \u0631\u0627 \u062f\u0631 \u067e\u0648\u0634\u0647 src\u060c \u062c\u0627\u06cc\u06cc \u06a9\u0647 \u06a9\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u067e\u0631\u0648\u0698\u0647 \u0645\u0627 \u062f\u0631 \u0622\u0646 \u0642\u0631\u0627\u0631 \u062f\u0627\u0631\u062f\u060c \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd src\r\nnano CustomersService.js<\/code><\/pre>\n<\/div>\n<p>\u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062d\u0627\u0648\u06cc \u0631\u0648\u0634 \u0647\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 Django REST API \u0627\u0633\u062a:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>import axios from 'axios';\r\nconst API_URL = 'http:\/\/localhost:8000';\r\n\r\nexport default class CustomersService{\r\n\r\nconstructor(){}\r\n\r\n\r\ngetCustomers() {\r\nconst url = `${API_URL}\/api\/customers\/`;\r\nreturn axios.get(url).then(response =&gt; response.data);\r\n}\r\ngetCustomersByURL(link){\r\nconst url = `${API_URL}${link}`;\r\nreturn axios.get(url).then(response =&gt; response.data);\r\n}\r\ngetCustomer(pk) {\r\nconst url = `${API_URL}\/api\/customers\/${pk}`;\r\nreturn axios.get(url).then(response =&gt; response.data);\r\n}\r\ndeleteCustomer(customer){\r\nconst url = `${API_URL}\/api\/customers\/${customer.pk}`;\r\nreturn axios.delete(url);\r\n}\r\ncreateCustomer(customer){\r\nconst url = `${API_URL}\/api\/customers\/`;\r\nreturn axios.post(url,customer);\r\n}\r\nupdateCustomer(customer){\r\nconst url = `${API_URL}\/api\/customers\/${customer.pk}`;\r\nreturn axios.put(url,customer);\r\n}\r\n}<\/code><\/pre>\n<\/div>\n<p>\u06a9\u0644\u0627\u0633 CustomersService \u0645\u062a\u062f\u0647\u0627\u06cc Axios \u0632\u06cc\u0631 \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<ul>\n<li>getCustomers(): \u0635\u0641\u062d\u0647 \u0627\u0648\u0644 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li>getCustomersByURL(): \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0627 \u0628\u0631 \u0627\u0633\u0627\u0633 URL \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f. \u0627\u06cc\u0646 \u0628\u0627\u0639\u062b \u0645\u06cc \u0634\u0648\u062f \u062a\u0627 \u0628\u0627 \u0639\u0628\u0648\u0631 \u062f\u0627\u062f\u0646 \u0644\u06cc\u0646\u06a9 \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f \/api\/customers\/?page=2 \u0628\u0647 \u0635\u0641\u062d\u0627\u062a \u0628\u0639\u062f\u06cc \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f.<\/li>\n<li>getCustomer(): \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u0628\u0627 \u06a9\u0644\u06cc\u062f \u0627\u0635\u0644\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li>createCustomer(): \u06cc\u06a9 \u0645\u0634\u062a\u0631\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li>updateCustomer(): \u06cc\u06a9 \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<li>deleteCustomer(): \u06cc\u06a9 \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u062d\u0630\u0641 \u0645\u06cc \u06a9\u0646\u062f.<\/li>\n<\/ul>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc API \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc React UI \u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u062c\u0632\u0621 CustomersList \u0646\u0645\u0627\u06cc\u0634 \u062f\u0647\u06cc\u0645.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-7-%d9%86%d9%85%d8%a7%db%8c%d8%b4-%d8%af%d8%a7%d8%af%d9%87-%d9%87%d8%a7-%d8%a7%d8%b2-api-%d8%af%d8%b1-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87-react\">\u0645\u0631\u062d\u0644\u0647 7 &#8211; \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 API \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 React<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647\u060c \u0645\u0624\u0644\u0641\u0647 CustomersList React \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u06cc\u06a9 \u062c\u0632\u0621 React \u0628\u062e\u0634\u06cc \u0627\u0632 \u0631\u0627\u0628\u0637 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0631\u0627 \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f. \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0647 \u0634\u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f UI \u0631\u0627 \u0628\u0647 \u0642\u0637\u0639\u0627\u062a \u0645\u0633\u062a\u0642\u0644 \u0648 \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u062a\u0642\u0633\u06cc\u0645 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0628\u0627 \u0627\u06cc\u062c\u0627\u062f CustomersList.js \u062f\u0631 frontend\/src \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano ~\/djangoreactproject\/frontend\/src\/CustomersList.js<\/code><\/pre>\n<\/div>\n<p>\u0628\u0627 \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646 React \u0648 Component \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a React \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>import React, { Component } from 'react';<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633\u060c \u0645\u0627\u0698\u0648\u0644 CustomersService \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0642\u0628\u0644 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u062f\u060c \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0647 \u0648 \u0646\u0645\u0648\u0646\u0647\u200c\u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0647 \u0631\u0648\u0634\u200c\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u06a9\u0647 \u0628\u0627 REST API \u0628\u0627\u0637\u0646 \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u0631\u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nimport CustomersService from '.\/CustomersService';\r\nconst customersService = new CustomersService();<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633\u060c \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 CustomersList \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 Component \u0631\u0627 \u0628\u0631\u0627\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc REST API \u06af\u0633\u062a\u0631\u0634 \u062f\u0647\u062f. \u06cc\u06a9 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a React \u0628\u0627\u06cc\u062f \u06a9\u0644\u0627\u0633 Component \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u062f\u0647\u062f \u06cc\u0627 \u0632\u06cc\u0631 \u06a9\u0644\u0627\u0633 \u0642\u0631\u0627\u0631 \u062f\u0647\u062f. \u0628\u0631\u0627\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0628\u06cc\u0634\u062a\u0631 \u062f\u0631 \u0645\u0648\u0631\u062f \u06a9\u0644\u0627\u0633 \u0647\u0627\u06cc E6 \u0648 \u0648\u0631\u0627\u062b\u062a\u060c \u0644\u0637\u0641\u0627\u064b \u0628\u0647 \u0622\u0645\u0648\u0632\u0634 \u0645\u0627 \u062f\u0631 \u0645\u0648\u0631\u062f \u062f\u0631\u06a9 \u06a9\u0644\u0627\u0633 \u0647\u0627 \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u0631\u0627\u062c\u0639\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a React \u06a9\u0647 react.Component \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u0645\u06cc \u062f\u0647\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nclass CustomersList extends Component {\r\n\r\nconstructor(props) {\r\nsuper(props);\r\nthis.state = {\r\ncustomers: [],\r\nnextPageURL: ''\r\n};\r\nthis.nextPage = this.nextPage.bind(this);\r\nthis.handleDelete = this.handleDelete.bind(this);\r\n}\r\n}\r\nexport default CustomersList;<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u062f\u0627\u062e\u0644 \u0633\u0627\u0632\u0646\u062f\u0647\u060c \u0634\u06cc state \u0631\u0627 \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u0627\u06cc\u0646 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u062d\u0627\u0644\u062a \u062c\u0632\u0621 \u0645\u0627 \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u062e\u0627\u0644\u06cc \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0646\u06af\u0647 \u0645\u06cc \u062f\u0627\u0631\u062f. \u0627\u06cc\u0646 \u0622\u0631\u0627\u06cc\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0648 nextPageURL \u0631\u0627 \u0646\u06af\u0647 \u0645\u06cc\u200c\u062f\u0627\u0631\u062f \u06a9\u0647 URL \u0635\u0641\u062d\u0647 \u0628\u0639\u062f\u06cc \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u0627\u0632 API \u067e\u0634\u062a\u06cc\u0628\u0627\u0646 \u0646\u06af\u0647 \u0645\u06cc\u200c\u062f\u0627\u0631\u062f. \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u062a\u062f\u0647\u0627\u06cc nextPage() \u0648 handleDelete() \u0631\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u062a\u0635\u0644 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06a9\u062f HTML \u0642\u0627\u0628\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0627\u0634\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u0645\u062a\u062f ()componentDidMount \u0648 \u06cc\u06a9 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0628\u0631\u0627\u06cc getCustomers() \u062f\u0631 \u06a9\u0644\u0627\u0633 CustomersList\u060c \u0642\u0628\u0644 \u0627\u0632 \u0628\u0633\u062a\u0647 \u0634\u062f\u0646 \u0628\u0631\u06cc\u0633 \u0641\u0631\u0641\u0631\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0645\u062a\u062f ()componentDidMount \u06cc\u06a9 \u0645\u062a\u062f \u0686\u0631\u062e\u0647 \u062d\u06cc\u0627\u062a \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0627\u0633\u062a \u06a9\u0647 \u0647\u0646\u06af\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0648 \u062f\u0631\u062c \u0622\u0646 \u062f\u0631 DOM \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u0634\u0648\u062f. getCustomers() \u0634\u06cc\u0621 \u062e\u062f\u0645\u0627\u062a \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0635\u0641\u062d\u0647 \u0627\u0648\u0644 \u062f\u0627\u062f\u0647 \u0648 \u067e\u06cc\u0648\u0646\u062f \u0635\u0641\u062d\u0647 \u0628\u0639\u062f\u06cc \u0631\u0627 \u0627\u0632 \u0628\u0627\u0637\u0646 \u062c\u0646\u06af\u0648 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\ncomponentDidMount() {\r\nvar self = this;\r\ncustomersService.getCustomers().then(function (result) {\r\nself.setState({ customers: result.data, nextPageURL: result.nextlink})\r\n});\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u062a\u062f handleDelete() \u0631\u0627 \u06a9\u0647 \u062d\u0630\u0641 \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f\u060c \u062f\u0631 \u0632\u06cc\u0631 componentDidMount():<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nhandleDelete(e,pk){\r\nvar self = this;\r\ncustomersService.deleteCustomer({pk : pk}).then(()=&gt;{\r\nvar newArr = self.state.customers.filter(function(obj) {\r\nreturn obj.pk !== pk;\r\n});\r\nself.setState({customers: newArr})\r\n});\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0645\u062a\u062f handleDelete\u060c \u0645\u062a\u062f deleteCustomer() \u0631\u0627 \u0628\u0631\u0627\u06cc \u062d\u0630\u0641 \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 pk (\u06a9\u0644\u06cc\u062f \u0627\u0635\u0644\u06cc) \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f. \u0627\u06af\u0631 \u0639\u0645\u0644\u06cc\u0627\u062a \u0645\u0648\u0641\u0642\u06cc\u062a \u0622\u0645\u06cc\u0632 \u0628\u0627\u0634\u062f\u060c \u0622\u0631\u0627\u06cc\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0628\u0631\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc \u062d\u0630\u0641 \u0634\u062f\u0647 \u0641\u06cc\u0644\u062a\u0631 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u06cc\u06a9 \u0645\u062a\u062f nextPage() \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0635\u0641\u062d\u0647 \u0628\u0639\u062f \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u06a9\u0646\u06cc\u062f \u0648 \u067e\u06cc\u0648\u0646\u062f \u0635\u0641\u062d\u0647 \u0628\u0639\u062f\u06cc \u0631\u0627 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nnextPage(){\r\nvar self = this;\r\ncustomersService.getCustomersByURL(this.state.nextPageURL).then((result) =&gt; {\r\nself.setState({ customers: result.data, nextPageURL: result.nextlink})\r\n});\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0645\u062a\u062f ()nextPage \u06cc\u06a9 \u0645\u062a\u062f getCustomersByURL() \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 URL \u0635\u0641\u062d\u0647 \u0628\u0639\u062f\u06cc \u0631\u0627 \u0627\u0632 \u0634\u06cc state\u060c this.state.nextPageURL \u0645\u06cc \u06af\u06cc\u0631\u062f \u0648 \u0622\u0631\u0627\u06cc\u0647 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0627 \u0628\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0628\u0631\u06af\u0634\u062a\u06cc \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0645\u062a\u062f render() \u062c\u0632\u0621 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0647 \u062c\u062f\u0648\u0644\u06cc \u0627\u0632 \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0627 \u0627\u0632 \u062d\u0627\u0644\u062a \u062c\u0632\u0621 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nrender() {\r\n\r\nreturn (\r\n&lt;div className=\"customers--list\"&gt;\r\n&lt;table className=\"table\"&gt;\r\n&lt;thead key=\"thead\"&gt;\r\n&lt;tr&gt;\r\n&lt;th&gt;#&lt;\/th&gt;\r\n&lt;th&gt;First Name&lt;\/th&gt;\r\n&lt;th&gt;Last Name&lt;\/th&gt;\r\n&lt;th&gt;Phone&lt;\/th&gt;\r\n&lt;th&gt;Email&lt;\/th&gt;\r\n&lt;th&gt;Address&lt;\/th&gt;\r\n&lt;th&gt;Description&lt;\/th&gt;\r\n&lt;th&gt;Actions&lt;\/th&gt;\r\n&lt;\/tr&gt;\r\n&lt;\/thead&gt;\r\n&lt;tbody&gt;\r\n{this.state.customers.map( c =&gt;\r\n&lt;tr key={c.pk}&gt;\r\n&lt;td&gt;{c.pk} &lt;\/td&gt;\r\n&lt;td&gt;{c.first_name}&lt;\/td&gt;\r\n&lt;td&gt;{c.last_name}&lt;\/td&gt;\r\n&lt;td&gt;{c.phone}&lt;\/td&gt;\r\n&lt;td&gt;{c.email}&lt;\/td&gt;\r\n&lt;td&gt;{c.address}&lt;\/td&gt;\r\n&lt;td&gt;{c.description}&lt;\/td&gt;\r\n&lt;td&gt;\r\n&lt;button onClick={(e)=&gt; this.handleDelete(e,c.pk) }&gt; Delete&lt;\/button&gt;\r\n&lt;a href={\"\/customer\/\" + c.pk}&gt; Update&lt;\/a&gt;\r\n&lt;\/td&gt;\r\n&lt;\/tr&gt;)}\r\n&lt;\/tbody&gt;\r\n&lt;\/table&gt;\r\n&lt;button className=\"btn btn-primary\" onClick= { this.nextPage }&gt;Next&lt;\/button&gt;\r\n&lt;\/div&gt;\r\n);\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0627\u06cc\u0646\u0645 \u0645\u062d\u062a\u0648\u0627\u06cc \u06a9\u0627\u0645\u0644 \u0641\u0627\u06cc\u0644:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>import React, { Component } from 'react';\r\nimport CustomersService from '.\/CustomersService';\r\n\r\nconst customersService = new CustomersService();\r\n\r\nclass CustomersList extends Component {\r\n\r\nconstructor(props) {\r\nsuper(props);\r\nthis.state = {\r\ncustomers: [],\r\nnextPageURL: ''\r\n};\r\nthis.nextPage = this.nextPage.bind(this);\r\nthis.handleDelete = this.handleDelete.bind(this);\r\n}\r\n\r\ncomponentDidMount() {\r\nvar self = this;\r\ncustomersService.getCustomers().then(function (result) {\r\nconsole.log(result);\r\nself.setState({ customers: result.data, nextPageURL: result.nextlink})\r\n});\r\n}\r\nhandleDelete(e,pk){\r\nvar self = this;\r\ncustomersService.deleteCustomer({pk : pk}).then(()=&gt;{\r\nvar newArr = self.state.customers.filter(function(obj) {\r\nreturn obj.pk !== pk;\r\n});\r\n\r\nself.setState({customers: newArr})\r\n});\r\n}\r\n\r\nnextPage(){\r\nvar self = this;\r\nconsole.log(this.state.nextPageURL);\r\ncustomersService.getCustomersByURL(this.state.nextPageURL).then((result) =&gt; {\r\nself.setState({ customers: result.data, nextPageURL: result.nextlink})\r\n});\r\n}\r\nrender() {\r\n\r\nreturn (\r\n&lt;div className=\"customers--list\"&gt;\r\n&lt;table className=\"table\"&gt;\r\n&lt;thead key=\"thead\"&gt;\r\n&lt;tr&gt;\r\n&lt;th&gt;#&lt;\/th&gt;\r\n&lt;th&gt;First Name&lt;\/th&gt;\r\n&lt;th&gt;Last Name&lt;\/th&gt;\r\n&lt;th&gt;Phone&lt;\/th&gt;\r\n&lt;th&gt;Email&lt;\/th&gt;\r\n&lt;th&gt;Address&lt;\/th&gt;\r\n&lt;th&gt;Description&lt;\/th&gt;\r\n&lt;th&gt;Actions&lt;\/th&gt;\r\n&lt;\/tr&gt;\r\n&lt;\/thead&gt;\r\n&lt;tbody&gt;\r\n{this.state.customers.map( c =&gt;\r\n&lt;tr key={c.pk}&gt;\r\n&lt;td&gt;{c.pk} &lt;\/td&gt;\r\n&lt;td&gt;{c.first_name}&lt;\/td&gt;\r\n&lt;td&gt;{c.last_name}&lt;\/td&gt;\r\n&lt;td&gt;{c.phone}&lt;\/td&gt;\r\n&lt;td&gt;{c.email}&lt;\/td&gt;\r\n&lt;td&gt;{c.address}&lt;\/td&gt;\r\n&lt;td&gt;{c.description}&lt;\/td&gt;\r\n&lt;td&gt;\r\n&lt;button onClick={(e)=&gt; this.handleDelete(e,c.pk) }&gt; Delete&lt;\/button&gt;\r\n&lt;a href={\"\/customer\/\" + c.pk}&gt; Update&lt;\/a&gt;\r\n&lt;\/td&gt;\r\n&lt;\/tr&gt;)}\r\n&lt;\/tbody&gt;\r\n&lt;\/table&gt;\r\n&lt;button className=\"btn btn-primary\" onClick= { this.nextPage }&gt;Next&lt;\/button&gt;\r\n&lt;\/div&gt;\r\n);\r\n}\r\n}\r\nexport default CustomersList;<\/code><\/pre>\n<\/div>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u06a9\u0647 \u0645\u0624\u0644\u0641\u0647 CustomersList \u0631\u0627 \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0634 \u0644\u06cc\u0633\u062a \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u0645\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0645\u0624\u0644\u0641\u0647\u200c\u0627\u06cc \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0627\u06cc\u062c\u0627\u062f \u0648 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-8-%d8%a7%d9%81%d8%b2%d9%88%d8%af%d9%86-%d9%85%d8%a4%d9%84%d9%81%d9%87-react-create-%d9%88-%d8%a8%d9%87-%d8%b1%d9%88%d8%b2-%d8%b1%d8%b3%d8%a7%d9%86%db%8c-%d9%85\">\u0645\u0631\u062d\u0644\u0647 8 &#8211; \u0627\u0641\u0632\u0648\u062f\u0646 \u0645\u0624\u0644\u0641\u0647 React Create \u0648 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0645\u0634\u062a\u0631\u06cc<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647\u060c \u0645\u0624\u0644\u0641\u0647 CustomerCreateUpdate \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u0648 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u0631\u0633\u06cc\u062f\u06af\u06cc \u0645\u06cc\u200c\u06a9\u0646\u062f. \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0628\u0627 \u0627\u0631\u0627\u0626\u0647 \u0641\u0631\u0645\u06cc \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0645\u0634\u062a\u0631\u06cc \u062c\u062f\u06cc\u062f \u06cc\u0627 \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0648\u0631\u0648\u062f\u06cc \u0645\u0648\u062c\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u062f\u0631 frontend\/src\u060c \u06cc\u06a9 \u0641\u0627\u06cc\u0644 CustomerCreateUpdate.js \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano ~\/djangoreactproject\/frontend\/src\/CustomerCreateUpdate.js<\/code><\/pre>\n<\/div>\n<p>\u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a React \u0628\u0627 \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646 React \u0648 Component \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>import React, { Component } from 'react';<\/code><\/pre>\n<\/div>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u06a9\u0644\u0627\u0633 CustomersService \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0642\u0628\u0644 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u0645\u060c \u0648\u0627\u0631\u062f \u0648 \u0646\u0645\u0648\u0646\u0647\u200c\u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645\u060c \u06a9\u0647 \u0631\u0648\u0634\u200c\u0647\u0627\u06cc\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u062f\u0647\u062f \u06a9\u0647 \u0628\u0627 REST API \u0628\u0627\u0637\u0646 \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u0631\u0642\u0631\u0627\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nimport CustomersService from '.\/CustomersService';\r\n\r\nconst customersService = new CustomersService();<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633\u060c \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 CustomerCreateUpdate \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 Component \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0648 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0645\u0634\u062a\u0631\u06cc\u0627\u0646 \u06af\u0633\u062a\u0631\u0634 \u0645\u06cc\u200c\u062f\u0647\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nclass CustomerCreateUpdate extends Component {\r\n\r\nconstructor(props) {\r\nsuper(props);\r\n}\r\n}\r\nexport default CustomerCreateUpdate;<\/code><\/pre>\n<\/div>\n<p>\u062f\u0631 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0644\u0627\u0633\u060c \u0645\u062a\u062f render() \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u06cc\u06a9 \u0641\u0631\u0645 HTML \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u0645\u06cc\u200c\u06af\u06cc\u0631\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nrender() {\r\nreturn (\r\n&lt;form onSubmit={this.handleSubmit}&gt;\r\n&lt;div className=\"form-group\"&gt;\r\n&lt;label&gt;\r\nFirst Name:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='firstName' \/&gt;\r\n\r\n&lt;label&gt;\r\nLast Name:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='lastName'\/&gt;\r\n\r\n&lt;label&gt;\r\nPhone:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='phone' \/&gt;\r\n\r\n&lt;label&gt;\r\nEmail:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='email' \/&gt;\r\n\r\n&lt;label&gt;\r\nAddress:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='address' \/&gt;\r\n\r\n&lt;label&gt;\r\nDescription:&lt;\/label&gt;\r\n&lt;textarea className=\"form-control\" ref='description' &gt;&lt;\/textarea&gt;\r\n\r\n&lt;input className=\"btn btn-primary\" type=\"submit\" value=\"Submit\" \/&gt;\r\n&lt;\/div&gt;\r\n&lt;\/form&gt;\r\n);\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0628\u0631\u0627\u06cc \u0647\u0631 \u0639\u0646\u0635\u0631 \u0648\u0631\u0648\u062f\u06cc \u0641\u0631\u0645\u060c \u0645\u062a\u062f \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc ref \u0631\u0627 \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u0648 \u062a\u0646\u0638\u06cc\u0645 \u0645\u0642\u062f\u0627\u0631 \u0639\u0646\u0635\u0631 \u0641\u0631\u0645 \u0627\u0636\u0627\u0641\u0647 \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u062f\u0631 \u0628\u0627\u0644\u0627\u06cc \u0645\u062a\u062f render() \u06cc\u06a9 \u0645\u062a\u062f handleSubmit(\u0631\u0648\u06cc\u062f\u0627\u062f) \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0648\u06cc \u062f\u06a9\u0645\u0647 \u0627\u0631\u0633\u0627\u0644 \u06a9\u0644\u06cc\u06a9 \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u0639\u0645\u0644\u06a9\u0631\u062f \u0645\u0646\u0627\u0633\u0628 \u0631\u0627 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nhandleSubmit(event) {\r\nconst { match: { params } } = this.props;\r\nif(params &amp;&amp; params.pk){\r\nthis.handleUpdate(params.pk);\r\n}\r\nelse\r\n{\r\nthis.handleCreate();\r\n}\r\nevent.preventDefault();\r\n}\r\n...<\/code><\/pre>\n<\/div>\n<p>\u0645\u062a\u062f handleSubmit(event) \u0627\u0631\u0633\u0627\u0644 \u0641\u0631\u0645 \u0631\u0627 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0633\u062a\u0647 \u0628\u0647 \u0645\u0633\u06cc\u0631\u060c \u06cc\u0627 \u0645\u062a\u062f handleUpdate(pk) \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 pk \u067e\u0627\u0633 \u0634\u062f\u0647 \u06cc\u0627 \u0645\u062a\u062f handleCreate() \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0645\u0634\u062a\u0631\u06cc \u062c\u062f\u06cc\u062f \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f. \u0628\u0647 \u0632\u0648\u062f\u06cc \u0627\u06cc\u0646 \u0631\u0648\u0634 \u0647\u0627 \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<p>\u0628\u0631\u06af\u0631\u062f\u06cc\u062f \u062f\u0631 \u0633\u0627\u0632\u0646\u062f\u0647 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a\u060c \u0645\u062a\u062f ()handleSubmit \u06a9\u0647 \u0628\u0647 \u062a\u0627\u0632\u06af\u06cc \u0627\u0636\u0627\u0641\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u067e\u06cc\u0648\u0646\u062f \u062f\u0647\u06cc\u062f \u062a\u0627 \u0628\u062a\u0648\u0627\u0646\u06cc\u062f \u062f\u0631 \u0641\u0631\u0645 \u062e\u0648\u062f \u0628\u0647 \u0622\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nclass CustomerCreateUpdate extends Component {\r\nconstructor(props) {\r\nsuper(props);\r\nthis.handleSubmit = this.handleSubmit.bind(this);\r\n}\r\n...<\/code><\/pre>\n<\/div>\n<p>\u0633\u067e\u0633 \u0645\u062a\u062f handleCreate() \u0631\u0627 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u0634\u062a\u0631\u06cc \u0627\u0632 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0641\u0631\u0645 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u062f. \u0628\u0627\u0644\u0627\u06cc \u0645\u062a\u062f handleSubmit(event) \u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nhandleCreate(){\r\ncustomersService.createCustomer(\r\n{\r\n\"first_name\": this.refs.firstName.value,\r\n\"last_name\": this.refs.lastName.value,\r\n\"email\": this.refs.email.value,\r\n\"phone\": this.refs.phone.value,\r\n\"address\": this.refs.address.value,\r\n\"description\": this.refs.description.value\r\n}).then((result)=&gt;{\r\nalert(\"Customer created!\");\r\n}).catch(()=&gt;{\r\nalert('There was an error! Please re-check your form.');\r\n});\r\n}\r\n...<\/code><\/pre>\n<\/div>\n<p>\u0645\u062a\u062f handleCreate() \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0645\u0634\u062a\u0631\u06cc \u0627\u0632 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0648\u0631\u0648\u062f\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f. \u0645\u062a\u062f \u0645\u0631\u0628\u0648\u0637\u0647 CustomersService.createCustomer() \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 API \u0648\u0627\u0642\u0639\u06cc \u0631\u0627 \u0628\u0647 backend \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0645\u0634\u062a\u0631\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u062f.<\/p>\n<p>\u0633\u067e\u0633\u060c \u062f\u0631 \u0632\u06cc\u0631 \u0645\u062a\u062f handleCreate\u060c \u0645\u062a\u062f handleUpdate(pk) \u0631\u0627 \u0628\u0631\u0627\u06cc \u067e\u06cc\u0627\u062f\u0647\u200c\u0633\u0627\u0632\u06cc \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc\u200c\u0647\u0627 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nhandleUpdate(pk){\r\ncustomersService.updateCustomer(\r\n{\r\n\"pk\": pk,\r\n\"first_name\": this.refs.firstName.value,\r\n\"last_name\": this.refs.lastName.value,\r\n\"email\": this.refs.email.value,\r\n\"phone\": this.refs.phone.value,\r\n\"address\": this.refs.address.value,\r\n\"description\": this.refs.description.value\r\n}\r\n).then((result)=&gt;{\r\n\r\nalert(\"Customer updated!\");\r\n}).catch(()=&gt;{\r\nalert('There was an error! Please re-check your form.');\r\n});\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0645\u062a\u062f updateCustomer() \u06cc\u06a9 \u0645\u0634\u062a\u0631\u06cc \u0631\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062c\u062f\u06cc\u062f \u0627\u0632 \u0641\u0631\u0645 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0647 \u0631\u0648\u0632 \u0645\u06cc \u06a9\u0646\u062f. \u0645\u062a\u062f customersService.updateCustomer() \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<p>\u0633\u067e\u0633 \u06cc\u06a9 \u0645\u062a\u062f ()componentDidMount \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f. \u0627\u06af\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0632 \u0645\u0633\u06cc\u0631 \u0645\u0634\u062a\u0631\u06cc\/:pk \u0628\u0627\u0632\u062f\u06cc\u062f \u06a9\u0646\u062f\u060c \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u0645 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u0644\u06cc\u062f \u0627\u0635\u0644\u06cc \u0627\u0632 URL\u060c \u0641\u0631\u0645 \u0631\u0627 \u0628\u0627 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0645\u0634\u062a\u0631\u06cc \u067e\u0631 \u06a9\u0646\u06cc\u0645. \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0645\u062a\u062f getCustomer(pk) \u0631\u0627 \u0628\u0639\u062f \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u062f\u0631 \u0631\u0648\u06cc\u062f\u0627\u062f \u0686\u0631\u062e\u0647 \u062d\u06cc\u0627\u062a (lifecycle event) componentDidMount () \u0633\u0648\u0627\u0631 \u0634\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645. \u0628\u0631\u0627\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0627\u06cc\u0646 \u0645\u062a\u062f \u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u062f\u0631 \u0632\u06cc\u0631 \u0633\u0627\u0632\u0646\u062f\u0647 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\ncomponentDidMount(){\r\nconst { match: { params } } = this.props;\r\nif(params &amp;&amp; params.pk)\r\n{\r\ncustomersService.getCustomer(params.pk).then((c)=&gt;{\r\nthis.refs.firstName.value = c.first_name;\r\nthis.refs.lastName.value = c.last_name;\r\nthis.refs.email.value = c.email;\r\nthis.refs.phone.value = c.phone;\r\nthis.refs.address.value = c.address;\r\nthis.refs.description.value = c.description;\r\n})\r\n}\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0627\u06cc\u0646\u0645 \u0645\u062d\u062a\u0648\u0627\u06cc \u06a9\u0627\u0645\u0644 \u0641\u0627\u06cc\u0644:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\">import React, { Component } from 'react';\r\nimport CustomersService from '.\/CustomersService';\r\nconst customersService = new CustomersService();\r\nclass CustomerCreateUpdate extends Component {\r\nconstructor(props) {\r\nsuper(props);\r\n\r\nthis.handleSubmit = this.handleSubmit.bind(this);\r\n}\r\ncomponentDidMount(){\r\nconst { match: { params } } = this.props;\r\nif(params &amp;&amp; params.pk)\r\n{\r\ncustomersService.getCustomer(params.pk).then((c)=&gt;{\r\nthis.refs.firstName.value = c.first_name;\r\nthis.refs.lastName.value = c.last_name;\r\nthis.refs.email.value = c.email;\r\nthis.refs.phone.value = c.phone;\r\nthis.refs.address.value = c.address;\r\nthis.refs.description.value = c.description;\r\n})\r\n}\r\n}\r\nhandleCreate(){\r\ncustomersService.createCustomer(\r\n{\r\n\"first_name\": this.refs.firstName.value,\r\n\"last_name\": this.refs.lastName.value,\r\n\"email\": this.refs.email.value,\r\n\"phone\": this.refs.phone.value,\r\n\"address\": this.refs.address.value,\r\n\"description\": this.refs.description.value\r\n} \r\n).then((result)=&gt;{\r\nalert(\"Customer created!\");\r\n}).catch(()=&gt;{\r\nalert('There was an error! Please re-check your form.');\r\n});\r\n}\r\nhandleUpdate(pk){\r\ncustomersService.updateCustomer(\r\n{\r\n\"pk\": pk,\r\n\"first_name\": this.refs.firstName.value,\r\n\"last_name\": this.refs.lastName.value,\r\n\"email\": this.refs.email.value,\r\n\"phone\": this.refs.phone.value,\r\n\"address\": this.refs.address.value,\r\n\"description\": this.refs.description.value\r\n} \r\n).then((result)=&gt;{\r\nconsole.log(result);\r\nalert(\"Customer updated!\");\r\n}).catch(()=&gt;{\r\nalert('There was an error! Please re-check your form.');\r\n});\r\n}\r\nhandleSubmit(event) {\r\nconst { match: { params } } = this.props;\r\nif(params &amp;&amp; params.pk){\r\nthis.handleUpdate(params.pk);\r\n}\r\nelse\r\n{\r\nthis.handleCreate();\r\n}\r\nevent.preventDefault();\r\n}\r\n\r\nrender() {\r\nreturn (\r\n&lt;form onSubmit={this.handleSubmit}&gt;\r\n&lt;div className=\"form-group\"&gt;\r\n&lt;label&gt;\r\nFirst Name:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='firstName' \/&gt;\r\n\r\n&lt;label&gt;\r\nLast Name:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='lastName'\/&gt;\r\n\r\n&lt;label&gt;\r\nPhone:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='phone' \/&gt;\r\n\r\n&lt;label&gt;\r\nEmail:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='email' \/&gt;\r\n\r\n&lt;label&gt;\r\nAddress:&lt;\/label&gt;\r\n&lt;input className=\"form-control\" type=\"text\" ref='address' \/&gt;\r\n\r\n&lt;label&gt;\r\nDescription:&lt;\/label&gt;\r\n&lt;textarea className=\"form-control\" ref='description' &gt;&lt;\/textarea&gt;\r\n\r\n&lt;input className=\"btn btn-primary\" type=\"submit\" value=\"Submit\" \/&gt;\r\n&lt;\/div&gt;\r\n&lt;\/form&gt;\r\n);\r\n} \r\n}\r\nexport default CustomerCreateUpdate;<\/pre>\n<\/div>\n<p>\u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u0645\u0624\u0644\u0641\u0647 CustomerCreateUpdate\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0645\u0624\u0644\u0641\u0647 \u0627\u0635\u0644\u06cc App \u0631\u0627 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u067e\u06cc\u0648\u0646\u062f\u0647\u0627\u06cc\u06cc \u0628\u0647 \u0645\u0624\u0644\u0641\u0647\u200c\u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u06a9\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u0645 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-9-%d8%a8%d9%87-%d8%b1%d9%88%d8%b2-%d8%b1%d8%b3%d8%a7%d9%86%db%8c-%d9%85%d8%a4%d9%84%d9%81%d9%87-%d8%a7%d8%b5%d9%84%db%8c-%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87\">\u0645\u0631\u062d\u0644\u0647 9 &#8211; \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u0645\u0624\u0644\u0641\u0647 \u0627\u0635\u0644\u06cc \u0628\u0631\u0646\u0627\u0645\u0647<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0628\u062e\u0634\u060c \u0645\u0624\u0644\u0641\u0647 App \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0647\u200c\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06cc \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0628\u0647 \u0645\u0624\u0644\u0641\u0647\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u062f\u0631 \u0645\u0631\u0627\u062d\u0644 \u0642\u0628\u0644\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u0645 \u067e\u06cc\u0648\u0646\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645.<\/p>\n<p>\u0627\u0632 \u067e\u0648\u0634\u0647 frontend\u060c \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0646\u0635\u0628 \u0631\u0648\u062a\u0631 React \u0627\u062c\u0631\u0627 \u06a9\u0646\u06cc\u062f\u060c \u06a9\u0647 \u0628\u0647 \u0634\u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0648 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0628\u06cc\u0646 \u0627\u062c\u0632\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 React \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd ~\/djangoreactproject\/frontend\r\nnpm install --save react-router-dom<\/code><\/pre>\n<\/div>\n<p>\u0628\u0639\u062f\u060c ~\/djangoreactproject\/frontend\/src\/App.js \u0631\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano ~\/djangoreactproject\/frontend\/src\/App.js<\/code><\/pre>\n<\/div>\n<p>\u062a\u0645\u0627\u0645 \u0645\u0648\u0627\u0631\u062f \u0645\u0648\u062c\u0648\u062f \u0631\u0627 \u062d\u0630\u0641 \u06a9\u0646\u06cc\u062f \u0648 \u06a9\u062f \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u06a9\u0644\u0627\u0633 \u0647\u0627\u06cc \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u06cc\u062f. \u0627\u06cc\u0646\u0647\u0627 \u0639\u0628\u0627\u0631\u062a\u0646\u062f \u0627\u0632 BrowserRouter \u06a9\u0647 \u06cc\u06a9 \u062c\u0632\u0621 Router \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f \u0648 Route \u06a9\u0647 \u06cc\u06a9 \u062c\u0632\u0621 \u0645\u0633\u06cc\u0631 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>import React, { Component } from 'react';\r\nimport { BrowserRouter } from 'react-router-dom'\r\nimport { Route, Link } from 'react-router-dom'\r\nimport CustomersList from '.\/CustomersList'\r\nimport CustomerCreateUpdate from '.\/CustomerCreateUpdate'\r\nimport '.\/App.css';<\/code><\/pre>\n<\/div>\n<p>BrowserRouter \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 API \u062a\u0627\u0631\u06cc\u062e\u0686\u0647 HTML5\u060c UI \u0631\u0627 \u0628\u0627 URL \u0647\u0645\u06af\u0627\u0645 \u0646\u06af\u0647 \u0645\u06cc \u062f\u0627\u0631\u062f.<\/p>\n<p>\u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0628\u0639\u062f\u060c \u06cc\u06a9 \u0637\u0631\u062d \u067e\u0627\u06cc\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0645\u0624\u0644\u0641\u0647 \u067e\u0627\u06cc\u0647 \u0631\u0627 \u0628\u0631\u0627\u06cc \u0628\u0633\u062a\u0647 \u0634\u062f\u0646 \u062a\u0648\u0633\u0637 \u0645\u0624\u0644\u0641\u0647 BrowserRouter \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc \u06a9\u0646\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nconst BaseLayout = () =&gt; (\r\n&lt;div className=\"container-fluid\"&gt;\r\n&lt;nav className=\"navbar navbar-expand-lg navbar-light bg-light\"&gt;\r\n&lt;a className=\"navbar-brand\" href=\"#\"&gt;Django React Demo&lt;\/a&gt;\r\n&lt;button className=\"navbar-toggler\" type=\"button\" data-toggle=\"collapse\" data-target=\"#navbarNavAltMarkup\" aria-controls=\"navbarNavAltMarkup\" aria-expanded=\"false\" aria-label=\"Toggle navigation\"&gt;\r\n&lt;span className=\"navbar-toggler-icon\"&gt;&lt;\/span&gt;\r\n&lt;\/button&gt;\r\n&lt;div className=\"collapse navbar-collapse\" id=\"navbarNavAltMarkup\"&gt;\r\n&lt;div className=\"navbar-nav\"&gt;\r\n&lt;a className=\"nav-item nav-link\" href=\"\/\"&gt;CUSTOMERS&lt;\/a&gt;\r\n&lt;a className=\"nav-item nav-link\" href=\"\/customer\"&gt;CREATE CUSTOMER&lt;\/a&gt;\r\n&lt;\/div&gt;\r\n&lt;\/div&gt;\r\n&lt;\/nav&gt;\r\n&lt;div className=\"content\"&gt;\r\n&lt;Route path=\"\/\" exact component={CustomersList} \/&gt;\r\n&lt;Route path=\"\/customer\/:pk\" component={CustomerCreateUpdate} \/&gt;\r\n&lt;Route path=\"\/customer\/\" exact component={CustomerCreateUpdate} \/&gt;\r\n&lt;\/div&gt;\r\n&lt;\/div&gt;\r\n)<\/code><\/pre>\n<\/div>\n<p>\u0645\u0627 \u0627\u0632 \u0645\u0624\u0644\u0641\u0647 Route \u0628\u0631\u0627\u06cc \u062a\u0639\u0631\u06cc\u0641 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645. \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a\u06cc \u06a9\u0647 \u0631\u0648\u062a\u0631 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0645\u062d\u0636 \u06cc\u0627\u0641\u062a\u0646 \u0645\u0637\u0627\u0628\u0642\u062a \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u06a9\u0646\u062f. \u0647\u0631 \u0645\u0633\u06cc\u0631 \u0628\u0647 \u06cc\u06a9 \u0645\u0633\u06cc\u0631 \u0628\u0631\u0627\u06cc \u062a\u0639\u06cc\u06cc\u0646 \u0645\u0633\u06cc\u0631\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0627\u062f\u0647 \u0634\u0648\u062f \u0648 \u06cc\u06a9 \u0645\u0624\u0644\u0641\u0647 \u0628\u0631\u0627\u06cc \u062a\u0639\u06cc\u06cc\u0646 \u0645\u0648\u0644\u0641\u0647 \u0645\u0648\u0631\u062f \u0646\u0638\u0631 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u062f. \u0648\u06cc\u0698\u06af\u06cc exact \u0628\u0647 \u0631\u0648\u062a\u0631 \u0645\u06cc \u06af\u0648\u06cc\u062f \u06a9\u0647 \u062f\u0642\u06cc\u0642\u0627\u064b \u0628\u0627 \u0645\u0633\u06cc\u0631 \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f.<\/p>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a App\u060c \u0645\u0648\u0644\u0641\u0647 \u0627\u0635\u0644\u06cc \u06cc\u0627 \u0633\u0637\u062d \u0628\u0627\u0644\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 React \u0645\u0627 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<div class=\"hcb_wrap\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>...\r\nclass App extends Component {\r\nrender() {\r\nreturn (\r\n&lt;BrowserRouter&gt;\r\n&lt;BaseLayout\/&gt;\r\n&lt;\/BrowserRouter&gt;\r\n);\r\n}\r\n}\r\nexport default App;<\/code><\/pre>\n<\/div>\n<\/div>\n<p>\u0645\u0627 \u0645\u0624\u0644\u0641\u0647 BaseLayout \u0631\u0627 \u0628\u0627 \u0645\u0624\u0644\u0641\u0647 BrowserRouter \u067e\u06cc\u0686\u06cc\u062f\u0647\u200c\u0627\u06cc\u0645 \u0632\u06cc\u0631\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0642\u0631\u0627\u0631 \u0627\u0633\u062a \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0627\u062c\u0631\u0627 \u0634\u0648\u062f.<\/p>\n<p>\u0641\u0627\u06cc\u0644 \u062a\u06a9\u0645\u06cc\u0644 \u0634\u062f\u0647 \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<div class=\"hcb_wrap\">\n<div class=\"hcb_wrap\">\n<pre class=\"prism line-numbers lang-js\" data-lang=\"JavaScript\"><code>import React, { Component } from 'react';\r\nimport { BrowserRouter } from 'react-router-dom'\r\nimport { Route, Link } from 'react-router-dom'\r\nimport CustomersList from '.\/CustomersList'\r\nimport CustomerCreateUpdate from '.\/CustomerCreateUpdate'\r\nimport '.\/App.css';\r\nconst BaseLayout = () =&gt; (\r\n&lt;div className=\"container-fluid\"&gt;\r\n&lt;nav className=\"navbar navbar-expand-lg navbar-light bg-light\"&gt;\r\n&lt;a className=\"navbar-brand\" href=\"#\"&gt;Django React Demo&lt;\/a&gt;\r\n&lt;button className=\"navbar-toggler\" type=\"button\" data-toggle=\"collapse\" data-target=\"#navbarNavAltMarkup\" aria-controls=\"navbarNavAltMarkup\" aria-expanded=\"false\" aria-label=\"Toggle navigation\"&gt;\r\n&lt;span className=\"navbar-toggler-icon\"&gt;&lt;\/span&gt;\r\n&lt;\/button&gt;\r\n&lt;div className=\"collapse navbar-collapse\" id=\"navbarNavAltMarkup\"&gt;\r\n&lt;div className=\"navbar-nav\"&gt;\r\n&lt;a className=\"nav-item nav-link\" href=\"\/\"&gt;CUSTOMERS&lt;\/a&gt;\r\n&lt;a className=\"nav-item nav-link\" href=\"\/customer\"&gt;CREATE CUSTOMER&lt;\/a&gt;\r\n\r\n&lt;\/div&gt;\r\n&lt;\/div&gt;\r\n&lt;\/nav&gt;\r\n&lt;div className=\"content\"&gt;\r\n&lt;Route path=\"\/\" exact component={CustomersList} \/&gt;\r\n&lt;Route path=\"\/customer\/:pk\" component={CustomerCreateUpdate} \/&gt;\r\n&lt;Route path=\"\/customer\/\" exact component={CustomerCreateUpdate} \/&gt;\r\n&lt;\/div&gt;\r\n&lt;\/div&gt;\r\n)\r\nclass App extends Component {\r\nrender() {\r\nreturn (\r\n&lt;BrowserRouter&gt;\r\n&lt;BaseLayout\/&gt;\r\n&lt;\/BrowserRouter&gt;\r\n);\r\n}\r\n}\r\nexport default App;<\/code><\/pre>\n<\/div>\n<\/div>\n<p><img  loading=\"lazy\"  decoding=\"async\"  src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABAQMAAAAl21bKAAAAA1BMVEUAAP+KeNJXAAAAAXRSTlMAQObYZgAAAAlwSFlzAAAOxAAADsQBlSsOGwAAAApJREFUCNdjYAAAAAIAAeIhvDMAAAAASUVORK5CYII=\"  alt=\"\"  width=\"2840\"  height=\"1378\"  class=\"aligncenter wp-image-15798 size-full pk-lazyload\"  data-pk-sizes=\"auto\"  data-ls-sizes=\"auto, (max-width: 2840px) 100vw, 2840px\"  data-pk-src=\"https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6.png\"  data-pk-srcset=\"https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6.png 2840w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-300x146.png 300w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-1024x497.png 1024w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-768x373.png 768w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-1536x745.png 1536w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-2048x994.png 2048w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-110x53.png 110w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-200x97.png 200w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-380x184.png 380w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-255x124.png 255w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-550x267.png 550w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-800x388.png 800w, https:\/\/cdn.itpiran.net\/2024\/06\/29225457\/3-6-1160x563.png 1160w\" ><\/p>\n<p>\u067e\u0633 \u0627\u0632 \u0627\u0641\u0632\u0648\u062f\u0646 \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f\u060c \u0627\u06a9\u0646\u0648\u0646 \u0622\u0645\u0627\u062f\u0647 \u0622\u0632\u0645\u0627\u06cc\u0634 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0633\u062a\u06cc\u0645. \u0628\u0647 http:\/\/localhost:3000 \u0628\u0631\u0648\u06cc\u062f. \u0634\u0645\u0627 \u0628\u0627\u06cc\u062f \u0635\u0641\u062d\u0647 \u0627\u0648\u0644 \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0628\u06cc\u0646\u06cc\u062f:<\/p>\n<p>\u0628\u0627 \u0648\u062c\u0648\u062f \u0627\u06cc\u0646 \u0628\u0631\u0646\u0627\u0645\u0647\u060c \u0627\u06a9\u0646\u0648\u0646 \u067e\u0627\u06cc\u0647 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 CRM \u0631\u0627 \u062f\u0627\u0631\u06cc\u062f.<\/p>\n<h2 id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\">\u0646\u062a\u06cc\u062c\u0647<\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 Django \u0648 React \u06cc\u06a9 \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u062f\u0645\u0648 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u06cc\u062f. \u0634\u0645\u0627 \u0627\u0632 \u0686\u0627\u0631\u0686\u0648\u0628 Django REST \u0628\u0631\u0627\u06cc \u0633\u0627\u062e\u062a REST API\u060c Axios \u0628\u0631\u0627\u06cc \u0645\u0635\u0631\u0641 API \u0648 Bootstrap 4 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0627\u06cc\u0644 CSS \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u06cc\u062f. \u06a9\u062f \u0645\u0646\u0628\u0639 \u0627\u06cc\u0646 \u067e\u0631\u0648\u0698\u0647 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062f\u0631 \u0627\u06cc\u0646 \u0645\u062e\u0632\u0646 GitHub \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u062f.<\/p>\n","protected":false},"excerpt":{"rendered":"Introducci\u00f3n Las personas utilizan distintos tipos de dispositivos para conectarse a Internet y navegar por la web.\u2026","protected":false},"author":1,"featured_media":15800,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_yoast_wpseo_focuskw":"\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04","_yoast_wpseo_title":"","_yoast_wpseo_metadesc":"","_yoast_wpseo_canonical":"","_yoast_wpseo_opengraph-description":"","_yoast_wpseo_opengraph-image":"","_yoast_wpseo_twitter-description":"","_yoast_wpseo_twitter-image":"","_yoast_wpseo_focuskeywords":"","_yoast_wpseo_primary_category":"193","footnotes":""},"categories":[193,352,363,369],"tags":[412,434,384,376,400,368],"class_list":{"0":"post-15794","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-tutorials","8":"category-app","9":"category-programming","10":"category-os","11":"tag-application","12":"tag-django","13":"tag-java-script","14":"tag-python","15":"tag-react-js","16":"tag-ubuntu"},"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.3 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04 - \u0628\u0644\u0627\u06af ITPiran<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.itpiran.net\/blog\/es\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/\" \/>\n<meta property=\"og:locale\" content=\"es_ES\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04 - \u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"og:description\" content=\"\u0645\u0642\u062f\u0645\u0647 \u0645\u0631\u062f\u0645 \u0627\u0632 \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641\u06cc \u0627\u0632 \u062f\u0633\u062a\u06af\u0627\u0647 \u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 \u0627\u06cc\u0646\u062a\u0631\u0646\u062a \u0648 \u0645\u0631\u0648\u0631 \u0648\u0628 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f.&hellip;\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.itpiran.net\/blog\/es\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/\" \/>\n<meta property=\"og:site_name\" content=\"\u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"article:published_time\" content=\"2024-06-29T20:51:23+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.itpiran.net\/2024\/06\/30001834\/dja.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"1793\" \/>\n\t<meta property=\"og:image:height\" content=\"1110\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"Tiempo de lectura\" \/>\n\t<meta name=\"twitter:data2\" content=\"18 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/\"},\"author\":{\"name\":\"admin\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\"},\"headline\":\"\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04\",\"datePublished\":\"2024-06-29T20:51:23+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/\"},\"wordCount\":552,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/06\\\/30001834\\\/dja.jpg\",\"keywords\":[\"application\",\"Django\",\"Java Script\",\"Python\",\"React.js\",\"Ubuntu\"],\"articleSection\":[\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"\u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646\",\"\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc\",\"\u0633\u06cc\u0633\u062a\u0645 \u0639\u0627\u0645\u0644\"],\"inLanguage\":\"es\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/\",\"name\":\"\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04 - \u0628\u0644\u0627\u06af ITPiran\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/06\\\/30001834\\\/dja.jpg\",\"datePublished\":\"2024-06-29T20:51:23+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/#breadcrumb\"},\"inLanguage\":\"es\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"es\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/#primaryimage\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/06\\\/30001834\\\/dja.jpg\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/06\\\/30001834\\\/dja.jpg\",\"width\":1793,\"height\":1110},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"item\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/category\\\/tutorials\\\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"name\":\"\u0628\u0644\u0627\u06af ITPiran\",\"description\":\"\u0627\u062e\u0628\u0627\u0631 \u0648 \u0645\u0642\u0627\u0644\u0627\u062a \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"es\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\",\"name\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\",\"alternateName\":\"ITPIran Blog\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"es\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2023\\\/12\\\/27150508\\\/cropped-ITPIRAN-BLOG-LOGO-2.png\",\"width\":512,\"height\":512,\"caption\":\"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\",\"name\":\"admin\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/es\\\/author\\\/admin\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"C\u00f3mo crear una aplicaci\u00f3n web moderna para la gesti\u00f3n de informaci\u00f3n de clientes con Django y React en Ubuntu 18.04 - Blog de ITPiran","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.itpiran.net\/blog\/es\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/","og_locale":"es_ES","og_type":"article","og_title":"\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04 - \u0628\u0644\u0627\u06af ITPiran","og_description":"\u0645\u0642\u062f\u0645\u0647 \u0645\u0631\u062f\u0645 \u0627\u0632 \u0627\u0646\u0648\u0627\u0639 \u0645\u062e\u062a\u0644\u0641\u06cc \u0627\u0632 \u062f\u0633\u062a\u06af\u0627\u0647 \u0647\u0627 \u0628\u0631\u0627\u06cc \u0627\u062a\u0635\u0627\u0644 \u0628\u0647 \u0627\u06cc\u0646\u062a\u0631\u0646\u062a \u0648 \u0645\u0631\u0648\u0631 \u0648\u0628 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u0646\u062f.&hellip;","og_url":"https:\/\/www.itpiran.net\/blog\/es\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/","og_site_name":"\u0628\u0644\u0627\u06af ITPiran","article_published_time":"2024-06-29T20:51:23+00:00","og_image":[{"width":1793,"height":1110,"url":"https:\/\/cdn.itpiran.net\/2024\/06\/30001834\/dja.jpg","type":"image\/jpeg"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"Escrito por":"admin","Tiempo de lectura":"18 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/#article","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/"},"author":{"name":"admin","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81"},"headline":"\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04","datePublished":"2024-06-29T20:51:23+00:00","mainEntityOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/"},"wordCount":552,"commentCount":0,"publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/06\/30001834\/dja.jpg","keywords":["application","Django","Java Script","Python","React.js","Ubuntu"],"articleSection":["\u0622\u0645\u0648\u0632\u0634\u06cc","\u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646","\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc","\u0633\u06cc\u0633\u062a\u0645 \u0639\u0627\u0645\u0644"],"inLanguage":"es","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/","url":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/","name":"C\u00f3mo crear una aplicaci\u00f3n web moderna para la gesti\u00f3n de informaci\u00f3n de clientes con Django y React en Ubuntu 18.04 - Blog de ITPiran","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/#primaryimage"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/06\/30001834\/dja.jpg","datePublished":"2024-06-29T20:51:23+00:00","breadcrumb":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/#breadcrumb"},"inLanguage":"es","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/"]}]},{"@type":"ImageObject","inLanguage":"es","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/#primaryimage","url":"https:\/\/cdn.itpiran.net\/2024\/06\/30001834\/dja.jpg","contentUrl":"https:\/\/cdn.itpiran.net\/2024\/06\/30001834\/dja.jpg","width":1793,"height":1110},{"@type":"BreadcrumbList","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/how-to-build-a-modern-web-application-to-manage-customer-information-with-django-and-react-on-ubuntu-18-04\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.itpiran.net\/blog\/"},{"@type":"ListItem","position":2,"name":"\u0622\u0645\u0648\u0632\u0634\u06cc","item":"https:\/\/www.itpiran.net\/blog\/category\/tutorials\/"},{"@type":"ListItem","position":3,"name":"\u0646\u062d\u0648\u0647 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646 \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u062c\u0646\u06af\u0648 \u0648 \u0648\u0627\u06a9\u0646\u0634 \u062f\u0631 \u0627\u0648\u0628\u0648\u0646\u062a\u0648 18.04"}]},{"@type":"WebSite","@id":"https:\/\/www.itpiran.net\/blog\/#website","url":"https:\/\/www.itpiran.net\/blog\/","name":"Blog de ITPiran","description":"Noticias y art\u00edculos sobre comercio sostenible en Ir\u00e1n","publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.itpiran.net\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"es"},{"@type":"Organization","@id":"https:\/\/www.itpiran.net\/blog\/#organization","name":"Blog sobre negocios iran\u00edes sostenibles","alternateName":"ITPIran Blog","url":"https:\/\/www.itpiran.net\/blog\/","logo":{"@type":"ImageObject","inLanguage":"es","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","contentUrl":"https:\/\/cdn.itpiran.net\/2023\/12\/27150508\/cropped-ITPIRAN-BLOG-LOGO-2.png","width":512,"height":512,"caption":"\u0628\u0644\u0627\u06af \u062a\u062c\u0627\u0631\u062a \u067e\u0627\u06cc\u062f\u0627\u0631 \u0627\u06cc\u0631\u0627\u0646\u06cc\u0627\u0646"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81","name":"administraci\u00f3n","url":"https:\/\/www.itpiran.net\/blog\/es\/author\/admin\/"}]}},"_links":{"self":[{"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/posts\/15794","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/comments?post=15794"}],"version-history":[{"count":4,"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/posts\/15794\/revisions"}],"predecessor-version":[{"id":15802,"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/posts\/15794\/revisions\/15802"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/media\/15800"}],"wp:attachment":[{"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/media?parent=15794"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/categories?post=15794"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/es\/wp-json\/wp\/v2\/tags?post=15794"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}