日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
webpack怎么用

這篇文章主要介紹了webpack怎么用,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

創(chuàng)新互聯(lián)是一家網(wǎng)站設(shè)計(jì)公司,集創(chuàng)意、互聯(lián)網(wǎng)應(yīng)用、軟件技術(shù)為一體的創(chuàng)意網(wǎng)站建設(shè)服務(wù)商,主營(yíng)產(chǎn)品:成都響應(yīng)式網(wǎng)站建設(shè)、品牌網(wǎng)站制作、營(yíng)銷型網(wǎng)站。我們專注企業(yè)品牌在網(wǎng)站中的整體樹(shù)立,網(wǎng)絡(luò)互動(dòng)的體驗(yàn),以及在手機(jī)等移動(dòng)端的優(yōu)質(zhì)呈現(xiàn)。網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、移動(dòng)互聯(lián)產(chǎn)品、網(wǎng)絡(luò)運(yùn)營(yíng)、VI設(shè)計(jì)、云產(chǎn)品.運(yùn)維為核心業(yè)務(wù)。為用戶提供一站式解決方案,我們深知市場(chǎng)的競(jìng)爭(zhēng)激烈,認(rèn)真對(duì)待每位客戶,為客戶提供賞析悅目的作品,網(wǎng)站的價(jià)值服務(wù)。

 webpack是基于node的。先安裝最新的node。

1.初始化

安裝node后,新建一個(gè)目錄,比如html5。cmd中切到當(dāng)前文件夾。

npm init -y

這個(gè)命令會(huì)創(chuàng)建一個(gè)默認(rèn)的package.json。它包含了項(xiàng)目的一些配置參數(shù),通過(guò)它可以進(jìn)行初始安裝。詳細(xì)參數(shù):https://docs.npmjs.com/files/package.json。

不要y參數(shù)的話,會(huì)在命令框中設(shè)置各項(xiàng)參數(shù),但覺(jué)得沒(méi)啥必要。

2.安裝webpack

npm install webpack --save-dev

將webpack安裝到當(dāng)前目錄。雖然npm install webpack -g 可以講webpack安裝到全局,但是容易出現(xiàn)一些模塊找不到的錯(cuò)誤,所以最好還是安裝到當(dāng)前目錄下。

3.目錄結(jié)構(gòu)

webpack是一款模塊加載各種資源并打包的工具。所以先建一個(gè)如下的目錄結(jié)構(gòu):

webpack怎么用

app包含的開(kāi)發(fā)中的js文件,一個(gè)組件,一個(gè)入口。build中就是用來(lái)存放打包之后的文件的。webpack.config.js 顧名思義用來(lái)配置webpack的。package.json就不用說(shuō)了。

component.js

export default function () {
 var element = document.createElement('h2');
 element.innerHTML = 'Hello world';
 return element;
}

component.js 是輸出一個(gè)內(nèi)容為h2元素。export default 是ES6語(yǔ)法,表示指定默認(rèn)輸出。import的時(shí)候不用帶大括號(hào)。

index.js

import component from './component';
document.body.appendChild(component());

index.js 的作用就是引用Component模塊,并在頁(yè)面上輸出一個(gè)h2元素。但完成這個(gè)還需要一個(gè)插件,因?yàn)槟壳拔覀冞€沒(méi)有index.html文件。

npm install html-webpack-plugin --save-dev

html-webpack-plugin的用來(lái)生成html,將其也安裝到開(kāi)發(fā)目錄下面。

4.設(shè)置 webpack 配置文件

我們需要通過(guò)webpack.config.js文件告訴webpack如何開(kāi)始。配置文件至少需要一個(gè)入口和一個(gè)輸出。多個(gè)頁(yè)面就需要多個(gè)入口。node的path模塊

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');

const PATHS = {
 app: path.join(__dirname, 'app'),
 build: path.join(__dirname, 'build'),
};

module.exports = {
 entry: {
 app: PATHS.app,
 },
 output: {
 path: PATHS.build,
 filename: '[name].js',
 },
 plugins: [
 new HtmlWebpackPlugin({
  title: 'Webpack demo',
 }),
 ],
};

第一次看到這個(gè)配置文件是有點(diǎn)懵,主要是exports,分三個(gè)部分,一個(gè)入口,一個(gè)輸出,一個(gè)插件。入口指向了app文件夾。默認(rèn)會(huì)把包含"index.js"的文件作為入口。輸出指定了build地址和一個(gè)文件名;[name]這兒表示占位符,可以看成webpack提供的一個(gè)變量。這個(gè)具體后面再看。而HtmlWebpackPlugin會(huì)生成一個(gè)默認(rèn)的html文件。

5.打包

有了以上準(zhǔn)備,直接輸入 webpack 就能運(yùn)行了。

webpack怎么用

這個(gè)輸出包含了Hash(每次打包值都不同),Version,Time(耗時(shí))。以及輸出的文件信息。這時(shí)打開(kāi)build文件夾,發(fā)現(xiàn)多了一個(gè)app.js和index.html文件,雙擊index.html:

webpack怎么用

也可以修改下package.json

