Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update webpack and Vite istallation instructions for htmx 2.0 #2668

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
71 changes: 57 additions & 14 deletions www/content/docs.md
Original file line number Diff line number Diff line change
Expand Up @@ -152,36 +152,79 @@ For npm-style build systems, you can install htmx via [npm](https://www.npmjs.co
npm install [email protected]
```

After installing, you’ll need to use appropriate tooling to use `node_modules/htmx.org/dist/htmx.js` (or `.min.js`).
For example, you might bundle htmx with some extensions and project-specific code.
After installing, you’ll need to use appropriate tooling to use `node_modules/htmx.org/dist/htmx[.esm, .cjs, .amd].js` (or `.min.js`).

### Webpack
In the simplest case all you need to do is to add this import to your entry point (like `index.js`)
```js
import 'htmx.org';
```

However, you will probably need the global `htmx` variable, which gives your code access to methods like

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If I may offer a suggestion:

The use of "probably" is unclear to beginners; You give a very concrete example right after (the use of htmx plugins), but is this the only scenario?

`htmx.onLoad` and allow you to use npm-installed htmx plugins. You can use one of the solutions following solutions
restless marked this conversation as resolved.
Show resolved Hide resolved
to achieve this.

If you are using webpack to manage your javascript:

* Install `htmx` via your favourite package manager (like npm or yarn)
* Add the import to your `index.js`
#### Global variable

Create a local `htmx.js` with the following content:

```js
import 'htmx.org';
import htmx from "htmx.org";
window.htmx = htmx;
```

If you want to use the global `htmx` variable (recommended), you need to inject it to the window scope:
Import this file in your entry point (like `index.js`):

```js
import './htmx.js';

// now you can import extensions
import 'htmx-ext-debug/debug.js';
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You are describing a workaround which requires creating htmx.js file to inject htmx into the window scope, so that the extensions can use it. It has to be done in a separate file, because ESM imports are asynchronous.

I have created a PR in the extensions repository, which eliminates the need of this workaround. With the new change extensions can be imported like this:

import `htmx.org`;
import `htmx-ext-extension-name`; // Replace `extension-name` with the extension name

It relies on the ESM import mechanism supported by most bundlers, including Webpack, Vite and Rollup.

// and use htmx methods
htmx.onLoad((content) => {
console.log('Hello')
});
```

#### Webpack

* Create a custom JS file
* Import this file to your `index.js` (below the import from step 2)
If you are using [webpack](https://webpack.js.org) to manage your javascript, the better option is
to add the following to your `webpack.config.js`

```js
import 'path/to/my_custom.js';
import webpack from 'webpack';

/** @type {import("webpack").Configuration} */
export default {
entry: './src/index.js',
//[...]
plugins: [
new webpack.ProvidePlugin({
htmx: 'htmx.org',
}),
],
};
```

* Then add this code to the file:
#### Vite

If you are using [Vite](https://vitejs.dev) to manage your javascript, the better option is
to add the following to your [vite.config.js](https://vitejs.dev/guide/backend-integration.html):

```js
window.htmx = require('htmx.org');
import inject from '@rollup/plugin-inject';

export default defineConfig({
build: {...},
plugins: [
inject({
htmx: 'htmx.org',

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Wouldn't this be: 'htmx.org/dist/htmx.esm'?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@plooney81 As per @1cg comment here: #2668 (comment) htmx.org uses htmx.esm.js by default now.
Please see: https://github.com/bigskysoftware/htmx/blob/master/package.json#L23C3-L23C30

In other words htmx.org should work (and works for me) well.

}),
],
})
```

* Finally, rebuild your bundle
Finally, rebuild your bundle.

## AJAX

Expand Down