Estoy creando una clase en mecanografiado que tiene una propiedad que es un mapa ES6 (ECMAscript 2016) así:
class Item {
configs: ????;
constructor () {
this.configs = new Map();
}
}
¿Cómo declaro un tipo de mapa ES6 en mecanografiado?
Estoy creando una clase en mecanografiado que tiene una propiedad que es un mapa ES6 (ECMAscript 2016) así:
class Item {
configs: ????;
constructor () {
this.configs = new Map();
}
}
¿Cómo declaro un tipo de mapa ES6 en mecanografiado?
Respuestas:
EDITAR (5 de junio de 2019): Si bien la idea de que "TypeScript admite de Map
forma nativa" sigue siendo cierta, ya que la versión 2.1 TypeScript admite algo llamado Record
.
type MyMapLikeType = Record<string, IPerson>;
const peopleA: MyMapLikeType = {
"a": { name: "joe" },
"b": { name: "bart" },
};
Desafortunadamente, el primer parámetro genérico (tipo de clave) todavía no se respeta completamente: incluso con un string
tipo, algo como peopleA[0]
(a number
) sigue siendo válido.
EDITAR (25 de abril de 2016): la respuesta a continuación es antigua y no debe considerarse la mejor respuesta. TypeScript ahora es compatible con Maps "nativamente", por lo que simplemente permite que se utilicen Maps ES6 cuando la salida es ES6. Para ES5, no proporciona polyfills; debes incrustarlos tú mismo.
Para obtener más información, consulte la respuesta de mohamed hegazy a continuación para obtener una respuesta más moderna, o incluso este comentario de reddit para una versión corta.
A partir de la versión 1.5.0 beta, TypeScript aún no es compatible con Maps . Tampoco es parte de la hoja de ruta .
La mejor solución actual es un objeto con clave y valor escritos (a veces llamado hashmap). Para un objeto con claves de tipo string
y valores de tipo number
:
var arr : { [key:string]:number; } = {};
Algunas advertencias, sin embargo:
string
onumber
Con el ejemplo anterior:
// OK:
arr["name"] = 1; // String key is fine
arr[0] = 0; // Number key is fine too
// Not OK:
arr[{ a: "a" }] = 2; // Invalid key
arr[3] = "name"; // Invalid value
map Map<string,string>=new Map<string,string>()
cuando map.set(something)
obtengo una excepción map is undefined
, ¿hay otra forma de inicializarla?
Ver comentario en: https://github.com/Microsoft/TypeScript/issues/3069#issuecomment-99964139
TypeScript no viene con pollyfills incorporados. depende de usted decidir qué pollyfill usar, si lo hay. puede usar algo como es6Collection , es6- shims , corejs ..etc. Todo lo que necesita el compilador de mecanografiado es una declaración para las construcciones ES6 que desea usar. Puedes encontrarlos en este archivo lib .
Aquí está la porción relevante:
interface Map<K, V> { clear(): void; delete(key: K): boolean; entries(): IterableIterator<[K, V]>; forEach(callbackfn: (value: V, index: K, map: Map<K, V>) => void, thisArg?: any): void; get(key: K): V; has(key: K): boolean; keys(): IterableIterator<K>; set(key: K, value?: V): Map<K, V>; size: number; values(): IterableIterator<V>; [Symbol.iterator]():IterableIterator<[K,V]>; [Symbol.toStringTag]: string; } interface MapConstructor { new <K, V>(): Map<K, V>; new <K, V>(iterable: Iterable<[K, V]>): Map<K, V>; prototype: Map<any, any>; } declare var Map: MapConstructor;
Aquí hay un ejemplo:
this.configs = new Map<string, string>();
this.configs.set("key", "value");
TS2304
, por favor verifique esto: stackoverflow.com/questions/39416691/…
Sí Map ahora está disponible en mecanografiado ... si mira en lib.es6.d.ts, verá la interfaz:
interface Map<K, V> {
clear(): void;
delete(key: K): boolean;
forEach(callbackfn: (value: V, key: K, map: Map<K, V>) => void,thisArg?: any): void;
get(key: K): V | undefined;
has(key: K): boolean;
set(key: K, value: V): this;
readonly size: number;}
Es ideal para usar como diccionario de cadenas, pares de objetos ... la única molestia es que si lo está utilizando para asignar valores en otro lugar con Map.get (clave), el IDE como Código le da problemas sobre la posibilidad de ser indefinido ... en lugar de crear una variable con una verificación está definida ... simplemente eche el tipo (suponiendo que sepa con certeza que el mapa tiene el par clave-valor)
class myclass {
mymap:Map<string,object>
...
mymap = new Map<string,object>()
mymap.set("akey",AnObject)
let objectref = <AnObject>mymap.get("akey")
¿Cómo declaro un tipo de mapa ES6 en mecanografiado?
Necesitas apuntar --module es6
. Esto es lamentable y puede plantear su inquietud aquí: https://github.com/Microsoft/TypeScript/issues/2953#issuecomment-98514111
Como mínimo:
tsconfig:
"lib": [
"es2015"
]
e instale un polyfill como https://github.com/zloirock/core-js si desea compatibilidad con IE <11: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects /Mapa
No estoy seguro de si esto es oficial pero funcionó para mí en el mecanografiado 2.7.1:
class Item {
configs: Map<string, string>;
constructor () {
this.configs = new Map();
}
}
En simple Map<keyType, valueType>
Con la opción de configuración de lib, puede seleccionar el mapa en su proyecto. Solo agrégalo es2015.collection
a tu sección de lib. Cuando no tenga lib config, agregue uno con los valores predeterminados y agregue es2015.collection
.
Entonces, cuando tenga target: es5, cambie tsconfig.json a:
"target": "es5",
"lib": [ "dom", "es5", "scripthost", "es2015.collection" ],
Typecript aún no es compatible Map
.