Форум программистов, компьютерный форум, киберфорум
Наши страницы

TypeScript

Войти
Регистрация
Восстановить пароль
 
sau
1676 / 1479 / 147
Регистрация: 22.07.2011
Сообщений: 5,602
Завершенные тесты: 1
#1

Пространства имен в TypeScript - TypeScript

19.03.2018, 18:43. Просмотров 196. Ответов 1
Метки нет (Все метки)

П.С Интересно , глядя на исходники ангуляр 2 , нет ни одного обьявления пространства имен , все именования классов по дедовскому способу - NameSubNameSubSubName.
Ну да ладно , речь не о том.

Допустим пишу экспортируемый модуль , модуль большой с кучей классов , которые бы хотелось раскидать по пространствам для лучшей организации кода , благо TypeScript позволяет обьявить namespace.
Но есть проблемка , допустим имеем определения:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//Model.ts
namespace MyApp.Data.Model
{
     export class ModelA  {}
     export class ModelB  {}
}
 
//Services.ts
//import { http } from "@angular/core"
namespace MyApp.Data.Services
{
     export class ServiceA {}
     export class ServiceB  
    {
          private modelA:MyApp.Data.Model.ModelA; //не видит в случае определения import-а
    }
}
все хорошо , все компилируются , но как только пытаюсь импортировать какой либо внешний модуль (например import { http } from "@angular/core") , так сразу компилятор TS перестает видеть ссылку на MyApp.Data.Model.ModelA в Services.ts. и ругается "TS пространство имен MyApp.Data не содержит экспортированный элемент Model". (какой нафиг элемент , если это часть имени namespace)

Опытным путем выяснилось , что если , например , объявленные пространства имен ни в какой части своего имени не совпадают , то все хорошо , ниже рабочий пример:


C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//Model.ts
namespace Model //убрали MyApp.Data , что бы разрешить конфликт.
{
     export class ModelA  {}
     export class ModelB  {}
}
 
//Services.ts
import { http } from "@angular/core"
namespace MyApp.Data.Services
{
     export class ServiceA {}
     export class ServiceB  
    {
          private modelA:Model.ModelA; //теперь все хорошо.
    }
}

Собственно вопрос , это либо typescript баг , либо такая странная особенность - но тогда причем тут import , почему без определения импорта все ок.

Добавлено через 2 часа 5 минут
В общем , разработчики typescript посчитали , что в режиме работы с модулями , использовать пространства имен - лишнее и вместе оно должным образом не работает.
http://www.typescriptlang.org/docs/h...d-modules.html
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.03.2018, 18:43
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Пространства имен в TypeScript (TypeScript):

Сохранение this в TypeScript - TypeScript
Доброго дня. Подскажите пожалуйста, как можно сохранить this класса так, чтобы можно было пользоваться им в функции любой глубины в этом...

Перевод C# на TypeScript - TypeScript
Доброго времени суток))) (Извините если не в ту тему) Существует рабочая программы для локального пользования(C# WinForm). Делаю Web...

Импорт функций в TypeScript - TypeScript
Добрый день, разбираюсь с TypeScript, и упералсь в стену непонимания почему не импортится файл. Вот есть у меня два файла // файл...

Разбиение скомилированного Typescript на файлы - TypeScript
В проекте имеется множество typescript файлов, которые компилируются в один js. Но часть скриптов нужна только на конкретных страницах, а...

Flow+Babel или TypeScript? - TypeScript
Добрый день. Поделитесь, пожалуйста, опытом при разработке веб-приложений на React с использованием средств для статической типизации. ...

Ошибка компиляции TypeScript+React - TypeScript
Здравствуйте. Хочу заставить работать вместе TypeScript и React в середе Visual Studio Code. Сам ТС стоит, реакт в папке с проектом....

1
senyaarseniy
30 / 30 / 6
Регистрация: 30.11.2013
Сообщений: 119
18.04.2018, 16:15 #2
Javascript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
export namespace MyApp.Data.Model
{
     export class ModelA  {}
     export class ModelB  {}
}
 
// Services.ts
import {  } from "@angular/core"
import * as modela from "./modela";
namespace MyApp.Data.Services
{
     export class ServiceA {}
     export class ServiceB
    {
          private modelA:modela.MyApp.Data.Model.ModelA; //не видит в случае определения import-а
    }
}
В тот момент когда ты используеш import - typescript перестаёт видить не импортированые файлы
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.04.2018, 16:15
Привет! Вот еще темы с ответами:

Использование Typescript и Google maps API - TypeScript
Привет! Более подходящей темы на форуме не нашел, если промазал, перенесите. пожалуйста. По теме. Делаю функционал по работе с...

Не понятен пример кода из спецификации TypeScript - TypeScript
Читаю про объектные типы в спецификации на странцие 13, но не понятно из описания как устроен и ведёт себя следующий пример кода: var f:...

Visual Studio Конвертация TypeScript в JavaScripts - TypeScript
Здравствуйте, не получается настроить конвертацию *.ts файлов в *.js которые бы я смог подключить на веб странице.

Senior Frontend в Cian.ru (React.js и TypeScript) - TypeScript
Привет, Сеньор Фронтенд! Зовем тебя делать продукт, которым пользуется каждый второй твой знакомый человек и, вероятно, ты сам - Циан....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru