# \[WEBPACK] Webpack import jQuery - Materialize

## Webpack từ A đến Á: Webpack import jQuery - Materialize

[CSS](https://viblo.asia/tags/css)[HTML](https://viblo.asia/tags/html)[JavaScript](https://viblo.asia/tags/javascript)[Webpack](https://viblo.asia/tags/webpack)

![Webpack từ A đến Á cùng kentrung](https://images.viblo.asia/2090b88e-6ec0-49fe-b677-65e927fafc2e.png)

Bài [trước](https://viblo.asia/p/webpack-tu-a-den-a-webpack-load-jquery-XL6lA94rlek) chúng ta đã biết cách load jQuery vào trong webpack. Bài hôm nay sẽ tiếp tục học cách load thêm thư viện và ví dụ ở đây là [Materialize](https://materializecss.com/) bản 1.0.0 nhé.

### 1. Chuẩn bị file <a href="#id-1-chuan-bi-file-0" id="id-1-chuan-bi-file-0"></a>

Code file `webpack.config.js` ban đầu:

```
const path = require('path')

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'main.js',
    path: path.resolve(__dirname, 'dist')
  }
}
```

Code file `dist/index.html`

```
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Webpack từ A đến Á cùng kentrung</title>
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/css/materialize.min.css">
</head>
<body>
  <div class="container">
    <div class="carousel">
      <a class="carousel-item" href="#one!">
          <img src="https://lorempixel.com/250/250/nature/1">
      </a>
      <a class="carousel-item" href="#two!">
          <img src="https://lorempixel.com/250/250/nature/2">
      </a>
      <a class="carousel-item" href="#three!">
          <img src="https://lorempixel.com/250/250/nature/3">
      </a>
      <a class="carousel-item" href="#four!">
          <img src="https://lorempixel.com/250/250/nature/4">
      </a>
      <a class="carousel-item" href="#five!">
          <img src="https://lorempixel.com/250/250/nature/5">
      </a>
    </div>
  </div>
  <script src="main.js"></script>
</body>
</html>
```

Trang html này mình định tạo **Carousel** của Materialize, vì mình chưa học cách load css vào trong webpack nên tạm thời mình load sẵn css vào trong html chỗ này.

```
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/materialize/1.0.0/css/materialize.min.css">
```

Code file `src/index.js`

```
$(document).ready(function(){
  $('.carousel').carousel()
})
```

Đoạn code trên có tác dụng tự động chạy carousel. Chạy thử webpack ta có giao diện trắng tinh và log như sau:

```
Uncaught ReferenceError: $ is not defined at (main.js:1)
```

### 2. Load jQuery <a href="#id-2-load-jquery-1" id="id-2-load-jquery-1"></a>

Bài [trước](https://viblo.asia/p/webpack-tu-a-den-a-webpack-load-jquery-XL6lA94rlek) đã hướng dẫn cách load jQuery rồi nhưng thôi bài này hướng dẫn lại từ đầu cho dễ theo dõi. Trước tiên mình phải cài đặt jQuery qua npm

```
npm install jquery
```

Sau khi tải xong jQuery tiếp theo ta sửa lại `webpack.config.js` để load jQuery thông qua provide plugin của webpack

```
const path = require('path')
const webpack = require('webpack')

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'main.js',
    path: path.resolve(__dirname, 'dist')
  },
  plugins: [
    new webpack.ProvidePlugin({
      $: 'jquery',
      jQuery: 'jquery'
    })
  ]
}
```

Vậy là chúng ta đã giải quyết xong vấn đề load jQuery để hiểu được các kí tự `$` trong code `src/index.js`. Chạy thử webpack và chúng ta có log lỗi như sau:

```
Uncaught TypeError: e(...).carousel is not a function at (main.js:1)
```

Cái này là do chúng ta chưa load Materialize Javascript, hàm `carousel` là của Materialize chứ không phải của jQuery nên nó không hiểu là đúng rồi.

### 3. Load Materialize <a href="#id-3-load-materialize-2" id="id-3-load-materialize-2"></a>

Tải Materialize qua npm

```
npm install materialize-css@next
```

Bước tiếp theo là chúng ta load Materialize Javascript vào trong file `src/index.js`

```
import 'materialize-css'

$(document).ready(function(){
  $('.carousel').carousel()
})
```

Câu lệnh import kia nó sẽ tự động tìm trong node-modules rồi đến materialize-css. Trong module này file package.json có khai báo

```
"main": "dist/js/materialize.js"
```

nên câu lệnh import ở trên chỉ là viết tắt của:

```
import 'materialize-css/dist/js/materialize.js'
```

Chạy lại webpack `npm run dev` và kết quả là ...vẫn không chạy được, vẫn lỗi như cũ

```
Uncaught TypeError: e(...).carousel is not a function at (main.js:1)
```

Mất khá nhiều thời gian search trên mạng, tốn bao nhiêu nơ ron thần kinh để suy nghĩ tại sao lại vậy. Cuối cùng mình cũng tìm được ra cách fix lỗi nhưng cũng chưa biết giải thích rõ lí do tại sao, các bạn pro có thể comment giải thích giúp mình nhé. Ta sửa lại file `webpack.config.js` và thêm giá trị cho các key jQuery

```
const path = require('path')
const webpack = require('webpack')

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'main.js',
    path: path.resolve(__dirname, 'dist')
  },
  plugins: [
    new webpack.ProvidePlugin({
      $: 'jquery',
      jQuery: 'jquery',
      'window.$': 'jquery',
      'window.jQuery': 'jquery'
    })
  ]
}
```

Chạy lại webpack `npm run dev` và kết quả là **NGON!**

![Webpack từ A đến Á cùng kentrung](https://images.viblo.asia/866afcc5-e8ce-41f0-aff5-85651f87d444.gif)

Bài viết đến đây là hết, hi vọng với bài viết này các bạn đã thêm được nhiều kiến thức bổ ích. Hẹn gặp lại các bạn ở bài viết tiếp theo!

* Tham khảo cách cài Materialize tại: <https://materializecss.com/>
* Source code github: <https://github.com/kentrung/webpack-tutorial>
* Series webpack: <https://viblo.asia/s/webpack-tu-a-den-a-cung-kentrung-pmleB8Am5rd>
