javascript - ImportRequire nodejs modules without @types in Typescript in 2018 - Stack Overflow

admin2025-04-03  1

I have a typescript nodejs project for a website. I need to use functionality that is available in this specific nodejs module:

This module does not have a .d.ts file available in its repository, nor is there one available in the '@types' typescript repository. I do not require type definitions for this module, but typescript does not include it and produces errors.

No matter which way I try to import, I either get

TS2304: Cannot find name 'require'.

in the build console, or

TypeError: qs.escape is not a function

in the browser dev console.

Many responses here on StackOverflow suggest solutions that require repositories that are no longer available in 2018, or that might work but for me still produce the error

TypeError: qs.escape is not a function

What is the correct way to use/import/require/consume nodejs module functionality (without .d.ts definitions available) in typescript in 2018?

I have a typescript nodejs project for a website. I need to use functionality that is available in this specific nodejs module: https://www.npmjs./package/weather-js

This module does not have a .d.ts file available in its repository, nor is there one available in the '@types' typescript repository. I do not require type definitions for this module, but typescript does not include it and produces errors.

No matter which way I try to import, I either get

TS2304: Cannot find name 'require'.

in the build console, or

TypeError: qs.escape is not a function

in the browser dev console.

Many responses here on StackOverflow suggest solutions that require repositories that are no longer available in 2018, or that might work but for me still produce the error

TypeError: qs.escape is not a function

What is the correct way to use/import/require/consume nodejs module functionality (without .d.ts definitions available) in typescript in 2018?

Share Improve this question asked Jan 12, 2018 at 10:59 MarvosMarvos 2772 gold badges3 silver badges11 bronze badges
Add a ment  | 

1 Answer 1

Reset to default 11

You can add a dummy definition to allow it to import but without actually typing the module contents (although maybe if you should type them fully and submit to DefinitlyTyped so the everyone can benefit from type safety too!)

weather-js.d.ts

// declaring module will allow typescript to import the module
declare module 'weather-js' {
  // typing module default export as `any` will allow you to access its members without piler warning
  var weatherJs: any; 
  export default weatherJs;
}

yourCode.ts

import weather from 'weather-js'

weather.find({search: 'San Francisco, CA', degreeType: 'F'}, () => {})
转载请注明原文地址:http://conceptsofalgorithm.com/Algorithm/1743625439a213769.html

最新回复(0)