Rumah hujung hadapan web tutorial js 通过webpack如何打包koa2 框架app,该怎么做?

通过webpack如何打包koa2 框架app,该怎么做?

Jun 08, 2018 pm 01:56 PM
koa2 webpack Kerahan pakej mengerahkan

本文给大家介绍的是使用webpack为koa2框架打包的步骤及最终的部署,非常实用,有需要的小伙伴可以参考下

以前在用koa写server的时候,发布简直是噩梦。需要将src里面的全部文件都覆盖掉,config配置文件也要覆盖,稍有不慎就会线上报各种各样的问题,然后就得回退,本地调好在发布。偶然看见一篇文章讲 如何使用webpack打包koa app ,惊为天人,原来webpack也能打包后台。这在以前想都没想过。

关键问题

一:所有node_modules里的模块都不进行打包

webpack的核心功能是将引用的各个模块打到一个文件里,并会将各种规范的模块进行统一的模块化处理(webpack规范)。

然而node中包含大量的fs、path操作,这些fs和path操作在打包完成后将没有操作对象,还会报出很多各样的错误。

所以使用webpack打包的核心就是拒绝打包一切node_modules里的模块,只是将相对路径引用的文件打包到一个文件里。恰巧我们发现webapck提供externals属性来排除掉不需要打包的模块。

再深入点我们可以发现:像webpack、nodemon、babel-preset-env这样的模块是app开发环境依赖的包,我们的程序里根本不会require这些模块。

综上可以发现:我们只将所有require到的包排除掉就可以了,这个模块对应的也就是package.json里dependencies下的模块。有关dependencies和devDependencies的区别要理解好。

因此我们可以使用externals-dependencies这个插件配合externals属性实现dependencies的排除工作。

代码:

const webpack = require('webpack');
const _externals = require('externals-dependencies')
module.exports = {
  ...
  externals: _externals(),
  ...
}
Salin selepas log masuk

二:target指向node

官方文档:编译为类 Node.js 环境可用(使用 Node.js require 加载 chunk)

代码:

target: 'node',
Salin selepas log masuk

三:增加node配置

官方文档:这些选项可以配置是否 polyfill 或 mock 某些 Node.js全局变量和模块。这可以使最初为 Node.js 环境编写的代码,在其他环境(如浏览器)中运行。

代码:

node: {
    console: true,
    global: true,
    process: true,
    Buffer: true,
    __filename: true,
    __dirname: true,
    setImmediate: true,
    path: true
},
Salin selepas log masuk

四:babel配置

为了兼容低版本的node不原生支持async/await的问题。这里babel我使用了babel-preset-env{"modules": false}的配置。此配置会将es6语法转为es5语法,例如let、const转为var。

同时将所有的async/await函数也转成了polyfill里定义的_asyncToGenerator函数。

其实是使用promise实现了async函数的功能。

当然这个函数在运行时还需要regeneratorRuntime函数。所以我在全局引入了babel-polyfill来提供regeneratorRuntime函。

注:如果你的node版本很高且原生支持async/await,大可将babel-preset-env和babel-polyfill省略掉

代码:

const path = require('path');
const webpack = require('webpack');
const _externals = require('externals-dependencies')

module.exports = {
  entry: {
    app: [
      // 如果polyfill放在这里,打包的时候将不会被external,必须在js里require才能有效external
      // 'babel-polyfill',
      './src/index.js'
    ]
  },
  output: {
    path: path.resolve(__dirname),
    filename: '[name].js'
  },
  resolve: {
    extensions: [".js"]
  },
  target: 'node',
  externals: _externals(),
  context: __dirname,
  node: {
    console: true,
    global: true,
    process: true,
    Buffer: true,
    __filename: true,
    __dirname: true,
    setImmediate: true,
    path: true
  },
  module: {
    rules: [
      {
        test: /\.js/,
        use: ['babel-loader']
      }
    ]
  },
  plugins: [
    new webpack.DefinePlugin({
      'process.env': {
        NODE_ENV: '"development"'
      }
    }),
  ]
}
Salin selepas log masuk

部署

经过打包,部署的时候就方便多了,只需要将package.json、app.js、以及view里的html部署上线就好了。然后在服务器上执行

1. npm install 
2. npm run for

然后server就后台运行了。如果需要更新发布,只需要本地重新npm run dev或npm run build打好包,拖到服务器覆盖app.js即可。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

使用React如何进行组件库的开发

利用fullpage.js实现滚动方式

使用npm安装Electron失败的问题

Atas ialah kandungan terperinci 通过webpack如何打包koa2 框架app,该怎么做?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menggunakan Jenkins Pipeline untuk membina proses pembungkusan dan penggunaan yang berterusan untuk program PHP? Bagaimana untuk menggunakan Jenkins Pipeline untuk membina proses pembungkusan dan penggunaan yang berterusan untuk program PHP? Jul 30, 2023 pm 07:41 PM

Bagaimana untuk menggunakan JenkinsPipeline untuk membina proses pembungkusan dan penggunaan yang berterusan untuk program PHP? Jenkins ialah alat penyepaduan dan penggunaan berterusan yang sangat popular. Ia menyediakan banyak pemalam dan fungsi untuk menjadikan proses binaan dan penggunaan mudah dan cekap. JenkinsPipeline ialah pemalam terbaharu untuk Jenkins, yang membolehkan kami menggunakan DSL (DomainSpecificLanguage) yang lengkap dan boleh dikembangkan untuk mentakrifkan penyepaduan dan penggunaan berterusan.

Bagaimana untuk menggunakan antara muka web yang boleh dipercayai pada pelayan Linux? Bagaimana untuk menggunakan antara muka web yang boleh dipercayai pada pelayan Linux? Sep 09, 2023 pm 03:27 PM

Bagaimana untuk menggunakan antara muka web yang boleh dipercayai pada pelayan Linux? Pengenalan: Dalam era ledakan maklumat hari ini, aplikasi Web telah menjadi salah satu cara utama untuk orang ramai mendapatkan maklumat dan berkomunikasi. Untuk memastikan privasi pengguna dan kebolehpercayaan maklumat, kami perlu menggunakan antara muka Web yang boleh dipercayai pada pelayan Linux. Artikel ini akan memperkenalkan cara untuk menggunakan antara muka web dalam persekitaran Linux dan menyediakan contoh kod yang berkaitan. 1. Pasang dan konfigurasikan pelayan Linux Mula-mula, kita perlu menyediakan Li

Bagaimana untuk menggunakan Docker untuk membungkus dan menggunakan program PHP? Bagaimana untuk menggunakan Docker untuk membungkus dan menggunakan program PHP? Jul 29, 2023 pm 05:48 PM

Bagaimana untuk menggunakan Docker untuk membungkus dan menggunakan program PHP? Dengan aplikasi pengkomputeran awan dan teknologi kontena yang meluas, semakin ramai pembangun mula menggunakan Docker untuk membungkus dan menggunakan aplikasi. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Docker untuk membungkus dan menggunakan program PHP dan memberikan contoh kod yang berkaitan. 1. Pasang Docker Sebelum memulakan, kita perlu memasang Docker terlebih dahulu. Untuk langkah pemasangan, sila rujuk dokumentasi rasmi Docker dan pilih kaedah pemasangan yang sepadan mengikut sistem pengendalian yang berbeza.

Cara menggunakan aplikasi menggunakan kontena Docker dalam FastAPI Cara menggunakan aplikasi menggunakan kontena Docker dalam FastAPI Jul 28, 2023 pm 01:25 PM

Cara menggunakan kontena Docker untuk menggunakan aplikasi dalam FastAPI Pengenalan: Docker ialah teknologi kontena yang membungkus aplikasi dan kebergantungan mereka ke dalam bekas bebas mudah alih untuk mencapai penggunaan dan pengembangan pantas. FastAPI ialah rangka kerja web moden berprestasi tinggi berdasarkan Python yang menyediakan pengalaman pembangunan API yang ringkas dan pantas. Artikel ini akan memperkenalkan cara menggunakan kontena Docker untuk menggunakan aplikasi dalam FastAPI dan menyediakan contoh kod yang sepadan.

Yolov10: Penjelasan terperinci, penggunaan dan aplikasi semuanya di satu tempat! Yolov10: Penjelasan terperinci, penggunaan dan aplikasi semuanya di satu tempat! Jun 07, 2024 pm 12:05 PM

1. Pengenalan Sejak beberapa tahun kebelakangan ini, YOLO telah menjadi paradigma dominan dalam bidang pengesanan objek masa nyata kerana keseimbangannya yang berkesan antara kos pengiraan dan prestasi pengesanan. Penyelidik telah meneroka reka bentuk seni bina YOLO, matlamat pengoptimuman, strategi pengembangan data, dsb., dan telah mencapai kemajuan yang ketara. Pada masa yang sama, bergantung pada penindasan bukan maksimum (NMS) untuk pemprosesan pasca menghalang penggunaan YOLO dari hujung ke hujung dan memberi kesan buruk kepada kependaman inferens. Dalam YOLO, reka bentuk pelbagai komponen tidak mempunyai pemeriksaan yang komprehensif dan teliti, mengakibatkan lebihan pengiraan yang ketara dan mengehadkan keupayaan model. Ia menawarkan kecekapan suboptimum, dan potensi yang agak besar untuk peningkatan prestasi. Dalam kerja ini, matlamatnya adalah untuk meningkatkan lagi sempadan kecekapan prestasi YOLO daripada kedua-dua pasca pemprosesan dan seni bina model. sampai habis

Bagaimana untuk menyelesaikan masalah tidak dapat diakses selepas Tomcat menggunakan pakej perang Bagaimana untuk menyelesaikan masalah tidak dapat diakses selepas Tomcat menggunakan pakej perang Jan 13, 2024 pm 12:07 PM

Bagaimana untuk menyelesaikan masalah bahawa Tomcat tidak boleh berjaya mengakses pakej perang selepas menggunakan ia memerlukan contoh kod khusus Sebagai pelayan Web Java yang digunakan secara meluas, Tomcat membenarkan pemaju untuk membungkus aplikasi Web mereka sendiri yang dibangunkan ke dalam fail perang untuk penggunaan. Walau bagaimanapun, kadangkala kita mungkin menghadapi masalah tidak berjaya mengakses pakej perang selepas menggunakannya. Ini mungkin disebabkan oleh konfigurasi yang salah atau sebab lain. Dalam artikel ini, kami akan menyediakan beberapa contoh kod konkrit yang menangani dilema ini. 1. Semak perkhidmatan Tomcat

Panduan Penggunaan Gunicorn untuk Aplikasi Flask Panduan Penggunaan Gunicorn untuk Aplikasi Flask Jan 17, 2024 am 08:13 AM

Bagaimana untuk menggunakan aplikasi Flask menggunakan Gunicorn? Flask ialah rangka kerja Web Python ringan yang digunakan secara meluas untuk membangunkan pelbagai jenis aplikasi Web. Gunicorn (GreenUnicorn) ialah pelayan HTTP berasaskan Python yang digunakan untuk menjalankan aplikasi WSGI (WebServerGatewayInterface). Artikel ini akan memperkenalkan cara menggunakan Gunicorn untuk menggunakan aplikasi Flask, dengan

Amalan terbaik dan penyelesaian masalah biasa untuk menggunakan projek web pada Tomcat Amalan terbaik dan penyelesaian masalah biasa untuk menggunakan projek web pada Tomcat Dec 29, 2023 am 08:21 AM

Amalan terbaik untuk menggunakan projek Web dengan Tomcat dan penyelesaian kepada masalah biasa Pengenalan: Tomcat, sebagai pelayan aplikasi Java yang ringan, telah digunakan secara meluas dalam pembangunan aplikasi Web. Artikel ini akan memperkenalkan amalan terbaik dan kaedah penyelesaian masalah biasa untuk penggunaan Tomcat projek web dan menyediakan contoh kod khusus untuk membantu pembaca memahami dan menggunakan dengan lebih baik. 1. Perancangan struktur direktori projek Sebelum menggunakan projek Web, kita perlu merancang struktur direktori projek. Secara umumnya, kita boleh menyusunnya dengan cara berikut

See all articles