2.1.0 • Published 6 months ago

node-loader v2.1.0

Weekly downloads
101,899
License
MIT
Repository
github
Last release
6 months ago

npm node tests coverage discussion size

node-loader

A Node.js add-ons loader.

Allows to connect native node modules with .node extension.

node-loader only works on the node/async-node/electron-main/electron-renderer/electron-preload targets.

Getting Started

To begin, you'll need to install node-loader:

npm install node-loader --save-dev

or

yarn add -D node-loader

or

pnpm add -D node-loader

Setup the target option to node/async-node/electron-main/electron-renderer/electron-preload value and do not mock the __dirname global variable.

webpack.config.js

module.exports = {
  resolve: {
    extensions: ["...", ".node"],
  },
  target: "node",
  node: {
    __dirname: false,
  },
  module: {
    rules: [
      {
        test: /\.node$/,
        loader: "node-loader",
      },
    ],
  },
};

Inline

index.js

import node from "node-loader!./file.node";

And run webpack via your preferred method.

Configuration

index.js

import node from "file.node";

Then add the loader to your webpack config. For example:

webpack.config.js

module.exports = {
  target: "node",
  node: {
    __dirname: false,
  },
  module: {
    rules: [
      {
        test: /\.node$/,
        loader: "node-loader",
      },
    ],
  },
};

And run webpack via your preferred method.

Options

NameTypeDefaultDescription
flags{Number}undefinedEnables/Disables url/image-set functions handling
name{String\|Function}'[contenthash].[ext]'Specifies a custom filename template for the target file(s).

flags

Type: Number Default: undefined

The flags argument is an integer that allows to specify dlopen behavior. See the process.dlopen documentation for details.

index.js

import node from "file.node";

webpack.config.js

const os = require("os");

module.exports = {
  target: "node",
  node: {
    __dirname: false,
  },
  module: {
    rules: [
      {
        test: /\.node$/,
        loader: "node-loader",
        options: {
          flags: os.constants.dlopen.RTLD_NOW,
        },
      },
    ],
  },
};

name

Type: String|Function Default: '[contenthash].[ext]'

Specifies a custom filename template for the target file(s).

String

webpack.config.js

module.exports = {
  target: "node",
  node: {
    __dirname: false,
  },
  module: {
    rules: [
      {
        test: /\.node$/,
        loader: "node-loader",
        options: {
          name: "[path][name].[ext]",
        },
      },
    ],
  },
};

Function

webpack.config.js

module.exports = {
  target: "node",
  node: {
    __dirname: false,
  },
  module: {
    rules: [
      {
        test: /\.node$/,
        loader: "node-loader",
        options: {
          name(resourcePath, resourceQuery) {
            // `resourcePath` - `/absolute/path/to/file.js`
            // `resourceQuery` - `?foo=bar`

            if (process.env.NODE_ENV === "development") {
              return "[path][name].[ext]";
            }

            return "[contenthash].[ext]";
          },
        },
      },
    ],
  },
};

Contributing

Please take a moment to read our contributing guidelines if you haven't yet done so.

CONTRIBUTING

License

MIT

@boris47/electron-webpackbetter-electron-webpackmagic-home-scaffold@aethernet/electron-webpack@infinitebrahmanuniverse/nolb-node-l@everything-registry/sub-chunk-2305ct_baseuiwisdom-vuexea-cli-view-servicevite-plugin-native@pravdomil/blocksjsvh-cs-frontend-only-jsjavascriptgraphicalmanipulatorkevm-ganache-clivue-toast-demo-dongdongspectiql@anyversion/elecpack@atls/code-runtime@atls/code-service@albertli90/react-electron-scripts@bazumax/quasar-app@01/core-utils@a1motion/electron-kit@horoshop/app@delewis13/electron-webpack@darwishdev/dash-devyach.clivue-toast-liwebpack-test-demo1webnoob-q-appwebpack-cli-utilwebpack-clis-utils@fay-react/tool@heat/awsless@ekz/packer@eventbrite/brite-core@kui-shell/webpack@kythuen/webpack-builder@langtrase/typescript-sdk@loopmode/electron-webpack@intlayer/webpack@intlayer/chokidar@ludum_studios/brix-navigation@ludum_studios/brix-physics@micro-app/plugin-webpack@moviecast/electron-webpack@mongodb-js/webpack-config-compass@monospaces/electron-webpack@monstrs/tools-runtime@monstrs/code-runtime@joelwat/quasar-app@keystore/react-tool@keystore/tool@junvary/quasar-ui-qcascader@keadex/docusaurus-plugin-mina@r3m0t/vscode-python@rws-framework/server@sa-frontend/bundling@quasar/app-webpack@quasar/app@richlox/core@paulwib/electron-webpack@not-govuk/webpack-config@nuggxyz/dotnugg-sdk@o2ter/react-booster@skysong/mc-cli@rockpack/compilermurniturmirage_toolkitmyquasarv1appp2h4knuxtjs-electronpairsyncrudonguirocket-starterrosbag_nextrws-js-serverreact-electron-chunkyquasar-clinext-intlayerreact-scripts-intlayerskypager-webpackskypager-frameworkgoblin-webpackgulp-assistanthome-portal-services-1hx-wallet-desktoplentil-macos-additionslentil-os-additionskirbo-electron-webpackeasy-create-sharkeh-dockerelectron-webpackelectron-webpack-releaseelectron-webpack-v2elan-clielecpackexplorer-uifavacli@theia/application-manager
2.1.0

6 months ago

2.0.0

4 years ago

1.0.3

4 years ago

1.0.2

5 years ago

1.0.1

5 years ago

1.0.0

5 years ago

0.6.0

9 years ago

0.5.0

12 years ago