{"id":15190,"date":"2024-04-01T17:08:49","date_gmt":"2024-04-01T13:38:49","guid":{"rendered":"https:\/\/www.itpiran.net\/blog\/?p=15190"},"modified":"2024-04-01T17:08:49","modified_gmt":"2024-04-01T13:38:49","slug":"typescript-new-projectstep-1-starting-the-typescript-project","status":"publish","type":"post","link":"https:\/\/www.itpiran.net\/blog\/ar\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/","title":{"rendered":"\u0643\u064a\u0641\u064a\u0629 \u0628\u062f\u0621 \u0645\u0634\u0631\u0648\u0639 TypeScript \u062c\u062f\u064a\u062f"},"content":{"rendered":"<h2 id=\"%d9%85%d9%82%d8%af%d9%85%d9%87\">\u0645\u0642\u062f\u0645\u0629<\/h2>\n<p>\u0631\u0628\u0645\u0627 \u0633\u0628\u0642 \u0644\u0643 \u0627\u0644\u0639\u0645\u0644 \u0645\u0639 TypeScript \u0639\u0646\u062f \u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0645\u0634\u0631\u0648\u0639 \u062a\u0645\u0647\u064a\u062f\u064a \u0623\u0648 \u0623\u062f\u0627\u0629 \u0645\u062b\u0644 Angular CLI. \u0641\u064a \u0647\u0630\u0627 \u0627\u0644\u0628\u0631\u0646\u0627\u0645\u062c \u0627\u0644\u062a\u0639\u0644\u064a\u0645\u064a\u060c \u0633\u062a\u062a\u0639\u0644\u0645 \u0643\u064a\u0641\u064a\u0629 \u0625\u0639\u062f\u0627\u062f \u0645\u0634\u0631\u0648\u0639 TypeScript \u062f\u0648\u0646 \u0627\u0644\u062d\u0627\u062c\u0629 \u0625\u0644\u0649 \u0623\u062f\u0627\u0629 \u062a\u0645\u0647\u064a\u062f\u064a\u0629. \u0633\u062a\u062a\u0639\u0644\u0645 \u0623\u064a\u0636\u064b\u0627 \u0643\u064a\u0641\u064a\u0629 \u0639\u0645\u0644 \u0627\u0644\u062a\u062c\u0645\u064a\u0639 \u0641\u064a TypeScript \u0648\u0643\u064a\u0641\u064a\u0629 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0623\u062f\u0627\u0629 Linter \u0641\u064a \u0645\u0634\u0631\u0648\u0639 TypeScript \u0627\u0644\u062e\u0627\u0635 \u0628\u0643.<\/p>\n<h5 id=\"%d9%be%db%8c%d8%b4-%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7\">\u0627\u0644\u0645\u062a\u0637\u0644\u0628\u0627\u062a \u0627\u0644\u0623\u0633\u0627\u0633\u064a\u0629<\/h5>\n<ul>\n<li>\u062a\u0645 \u062a\u062b\u0628\u064a\u062a \u0623\u062d\u062f\u062b \u0625\u0635\u062f\u0627\u0631 \u0645\u0646 Node \u0639\u0644\u0649 \u062c\u0647\u0627\u0632\u0643.<\/li>\n<li>\u0627\u0644\u062a\u0639\u0631\u0641 \u0639\u0644\u0649\u00a0 <code>npm<\/code><\/li>\n<\/ul>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-1-%d8%b4%d8%b1%d9%88%d8%b9-%d9%be%d8%b1%d9%88%da%98%d9%87-typescript\">\u0627\u0644\u062e\u0637\u0648\u0629 1 - \u0628\u062f\u0621 \u0645\u0634\u0631\u0648\u0639 TypeScript<\/h2>\n<p>\u0644\u0628\u062f\u0621 \u0645\u0634\u0631\u0648\u0639 TypeScript \u0627\u0644\u062e\u0627\u0635 \u0628\u0643\u060c \u062a\u062d\u062a\u0627\u062c \u0625\u0644\u0649 \u0625\u0646\u0634\u0627\u0621 \u062f\u0644\u064a\u0644 \u0644\u0645\u0634\u0631\u0648\u0639\u0643:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\">mkdir typescript-project<\/pre>\n<\/div>\n<p>\u0627\u0646\u062a\u0642\u0644 \u0627\u0644\u0622\u0646 \u0625\u0644\u0649 \u062f\u0644\u064a\u0644 \u0627\u0644\u0645\u0634\u0631\u0648\u0639 \u0627\u0644\u062e\u0627\u0635 \u0628\u0643:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>cd typescript-project<\/code><\/pre>\n<\/div>\n<p>\u064a\u0645\u0643\u0646\u0643 \u062a\u062b\u0628\u064a\u062a TypeScript \u0639\u0646 \u0637\u0631\u064a\u0642 \u0625\u0639\u062f\u0627\u062f \u062f\u0644\u064a\u0644 \u0627\u0644\u0645\u0634\u0631\u0648\u0639 \u0627\u0644\u062e\u0627\u0635 \u0628\u0643:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npm i typescript --save-dev<\/code><\/pre>\n<\/div>\n<p>\u0645\u0646 \u0627\u0644\u0645\u0647\u0645 \u0623\u0646 \u064a\u0643\u0648\u0646 \u0627\u0644\u0639\u0644\u0645 <code>--\u062d\u0641\u0638-\u0627\u0644\u062a\u0637\u0648\u064a\u0631<\/code> \u0623\u0636\u0641 TypeScript \u0644\u0623\u0646\u0647 \u064a\u062e\u0632\u0651\u0646 TypeScript \u0643\u0627\u0639\u062a\u0645\u0627\u062f\u064a\u0629 \u062a\u0637\u0648\u064a\u0631. \u0647\u0630\u0627 \u064a\u0639\u0646\u064a \u0623\u0646 TypeScript \u0636\u0631\u0648\u0631\u064a \u0644\u062a\u0637\u0648\u064a\u0631 \u0645\u0634\u0631\u0648\u0639\u0643.<\/p>\n<p>\u0628\u0639\u062f \u062a\u062b\u0628\u064a\u062a TypeScript\u060c \u064a\u0645\u0643\u0646\u0643 \u062a\u0647\u064a\u0626\u0629 \u0645\u0634\u0631\u0648\u0639 TypeScript \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0627\u0644\u0623\u0645\u0631 \u0627\u0644\u062a\u0627\u0644\u064a:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npx tsc --init<\/code><\/pre>\n<\/div>\n<p><code>npm<\/code> \u0643\u0645\u0627 \u0623\u0646 \u0644\u062f\u064a\u0647\u0627 \u0623\u062f\u0627\u0629 \u062a\u0633\u0645\u0649 <code>\u0646 \u0628\u064a \u0627\u0643\u0633<\/code> \u0627\u0644\u0630\u064a \u064a\u0646\u0641\u0630 \u0627\u0644\u062d\u0632\u0645 \u0627\u0644\u0642\u0627\u0628\u0644\u0629 \u0644\u0644\u062a\u0646\u0641\u064a\u0630. <code>\u0646 \u0628\u064a \u0627\u0643\u0633<\/code> \u0625\u0646\u0647 \u064a\u0633\u0645\u062d \u0644\u0646\u0627 \u0628\u062a\u0634\u063a\u064a\u0644 \u0627\u0644\u062d\u0632\u0645 \u062f\u0648\u0646 \u0627\u0644\u062d\u0627\u062c\u0629 \u0625\u0644\u0649 \u062a\u062b\u0628\u064a\u062a \u0639\u0627\u0644\u0645\u064a.<\/p>\n<p>\u0637\u0644\u0628 <code>\u062a\u064a \u0627\u0633 \u0633\u064a<\/code> \u064a\u064f\u0633\u062a\u062e\u062f\u0645 \u0647\u0646\u0627 \u0644\u0623\u0646\u0647 \u0627\u0644\u0645\u064f\u062c\u0645\u0650\u0651\u0639 \u0627\u0644\u0645\u064f\u0636\u0645\u064e\u0651\u0646 \u0641\u064a TypeScript. \u0639\u0646\u062f \u0643\u062a\u0627\u0628\u0629 \u0627\u0644\u0643\u0648\u062f \u0641\u064a TypeScript\u060c \u064a\u062a\u0645 \u062a\u0646\u0641\u064a\u0630\u0647 <code>\u062a\u064a \u0627\u0633 \u0633\u064a<\/code> \u064a\u0642\u0648\u0645 \u0628\u062a\u062d\u0648\u064a\u0644 \u0623\u0648 \u062a\u062c\u0645\u064a\u0639 \u0627\u0644\u0643\u0648\u062f \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0625\u0644\u0649 JavaScript.<\/p>\n<p>\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0627\u0644\u0639\u0644\u0645 <code>--init<\/code> \u0641\u064a \u0627\u0644\u0623\u0645\u0631 \u0623\u0639\u0644\u0627\u0647\u060c \u064a\u062a\u0645 \u062a\u0647\u064a\u0626\u0629 \u0645\u0634\u0631\u0648\u0639\u0643 \u0628\u0625\u0646\u0634\u0627\u0621 \u0645\u0644\u0641 tsconfig.json \u0641\u064a \u062f\u0644\u064a\u0644 \u0645\u0634\u0631\u0648\u0639 TypeScript. \u064a\u062a\u064a\u062d \u0644\u0643 \u0647\u0630\u0627 \u0627\u0644\u0645\u0644\u0641 \u0625\u062c\u0631\u0627\u0621 \u0627\u0644\u0645\u0632\u064a\u062f \u0645\u0646 \u0627\u0644\u062a\u0647\u064a\u0626\u0629 \u0648\u0645\u0639\u0631\u0641\u0629 \u0643\u064a\u0641\u064a\u0629 \u062a\u0641\u0627\u0639\u0644 TypeScript \u0645\u0639 \u0627\u0644\u0645\u064f\u062c\u0645\u0650\u0651\u0639. <code>\u062a\u064a \u0627\u0633 \u0633\u064a<\/code> \u062a\u062e\u0635\u064a\u0635. \u064a\u0645\u0643\u0646\u0643 \u0625\u0632\u0627\u0644\u0629 \u0648\u0625\u0636\u0627\u0641\u0629 \u0648\u062a\u0639\u062f\u064a\u0644 \u0627\u0644\u062a\u0643\u0648\u064a\u0646\u0627\u062a \u0641\u064a \u0647\u0630\u0627 \u0627\u0644\u0645\u0644\u0641 \u0644\u062a\u0644\u0628\u064a\u0629 \u0627\u062d\u062a\u064a\u0627\u062c\u0627\u062a\u0643 \u0639\u0644\u0649 \u0627\u0644\u0646\u062d\u0648 \u0627\u0644\u0623\u0645\u062b\u0644.<\/p>\n<p><code>tsconfig.json<\/code> \u0627\u0641\u062a\u062d\u0647 \u0641\u064a \u0645\u062d\u0631\u0631 \u0627\u0644\u0646\u0635\u0648\u0635 \u0627\u0644\u062e\u0627\u0635 \u0628\u0643 \u0644\u0644\u0639\u062b\u0648\u0631 \u0639\u0644\u0649 \u0627\u0644\u062a\u0643\u0648\u064a\u0646 \u0627\u0644\u0627\u0641\u062a\u0631\u0627\u0636\u064a:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>nano tsconfig.json<\/code><\/pre>\n<\/div>\n<p>\u0633\u064a\u0643\u0648\u0646 \u0647\u0646\u0627\u0643 \u0627\u0644\u0639\u062f\u064a\u062f \u0645\u0646 \u0627\u0644\u062e\u064a\u0627\u0631\u0627\u062a\u060c \u0648\u0633\u064a\u062a\u0645 \u0634\u0631\u062d \u0645\u0639\u0638\u0645\u0647\u0627 \u0623\u062f\u0646\u0627\u0647:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-ts\" data-lang=\"TypeScript\"><code>{\r\n\"compilerOptions\": {\r\n\/* Visit https:\/\/aka.ms\/tsconfig.json to read more about this file *\/\r\n\/* Projects *\/\r\n\/\/ \"incremental\": true, \/* Enable incremental compilation *\/\r\n\/\/ \"composite\": true, \/* Enable constraints that allow a TypeScript project to be used with project references. *\/\r\n\/\/ \"tsBuildInfoFile\": \".\/\", \/* Specify the folder for .tsbuildinfo incremental compilation files. *\/\r\n\/\/ \"disableSourceOfProjectReferenceRedirect\": true, \/* Disable preferring source files instead of declaration files when referencing composite projects *\/\r\n\/\/ \"disableSolutionSearching\": true, \/* Opt a project out of multi-project reference checking when editing. *\/\r\n\/\/ \"disableReferencedProjectLoad\": true, \/* Reduce the number of projects loaded automatically by TypeScript. *\/\r\n. . .\r\n}\r\n}<\/code><\/pre>\n<\/div>\n<p>\u064a\u0645\u0643\u0646\u0643 \u062a\u062e\u0635\u064a\u0635 \u0625\u0639\u062f\u0627\u062f\u0627\u062a TypeScript \u0639\u0628\u0631 \u0645\u0644\u0641 tsconfig.json. \u0639\u0644\u0649 \u0633\u0628\u064a\u0644 \u0627\u0644\u0645\u062b\u0627\u0644\u060c \u064a\u0645\u0643\u0646\u0643 \u0625\u0644\u063a\u0627\u0621 \u062a\u0639\u0644\u064a\u0642 \u0645\u062f\u062e\u0644 outDir \u0648\u062a\u0639\u064a\u064a\u0646\u0647 \u0625\u0644\u0649 &quot;.\/build&quot;\u060c \u0645\u0645\u0627 \u0633\u064a\u0636\u0639 \u062c\u0645\u064a\u0639 \u0645\u0644\u0641\u0627\u062a TypeScript \u0627\u0644\u0645\u064f\u062c\u0645\u0651\u0639\u0629 \u0641\u064a \u0647\u0630\u0627 \u0627\u0644\u0645\u062c\u0644\u062f.<\/p>\n<p>\u0639\u0646 \u0637\u0631\u064a\u0642 \u062a\u062b\u0628\u064a\u062a TypeScript \u0648\u062a\u062b\u0628\u064a\u062a \u0627\u0644\u0645\u0644\u0641 <code>tsconfig.json<\/code>\u0627\u0644\u0622\u0646 \u064a\u0645\u0643\u0646\u0643 \u0627\u0644\u0627\u0646\u062a\u0642\u0627\u0644 \u0625\u0644\u0649 \u0628\u0631\u0645\u062c\u0629 \u062a\u0637\u0628\u064a\u0642 TypeScript \u0648\u062a\u062c\u0645\u064a\u0639\u0647.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-2-%da%a9%d8%a7%d9%85%d9%be%d8%a7%db%8c%d9%84-%d9%be%d8%b1%d9%88%da%98%d9%87-typescript\">\u0627\u0644\u062e\u0637\u0648\u0629 2 - \u062a\u062c\u0645\u064a\u0639 \u0645\u0634\u0631\u0648\u0639 TypeScript<\/h2>\n<p>\u0627\u0644\u0622\u0646 \u064a\u0645\u0643\u0646\u0643 \u0627\u0644\u0628\u062f\u0621 \u0641\u064a \u0628\u0631\u0645\u062c\u0629 \u0645\u0634\u0631\u0648\u0639 TypeScript \u0627\u0644\u062e\u0627\u0635 \u0628\u0643. \u0623\u0646\u0634\u0626 \u0645\u0644\u0641\u064b\u0627 \u062c\u062f\u064a\u062f\u064b\u0627 \u0628\u0627\u0633\u0645 <code>index.ts<\/code> \u0627\u0641\u062a\u062d\u0647 \u0641\u064a \u0645\u062d\u0631\u0631 \u0627\u0644\u0646\u0635\u0648\u0635 \u0644\u062f\u064a\u0643. \u0623\u0644\u0635\u0642 \u0643\u0648\u062f TypeScript \u0627\u0644\u062a\u0627\u0644\u064a \u0641\u064a\u0647 <code>index.ts<\/code> \u064a\u0643\u062a\u0628:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-ts\" data-lang=\"TypeScript\"><code>const world = 'world';\r\nexport function hello(who: string = world): string {\r\nreturn `Hello ${who}! `;\r\n}<\/code><\/pre>\n<\/div>\n<p>\u0645\u0639 \u0648\u062c\u0648\u062f \u0647\u0630\u0627 \u0627\u0644\u0643\u0648\u062f \u0627\u0644\u062e\u0627\u0635 \u0628\u0640 TypeScript\u060c \u0645\u0634\u0631\u0648\u0639\u0643 \u062c\u0627\u0647\u0632 \u0644\u0644\u062a\u062c\u0645\u064a\u0639. \u0634\u063a\u0651\u0644 \u0627\u0644\u0623\u0645\u0631 tsc \u0645\u0646 \u062f\u0644\u064a\u0644 \u0645\u0634\u0631\u0648\u0639\u0643:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npx tsc<\/code><\/pre>\n<\/div>\n<p>\u0633\u062a\u0644\u0627\u062d\u0638 \u0623\u0646 \u0645\u0644\u0641 JavaScript \u0627\u0644\u0645\u062c\u0645\u0651\u0639 index.js \u0648\u0645\u0644\u0641 sourcemap index.js.map \u062a\u0645\u062a \u0625\u0636\u0627\u0641\u062a\u0647\u0645\u0627 \u0625\u0644\u0649 \u0645\u062c\u0644\u062f \u0627\u0644\u0628\u0646\u0627\u0621\u060c \u0625\u0630\u0627 \u0642\u0645\u062a \u0628\u062a\u062d\u062f\u064a\u062f\u0647 \u0641\u064a \u0645\u0644\u0641 tsconfig.js.<\/p>\n<p><code>index.js<\/code> \u0627\u0641\u062a\u062d\u0647 \u0648\u0633\u0648\u0641 \u062a\u0631\u0649 \u0643\u0648\u062f JavaScript \u0627\u0644\u0645\u062a\u0631\u062c\u0645 \u0627\u0644\u062a\u0627\u0644\u064a:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-ts\" data-lang=\"TypeScript\"><code>\"use strict\";\r\nObject.defineProperty(exports, \"__esModule\", { value: true });\r\nexports.hello = void 0;\r\nconst world = 'world';\r\nfunction hello(who = world) {\r\nreturn `Hello ${who}! `;\r\n}\r\nexports.hello = hello;<\/code><\/pre>\n<\/div>\n<p>\u0642\u062f \u064a\u0643\u0648\u0646 \u062a\u0634\u063a\u064a\u0644 \u0645\u064f\u062c\u0645\u0650\u0651\u0639 TypeScript \u0641\u064a \u0643\u0644 \u0645\u0631\u0629 \u062a\u064f\u062c\u0631\u064a \u0641\u064a\u0647\u0627 \u062a\u063a\u064a\u064a\u0631\u064b\u0627 \u0623\u0645\u0631\u064b\u0627 \u0645\u064f\u0645\u0644\u064b\u0627. \u0644\u062d\u0644 \u0647\u0630\u0647 \u0627\u0644\u0645\u0634\u0643\u0644\u0629\u060c \u064a\u0645\u0643\u0646\u0643 \u0648\u0636\u0639 \u0627\u0644\u0645\u064f\u062c\u0645\u0650\u0651\u0639 \u0641\u064a \u0648\u0636\u0639 \u0627\u0644\u0645\u0631\u0627\u0642\u0628\u0629\u060c \u0648\u0627\u0644\u0630\u064a \u0633\u064a\u064f\u0639\u064a\u062f \u062a\u062c\u0645\u064a\u0639 \u0627\u0644\u0643\u0648\u062f \u0641\u064a \u0643\u0644 \u0645\u0631\u0629 \u064a\u064f\u062c\u0631\u0649 \u0641\u064a\u0647\u0627 \u062a\u063a\u064a\u064a\u0631.<\/p>\n<p>\u064a\u0645\u0643\u0646\u0643 \u062a\u0645\u0643\u064a\u0646 \u0648\u0636\u0639 \u0627\u0644\u0633\u0627\u0639\u0629 \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0627\u0644\u0623\u0645\u0631 \u0627\u0644\u062a\u0627\u0644\u064a:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npx tsc -w<\/code><\/pre>\n<\/div>\n<p>\u0644\u0642\u062f \u062a\u0639\u0644\u0645\u062a\u064e \u0643\u064a\u0641\u064a\u0629 \u0639\u0645\u0644 \u0645\u064f\u062c\u0645\u0650\u0651\u0639 TypeScript\u060c \u0648\u064a\u0645\u0643\u0646\u0643 \u0627\u0644\u0622\u0646 \u062a\u062c\u0645\u064a\u0639 \u0645\u0644\u0641\u0627\u062a TypeScript \u0628\u0646\u062c\u0627\u062d. \u064a\u0645\u0643\u0646\u0643 \u0627\u0644\u0627\u0631\u062a\u0642\u0627\u0621 \u0628\u0645\u0634\u0627\u0631\u064a\u0639 TypeScript \u0627\u0644\u062e\u0627\u0635\u0629 \u0628\u0643 \u0625\u0644\u0649 \u0645\u0633\u062a\u0648\u0649 \u0623\u0639\u0644\u0649 \u0645\u0646 \u062e\u0644\u0627\u0644 \u0625\u0636\u0627\u0641\u0629 \u0645\u064f\u062d\u0633\u0650\u0651\u0646 \u0646\u0635\u0648\u0635 (linter) \u0625\u0644\u0649 \u0633\u064a\u0631 \u0639\u0645\u0644\u0643.<\/p>\n<h2 id=\"%d9%85%d8%b1%d8%ad%d9%84%d9%87-3-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2-google-typescript-style-%d8%a8%d8%b1%d8%a7%db%8c-%d9%be%d8%b1-%da%a9%d8%b1%d8%af%d9%86-%d9%88-%d8%aa\">\u0627\u0644\u062e\u0637\u0648\u0629 3 - \u0627\u0633\u062a\u062e\u062f\u0645 Google TypeScript Style \u0644\u0645\u0644\u0621 \u0648\u062a\u0635\u062d\u064a\u062d \u0627\u0644\u0643\u0648\u062f \u0627\u0644\u062e\u0627\u0635 \u0628\u0643<\/h2>\n<p>\u064a\u0633\u0627\u0639\u062f\u0643 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0645\u064f\u0631\u0627\u062c\u0639 \u0627\u0644\u0646\u0635 (linter) \u0641\u064a \u0643\u062a\u0627\u0628\u0629 \u0627\u0644\u0634\u064a\u0641\u0631\u0629 \u0627\u0644\u0628\u0631\u0645\u062c\u064a\u0629 \u0639\u0644\u0649 \u0627\u0643\u062a\u0634\u0627\u0641 \u0627\u0644\u062a\u0646\u0627\u0642\u0636\u0627\u062a \u0648\u0623\u062e\u0637\u0627\u0621 \u0628\u0646\u0627\u0621 \u0627\u0644\u062c\u0645\u0644\u0629 \u0648\u0627\u0644\u0633\u0647\u0648 \u0641\u064a \u0627\u0644\u0634\u064a\u0641\u0631\u0629 \u0627\u0644\u0628\u0631\u0645\u062c\u064a\u0629 \u0628\u0633\u0631\u0639\u0629. \u0628\u0627\u0644\u0625\u0636\u0627\u0641\u0629 \u0625\u0644\u0649 \u0630\u0644\u0643\u060c \u0644\u0627 \u064a\u0633\u0627\u0639\u062f\u0643 \u062f\u0644\u064a\u0644 \u0627\u0644\u0623\u0633\u0644\u0648\u0628 \u0639\u0644\u0649 \u0636\u0645\u0627\u0646 \u062c\u0648\u062f\u0629 \u0635\u064a\u0627\u063a\u0629 \u0627\u0644\u0634\u064a\u0641\u0631\u0629 \u0648\u062a\u0646\u0627\u0633\u0642\u0647\u0627 \u0641\u062d\u0633\u0628\u060c \u0628\u0644 \u064a\u062a\u064a\u062d \u0644\u0643 \u0623\u064a\u0636\u064b\u0627 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0623\u062f\u0648\u0627\u062a \u0625\u0636\u0627\u0641\u064a\u0629 \u0644\u062a\u0639\u0632\u064a\u0632 \u0647\u0630\u0627 \u0627\u0644\u0623\u0633\u0644\u0648\u0628. \u0648\u0645\u0646 \u0627\u0644\u0623\u062f\u0648\u0627\u062a \u0627\u0644\u0634\u0627\u0626\u0639\u0629 \u0641\u064a \u0647\u0630\u0627 \u0627\u0644\u0645\u062c\u0627\u0644 \u0623\u062f\u0627\u0629 eslint\u060c \u0627\u0644\u062a\u064a \u062a\u0639\u0645\u0644 \u0628\u0643\u0641\u0627\u0621\u0629 \u0645\u0639 \u0627\u0644\u0639\u062f\u064a\u062f \u0645\u0646 \u0628\u064a\u0626\u0627\u062a \u0627\u0644\u062a\u0637\u0648\u064a\u0631 \u0627\u0644\u0645\u062a\u0643\u0627\u0645\u0644\u0629 (IDEs) \u0644\u062a\u0633\u0647\u064a\u0644 \u0639\u0645\u0644\u064a\u0629 \u0627\u0644\u062a\u0637\u0648\u064a\u0631.<\/p>\n<p>\u0628\u0645\u062c\u0631\u062f \u062a\u0634\u063a\u064a\u0644 \u0645\u0634\u0631\u0648\u0639\u0643\u060c \u064a\u0645\u0643\u0646\u0643 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0623\u062f\u0648\u0627\u062a \u0623\u062e\u0631\u0649 \u0641\u064a \u0628\u064a\u0626\u0629 TypeScript \u0644\u0645\u0633\u0627\u0639\u062f\u062a\u0643 \u0639\u0644\u0649 \u062a\u062c\u0646\u0628 \u0625\u0639\u062f\u0627\u062f \u0645\u0644\u0641 tsconfig.json \u064a\u062f\u0648\u064a\u064b\u0627. \u062a\u064f\u0639\u062f \u0623\u062f\u0627\u0629 Google TypeScript Style \u0625\u062d\u062f\u0649 \u0647\u0630\u0647 \u0627\u0644\u0623\u062f\u0648\u0627\u062a. \u062a\u064f\u0639\u0631\u0641 \u0623\u064a\u0636\u064b\u0627 \u0628\u0627\u0633\u0645 GTS\u060c \u0648\u0647\u064a \u062f\u0644\u064a\u0644 \u0623\u0646\u0645\u0627\u0637\u060c \u0648\u0648\u0631\u0642\u0629 \u0623\u0646\u0645\u0627\u0637 \u0645\u0636\u0645\u0646\u0629\u060c \u0648\u0645\u0635\u062d\u062d \u0623\u0643\u0648\u0627\u062f \u062a\u0644\u0642\u0627\u0626\u064a\u060c \u0643\u0644 \u0630\u0644\u0643 \u0641\u064a \u0623\u062f\u0627\u0629 \u0648\u0627\u062d\u062f\u0629. \u064a\u0633\u0627\u0639\u062f\u0643 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 GTS \u0639\u0644\u0649 \u062a\u0634\u063a\u064a\u0644 \u0645\u0634\u0631\u0648\u0639 TypeScript \u062c\u062f\u064a\u062f \u0628\u0633\u0631\u0639\u0629\u060c \u0648\u062a\u062c\u0646\u0628 \u0627\u0644\u0642\u0644\u0642 \u0628\u0634\u0623\u0646 \u0627\u0644\u062a\u0641\u0627\u0635\u064a\u0644 \u0627\u0644\u062a\u0646\u0638\u064a\u0645\u064a\u0629 \u0627\u0644\u0635\u063a\u064a\u0631\u0629\u060c \u0648\u0627\u0644\u062a\u0631\u0643\u064a\u0632 \u0639\u0644\u0649 \u062a\u0635\u0645\u064a\u0645 \u0645\u0634\u0631\u0648\u0639\u0643. \u0643\u0645\u0627 \u062a\u0648\u0641\u0631 GTS \u0625\u0639\u062f\u0627\u062f\u0627\u062a \u0627\u0641\u062a\u0631\u0627\u0636\u064a\u0629\u060c \u0645\u0627 \u064a\u0639\u0646\u064a \u0623\u0646\u0643 \u0644\u0646 \u062a\u062d\u062a\u0627\u062c \u0625\u0644\u0649 \u062a\u062e\u0635\u064a\u0635 \u0627\u0644\u0639\u062f\u064a\u062f \u0645\u0646 \u0627\u0644\u0625\u0639\u062f\u0627\u062f\u0627\u062a.<\/p>\n<p>\u0627\u0628\u062f\u0623 \u0628\u062a\u062b\u0628\u064a\u062a GTS:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npm i gts --save-dev<\/code><\/pre>\n<\/div>\n<p>\u0645\u0646 \u0647\u0646\u0627\u060c \u0642\u0645 \u0628\u062a\u0647\u064a\u0626\u0629 GTS \u0628\u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0627\u0644\u0623\u0645\u0631 \u0627\u0644\u062a\u0627\u0644\u064a:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-bash\" data-lang=\"Bash\"><code>npx gts init<\/code><\/pre>\n<\/div>\n<p>\u0633\u064a\u064f\u0646\u0634\u0626 \u0627\u0644\u0623\u0645\u0631 \u0623\u0639\u0644\u0627\u0647 \u0643\u0644 \u0645\u0627 \u062a\u062d\u062a\u0627\u062c\u0647 \u0644\u0628\u062f\u0621 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 TypeScript\u060c \u0628\u0645\u0627 \u0641\u064a \u0630\u0644\u0643 \u0645\u0644\u0641 tsconfig.json \u0648\u0625\u0639\u062f\u0627\u062f\u0627\u062a \u0627\u0644\u062a\u062f\u0642\u064a\u0642. \u0633\u064a\u062a\u0645 \u0623\u064a\u0636\u064b\u0627 \u0625\u0646\u0634\u0627\u0621 \u0645\u0644\u0641 package.json \u0625\u0630\u0627 \u0644\u0645 \u064a\u0643\u0646 \u0644\u062f\u064a\u0643 \u0648\u0627\u062d\u062f \u0628\u0627\u0644\u0641\u0639\u0644.<\/p>\n<p>\u064a\u0624\u062f\u064a \u062a\u0634\u063a\u064a\u0644 npx gts init \u0623\u064a\u0636\u064b\u0627 \u0625\u0644\u0649 \u0625\u0636\u0627\u0641\u0629 \u0646\u0635\u0648\u0635 \u0628\u0631\u0645\u062c\u064a\u0629 \u0645\u0641\u064a\u062f\u0629 \u0645\u0646 npm \u0625\u0644\u0649 \u0645\u0644\u0641 package.json. \u0639\u0644\u0649 \u0633\u0628\u064a\u0644 \u0627\u0644\u0645\u062b\u0627\u0644\u060c \u064a\u0645\u0643\u0646\u0643 \u0627\u0644\u0622\u0646 \u062a\u0634\u063a\u064a\u0644 npm run compile \u0644\u062a\u062c\u0645\u064a\u0639 \u0645\u0634\u0631\u0648\u0639 TypeScript. \u0644\u0644\u062a\u062d\u0642\u0642 \u0645\u0646 \u0623\u062e\u0637\u0627\u0621 Curtain\u060c \u064a\u0645\u0643\u0646\u0643 \u0627\u0644\u0622\u0646 \u062a\u0634\u063a\u064a\u0644 npm run check.<\/p>\n<p>\u062a\u0645 \u0627\u0644\u0622\u0646 \u062a\u062b\u0628\u064a\u062a GTS \u0648\u062f\u0645\u062c\u0647 \u0628\u0634\u0643\u0644 \u0635\u062d\u064a\u062d \u0641\u064a \u0645\u0634\u0631\u0648\u0639 TypeScript \u0627\u0644\u062e\u0627\u0635 \u0628\u0643. \u0633\u064a\u0633\u0645\u062d \u0644\u0643 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 GTS \u0641\u064a \u0627\u0644\u0645\u0634\u0627\u0631\u064a\u0639 \u0627\u0644\u0645\u0633\u062a\u0642\u0628\u0644\u064a\u0629 \u0628\u0625\u0639\u062f\u0627\u062f \u0645\u0634\u0627\u0631\u064a\u0639 TypeScript \u062c\u062f\u064a\u062f\u0629 \u0628\u0633\u0631\u0639\u0629 \u0645\u0639 \u0627\u0644\u0625\u0639\u062f\u0627\u062f\u0627\u062a \u0627\u0644\u0644\u0627\u0632\u0645\u0629.<\/p>\n<p>\u0628\u0645\u0627 \u0623\u0646 GTS \u064a\u064f\u0642\u062f\u0651\u0645 \u0646\u0647\u062c\u064b\u0627 \u0642\u0627\u0626\u0645\u064b\u0627 \u0639\u0644\u0649 \u0627\u0644\u0622\u0631\u0627\u0621 \u062f\u0648\u0646 \u0627\u0644\u062d\u0627\u062c\u0629 \u0625\u0644\u0649 \u062a\u0647\u064a\u0626\u0629\u060c \u0641\u0625\u0646\u0647 \u064a\u0633\u062a\u062e\u062f\u0645 \u0642\u0648\u0627\u0639\u062f\u0647 \u0627\u0644\u062e\u0627\u0635\u0629. \u062a\u062a\u0628\u0639 \u0647\u0630\u0647 \u0627\u0644\u0642\u0648\u0627\u0639\u062f \u0623\u0641\u0636\u0644 \u0627\u0644\u0645\u0645\u0627\u0631\u0633\u0627\u062a\u060c \u0648\u0644\u0643\u0646 \u0625\u0630\u0627 \u0643\u0646\u062a \u0628\u062d\u0627\u062c\u0629 \u0625\u0644\u0649 \u062a\u063a\u064a\u064a\u0631 \u0627\u0644\u0642\u0648\u0627\u0639\u062f \u0628\u0623\u064a \u0634\u0643\u0644 \u0645\u0646 \u0627\u0644\u0623\u0634\u0643\u0627\u0644\u060c \u064a\u0645\u0643\u0646\u0643 \u0627\u0644\u0642\u064a\u0627\u0645 \u0628\u0630\u0644\u0643 \u0639\u0646 \u0637\u0631\u064a\u0642 \u062a\u0648\u0633\u064a\u0639 \u0642\u0648\u0627\u0639\u062f eslint \u0627\u0644\u0627\u0641\u062a\u0631\u0627\u0636\u064a\u0629. \u0644\u0644\u0642\u064a\u0627\u0645 \u0628\u0630\u0644\u0643\u060c \u0623\u0646\u0634\u0626 \u0645\u0644\u0641\u064b\u0627 \u0641\u064a \u062f\u0644\u064a\u0644 \u0645\u0634\u0631\u0648\u0639\u0643 \u0628\u0627\u0633\u0645 .eslintrc \u0644\u062a\u0648\u0633\u064a\u0639 \u0642\u0648\u0627\u0639\u062f \u0627\u0644\u0646\u0645\u0637:<\/p>\n<div class=\"hcb_wrap\" data-no-translation=\"\" data-no-auto-translation=\"\">\n<pre class=\"prism line-numbers lang-plain\" data-lang=\"Plain Text\"><code>---\r\nextends:\r\n- '.\/node_modules\/gts'<\/code><\/pre>\n<\/div>\n<p>\u064a\u062a\u064a\u062d \u0644\u0643 \u0647\u0630\u0627 \u0625\u0636\u0627\u0641\u0629 \u0623\u0648 \u062a\u0639\u062f\u064a\u0644 \u0642\u0648\u0627\u0639\u062f \u0627\u0644\u0623\u0633\u0644\u0648\u0628 \u0627\u0644\u062a\u064a \u064a\u0648\u0641\u0631\u0647\u0627 GTS.<\/p>\n<h2 id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\">\u0646\u062a\u064a\u062c\u0629<\/h2>\n<p>\u0641\u064a \u0647\u0630\u0627 \u0627\u0644\u0628\u0631\u0646\u0627\u0645\u062c \u0627\u0644\u062a\u0639\u0644\u064a\u0645\u064a\u060c \u0628\u062f\u0623\u062a\u064e \u0645\u0634\u0631\u0648\u0639 TypeScript \u0628\u0625\u0639\u062f\u0627\u062f\u0627\u062a \u0645\u062e\u0635\u0635\u0629. \u0643\u0645\u0627 \u062f\u0645\u062c\u062a\u064e \u0646\u0645\u0637 Google TypeScript \u0641\u064a \u0645\u0634\u0631\u0648\u0639 TypeScript \u0627\u0644\u062e\u0627\u0635 \u0628\u0643. \u064a\u0633\u0627\u0639\u062f\u0643 \u0627\u0633\u062a\u062e\u062f\u0627\u0645 GTS \u0639\u0644\u0649 \u0628\u062f\u0621 \u0645\u0634\u0631\u0648\u0639 TypeScript \u062c\u062f\u064a\u062f \u0628\u0633\u0631\u0639\u0629. \u0645\u0639 GTS\u060c \u0644\u0646 \u062a\u062d\u062a\u0627\u062c \u0625\u0644\u0649 \u0625\u0639\u062f\u0627\u062f \u0627\u0644\u0625\u0639\u062f\u0627\u062f\u0627\u062a \u064a\u062f\u0648\u064a\u064b\u0627 \u0623\u0648 \u062f\u0645\u062c \u0645\u064f\u062d\u0644\u0644 \u0644\u063a\u0648\u064a (linter) \u0641\u064a \u0633\u064a\u0631 \u0639\u0645\u0644\u0643.<\/p>","protected":false},"excerpt":{"rendered":"\u0645\u0642\u062f\u0645\u0629 \u0631\u0628\u0645\u0627 \u062a\u0643\u0648\u0646 \u0642\u062f \u0639\u0645\u0644\u062a \u0628\u0627\u0644\u0641\u0639\u0644 \u0645\u0639 TypeScript \u0639\u0646\u062f \u0627\u0633\u062a\u062e\u062f\u0627\u0645 \u0645\u0634\u0631\u0648\u0639 \u0645\u0628\u062a\u062f\u0626 \u0623\u0648 \u0623\u062f\u0627\u0629 \u0645\u062b\u0644 Angular CLI.","protected":false},"author":1,"featured_media":15191,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_yoast_wpseo_focuskw":"","_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,363],"tags":[416,366],"class_list":{"0":"post-15190","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-tutorials","8":"category-programming","9":"tag-typescript","10":"tag-366"},"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.3 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 TypeScript \u062c\u062f\u06cc\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645 - \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\/ar\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/\" \/>\n<meta property=\"og:locale\" content=\"ar_AR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 TypeScript \u062c\u062f\u06cc\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645 - \u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"og:description\" content=\"\u0645\u0642\u062f\u0645\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0642\u0628\u0644\u0627\u064b \u0647\u0646\u06af\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u0634\u0631\u0648\u0639 \u06cc\u0627 \u0627\u0628\u0632\u0627\u0631\u06cc \u0645\u0627\u0646\u0646\u062f Angular CLI \u0628\u0627 TypeScript \u06a9\u0627\u0631&hellip;\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.itpiran.net\/blog\/ar\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/\" \/>\n<meta property=\"og:site_name\" content=\"\u0628\u0644\u0627\u06af ITPiran\" \/>\n<meta property=\"article:published_time\" content=\"2024-04-01T13:38:49+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.itpiran.net\/2024\/04\/01170716\/Type-Script.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=\"\u0643\u064f\u062a\u0628 \u0628\u0648\u0627\u0633\u0637\u0629\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u0648\u0642\u062a \u0627\u0644\u0642\u0631\u0627\u0621\u0629 \u0627\u0644\u0645\u064f\u0642\u062f\u0651\u0631\" \/>\n\t<meta name=\"twitter:data2\" content=\"\u062f\u0642\u064a\u0642\u0629 \u0648\u0627\u062d\u062f\u0629\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/\"},\"author\":{\"name\":\"admin\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#\\\/schema\\\/person\\\/04ed27b919baca468a2273f8e4318f81\"},\"headline\":\"\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 TypeScript \u062c\u062f\u06cc\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645\",\"datePublished\":\"2024-04-01T13:38:49+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/\"},\"wordCount\":108,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/04\\\/01170716\\\/Type-Script.jpg\",\"keywords\":[\"typeScript\",\"\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc\"],\"articleSection\":[\"\u0622\u0645\u0648\u0632\u0634\u06cc\",\"\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc\"],\"inLanguage\":\"ar\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/\",\"url\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/\",\"name\":\"\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 TypeScript \u062c\u062f\u06cc\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645 - \u0628\u0644\u0627\u06af ITPiran\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/#primaryimage\"},\"thumbnailUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/04\\\/01170716\\\/Type-Script.jpg\",\"datePublished\":\"2024-04-01T13:38:49+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/#breadcrumb\"},\"inLanguage\":\"ar\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"ar\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/#primaryimage\",\"url\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/04\\\/01170716\\\/Type-Script.jpg\",\"contentUrl\":\"https:\\\/\\\/cdn.itpiran.net\\\/2024\\\/04\\\/01170716\\\/Type-Script.jpg\",\"width\":1793,\"height\":1110},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.itpiran.net\\\/blog\\\/tutorials\\\/typescript-new-projectstep-1-starting-the-typescript-project\\\/#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\":\"\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 TypeScript \u062c\u062f\u06cc\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645\"}]},{\"@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\":\"ar\"},{\"@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\":\"ar\",\"@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\\\/ar\\\/author\\\/admin\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"\u0643\u064a\u0641\u064a\u0629 \u0628\u062f\u0621 \u0645\u0634\u0631\u0648\u0639 TypeScript \u062c\u062f\u064a\u062f - \u0645\u062f\u0648\u0646\u0629 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\/ar\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/","og_locale":"ar_AR","og_type":"article","og_title":"\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 TypeScript \u062c\u062f\u06cc\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645 - \u0628\u0644\u0627\u06af ITPiran","og_description":"\u0645\u0642\u062f\u0645\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0642\u0628\u0644\u0627\u064b \u0647\u0646\u06af\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u0634\u0631\u0648\u0639 \u06cc\u0627 \u0627\u0628\u0632\u0627\u0631\u06cc \u0645\u0627\u0646\u0646\u062f Angular CLI \u0628\u0627 TypeScript \u06a9\u0627\u0631&hellip;","og_url":"https:\/\/www.itpiran.net\/blog\/ar\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/","og_site_name":"\u0628\u0644\u0627\u06af ITPiran","article_published_time":"2024-04-01T13:38:49+00:00","og_image":[{"width":1793,"height":1110,"url":"https:\/\/cdn.itpiran.net\/2024\/04\/01170716\/Type-Script.jpg","type":"image\/jpeg"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u0643\u064f\u062a\u0628 \u0628\u0648\u0627\u0633\u0637\u0629":"admin","\u0648\u0642\u062a \u0627\u0644\u0642\u0631\u0627\u0621\u0629 \u0627\u0644\u0645\u064f\u0642\u062f\u0651\u0631":"\u062f\u0642\u064a\u0642\u0629 \u0648\u0627\u062d\u062f\u0629"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/#article","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/"},"author":{"name":"admin","@id":"https:\/\/www.itpiran.net\/blog\/#\/schema\/person\/04ed27b919baca468a2273f8e4318f81"},"headline":"\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 TypeScript \u062c\u062f\u06cc\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645","datePublished":"2024-04-01T13:38:49+00:00","mainEntityOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/"},"wordCount":108,"commentCount":0,"publisher":{"@id":"https:\/\/www.itpiran.net\/blog\/#organization"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/04\/01170716\/Type-Script.jpg","keywords":["typeScript","\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc"],"articleSection":["\u0622\u0645\u0648\u0632\u0634\u06cc","\u0628\u0631\u0646\u0627\u0645\u0647 \u0646\u0648\u06cc\u0633\u06cc"],"inLanguage":"ar","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/","url":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/","name":"\u0643\u064a\u0641\u064a\u0629 \u0628\u062f\u0621 \u0645\u0634\u0631\u0648\u0639 TypeScript \u062c\u062f\u064a\u062f - \u0645\u062f\u0648\u0646\u0629 ITPiran","isPartOf":{"@id":"https:\/\/www.itpiran.net\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/#primaryimage"},"image":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/#primaryimage"},"thumbnailUrl":"https:\/\/cdn.itpiran.net\/2024\/04\/01170716\/Type-Script.jpg","datePublished":"2024-04-01T13:38:49+00:00","breadcrumb":{"@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/#breadcrumb"},"inLanguage":"ar","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/"]}]},{"@type":"ImageObject","inLanguage":"ar","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/#primaryimage","url":"https:\/\/cdn.itpiran.net\/2024\/04\/01170716\/Type-Script.jpg","contentUrl":"https:\/\/cdn.itpiran.net\/2024\/04\/01170716\/Type-Script.jpg","width":1793,"height":1110},{"@type":"BreadcrumbList","@id":"https:\/\/www.itpiran.net\/blog\/tutorials\/typescript-new-projectstep-1-starting-the-typescript-project\/#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":"\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 TypeScript \u062c\u062f\u06cc\u062f \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u06a9\u0646\u06cc\u0645"}]},{"@type":"WebSite","@id":"https:\/\/www.itpiran.net\/blog\/#website","url":"https:\/\/www.itpiran.net\/blog\/","name":"\u0645\u062f\u0648\u0646\u0629 ITPiran","description":"\u0623\u062e\u0628\u0627\u0631 \u0648\u0645\u0642\u0627\u0644\u0627\u062a \u0639\u0646 \u0627\u0644\u062a\u062c\u0627\u0631\u0629 \u0627\u0644\u0645\u0633\u062a\u062f\u0627\u0645\u0629 \u0627\u0644\u0625\u064a\u0631\u0627\u0646\u064a\u0629","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":"ar"},{"@type":"Organization","@id":"https:\/\/www.itpiran.net\/blog\/#organization","name":"\u0645\u062f\u0648\u0646\u0629 \u0627\u0644\u0623\u0639\u0645\u0627\u0644 \u0627\u0644\u0625\u064a\u0631\u0627\u0646\u064a\u0629 \u0627\u0644\u0645\u0633\u062a\u062f\u0627\u0645\u0629","alternateName":"ITPIran Blog","url":"https:\/\/www.itpiran.net\/blog\/","logo":{"@type":"ImageObject","inLanguage":"ar","@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":"\u0645\u0633\u0624\u0644","url":"https:\/\/www.itpiran.net\/blog\/ar\/author\/admin\/"}]}},"_links":{"self":[{"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/posts\/15190","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/comments?post=15190"}],"version-history":[{"count":1,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/posts\/15190\/revisions"}],"predecessor-version":[{"id":15192,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/posts\/15190\/revisions\/15192"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/media\/15191"}],"wp:attachment":[{"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/media?parent=15190"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/categories?post=15190"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.itpiran.net\/blog\/ar\/wp-json\/wp\/v2\/tags?post=15190"}],"curies":[{"name":"\u0648\u0648\u0631\u062f\u0628\u0631\u064a\u0633","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}