-
-
Notifications
You must be signed in to change notification settings - Fork 1.4k
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
base: master
Are you sure you want to change the base?
Changes from 5 commits
f16922a
bc1bf08
1c7d064
9d8ca94
fc272ef
235cbc9
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -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 | ||
`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'; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. You are describing a workaround which requires creating 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', | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Wouldn't this be: There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @plooney81 As per @1cg comment here: #2668 (comment) In other words |
||
}), | ||
], | ||
}) | ||
``` | ||
|
||
* Finally, rebuild your bundle | ||
Finally, rebuild your bundle. | ||
|
||
## AJAX | ||
|
||
|
There was a problem hiding this comment.
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?