我如何在TypeScript中声明一个模块的变量?

编程入门 行业动态 更新时间:2024-10-04 19:21:48

我如何在TypeScript中声明一个模块的<a href=https://www.elefans.com/category/jswz/34/1771380.html style=变量?"/>

我如何在TypeScript中声明一个模块的变量?

我有两个文件。index.tsA.ts

A.ts:

export default class {
    do() {
        console.log(someVar);
    }
}

index.ts:

import A from './A';

function printIt(param) {
    let someVar = param;
    let a = new A();
    a.do();
}

printIt('wow'); // Console output: wow
printIt('123'); // Console output: 123

* 申报是真的吗?someVar 对于 A.tsindex.ts 不包 A 类?

我知道Node.JS将所有模块封装在 (function (exports, require, module, __filename, __dirname, process, global) { }: 如何改变Node.js模块的包装器?

我试着做一个自定义的require函数,并把我的var作为参数传递。但我不明白如何才能在TypScript中建立自己的require函数。有什么好办法吗?

回答如下:

变量的作用域取决于它们被定义的位置,而不是它们被调用的位置。这是故意的,所以你不会意外地调用你不知道与你的函数调用在同一作用域内的变量。

你必须明确地告诉代码你想把这个新变量传入它,就像Lux展示的那样,或者通过像这样把它传给函数。

export default class {
     do(someVar) {
         console.log(someVar);
     }
}
function printIt(param) {
   let someVar = param;
   let a = new A();
   a.do(someVar);
}

你试图做的事情就像让所有的东西都成为一个全局变量一样.如果你必须这样做(你不应该这样做),有一种方法你可以。

export default class {
     do() {
         console.log(global.someVar);
     }
}
function printIt(param) {
   global.someVar = param;
   let a = new A();
   a.do();
}

你不想做全局变量的原因有很多。此处 是一些

澄清后编辑。

模块中的 "this "关键字指的是模块的全局范围,所以我试了下面的片段。

// modA.js
const moduleContext = this

class ExportedClass {
    printer() {
        console.log(moduleContext.someVar)
    }
}

module.exports = { ExportedClass }


//modB.js
let A = require("./modA")

A.someVar = "hello world"

let obj = new A.ExportedClass()

obj.printer()

更多推荐

我如何在TypeScript中声明一个模块的变量?

本文发布于:2024-05-13 12:28:45,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1759537.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:变量   模块   声明   如何在   TypeScript

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!