{
 "name": "Html5",
 "version": "1.0.0",
 "description": "",
 "main": "index.js",
 "scripts": {
 "build": "webpack"
 },
 "keywords": [],
 "author": "",
 
 "license": "ISC",
 "devDependencies": {
 "html-webpack-plugin": "^2.28.0",
 "webpack": "^2.2.1"
 }
}

指定build。在cmd中執(zhí)行npm run build 得到同樣的結(jié)果

webpack怎么用

出現(xiàn)helloword。再看下文件內(nèi)容

index.html:



 
 
 Webpack demo
 
 
 

默認(rèn)引用了app.js。

6、解析

app.js

/******/ (function(modules) { // webpackBootstrap
/******/  // The module cache
/******/  var installedModules = {};

/******/  // The require function
/******/  function __webpack_require__(moduleId) {

/******/   // Check if module is in cache
/******/   if(installedModules[moduleId])
/******/    return installedModules[moduleId].exports;

/******/   // Create a new module (and put it into the cache)
/******/   var module = installedModules[moduleId] = {
/******/    i: moduleId,
/******/    l: false,
/******/    exports: {}
/******/   };

/******/   // Execute the module function
/******/   modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);

/******/   // Flag the module as loaded
/******/   module.l = true;

/******/   // Return the exports of the module
/******/   return module.exports;
/******/  }


/******/  // expose the modules object (__webpack_modules__)
/******/  __webpack_require__.m = modules;

/******/  // expose the module cache
/******/  __webpack_require__.c = installedModules;

/******/  // identity function for calling harmony imports with the correct context
/******/  __webpack_require__.i = function(value) { return value; };

/******/  // define getter function for harmony exports
/******/  __webpack_require__.d = function(exports, name, getter) {
/******/   if(!__webpack_require__.o(exports, name)) {
/******/    Object.defineProperty(exports, name, {
/******/     configurable: false,
/******/     enumerable: true,
/******/     get: getter
/******/    });
/******/   }
/******/  };

/******/  // getDefaultExport function for compatibility with non-harmony modules
/******/  __webpack_require__.n = function(module) {
/******/   var getter = module && module.__esModule ?
/******/    function getDefault() { return module['default']; } :
/******/    function getModuleExports() { return module; };
/******/   __webpack_require__.d(getter, 'a', getter);
/******/   return getter;
/******/  };

/******/  // Object.prototype.hasOwnProperty.call
/******/  __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };

/******/  // __webpack_public_path__
/******/  __webpack_require__.p = "";

/******/  // Load entry module and return exports
/******/  return __webpack_require__(__webpack_require__.s = 1);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
/* harmony default export */ __webpack_exports__["a"] = function () {
 var element = document.createElement('h2');
 element.innerHTML = 'Hello world';
 return element;
};

/***/ }),
/* 1 */
/***/ (function(module, __webpack_exports__, __webpack_require__) {

"use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__component__ = __webpack_require__(0);

document.body.appendChild(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__component__["a" /* default */])());

/***/ })
/******/ ]);

而app.js內(nèi)容比較多了。整體是一個(gè)匿名函數(shù)。

(function(module) {
})([(function (){}), function() {}])

app文件夾中的兩個(gè)js文件成了這兒的兩個(gè)模塊。函數(shù)最開(kāi)始是從__webpack_require__開(kāi)始

return __webpack_require__(__webpack_require__.s = 1);

這里指定從模塊1執(zhí)行(賦值語(yǔ)句的返回值為其值)。而模塊1的調(diào)用是通過(guò)__webpack_require__的這句執(zhí)行的。

代碼如下:

modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);

通過(guò)call調(diào)用模塊的主要作用是為了把參數(shù)傳過(guò)去。

(function(module, __webpack_exports__, __webpack_require__) {

"use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__component__ = __webpack_require__(0);

document.body.appendChild(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__component__["a" /* default */])());

/***/ })

__webpack_require__ 每加載一個(gè)模塊都會(huì)先去模塊緩存中找,沒(méi)有就新建一個(gè)module對(duì)象:

var module = installedModules[moduleId] = {
   i: moduleId,
   l: false,
   exports: {}
  };

模塊1中加載了模塊0,

var __WEBPACK_IMPORTED_MODULE_0__component__ = __webpack_require__(0);

__WEBPACK_IMPORTED_MODULE_0__component__ 返回的是這個(gè)模塊0的exports部分。而之前Component.js的默認(rèn)方法定義成了

__webpack_exports__["a"] = function () {
var element = document.createElement('h2');
element.innerHTML = 'Hello world';
return element;
}

所以再模塊1的定義通過(guò)"a“來(lái)獲取這個(gè)方法:

代碼如下:

document.body.appendChild(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__component__["a" /* default */])());

這樣就完整了,但這里使用了__webpack_require__.i 將原值返回。

/******/  // identity function for calling harmony imports with the correct context
/******/  __webpack_require__.i = function(value) { return value; };

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“webpack怎么用”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!


網(wǎng)頁(yè)標(biāo)題:webpack怎么用
文章網(wǎng)址:http://www.dlmjj.cn/article/ghpdds.html