zoukankan      html  css  js  c++  java
  • [React] Override webpack config for create-react-app without ejection

    The default service worker that comes with create-react-app doesn't allow for very much configuration. We'll replace that default service worker in two ways.

    First, we'll create a blank service worker js file, and use that as our custom service worker.

    Next, we'll re-write the default webpack config with react-app-rewired, and utilize the InjectManifest workbox webpack plugin. This will allow us to create a totally custom service worker that still allows us to use workbox, without ejecting our app.

    Install:

        "react-app-rewired": "^1.6.2",
        "react-scripts": "^2.1.1",
        "serve": "^10.1.1",
        "workbox-webpack-plugin": "^3.6.3"

    Create a config-overrides.js in root folder:

    Default create-react-app using 'GenerateSW' function, we want to override with 'InjectManifest' function. 

    /* config-overrides.js */
    
    const WorkboxWebpackPlugin = require('workbox-webpack-plugin')
    
    module.exports = function override(config, env) {
      config.plugins = config.plugins.map(plugin => {
        if(plugin.constructor.name === 'GenerateSW') {
          return new WorkboxWebpackPlugin.InjectManifest({
            swSrc: './src/sw.js', // point to the sw.js file we will create later
            swDest: 'service-worker.js' // will be generatedin pulbic folder
          })
        }
    
        return plugin
      })
    
      return config
    }

    Update package.json:

      "scripts": {
        "start": "react-app-rewired start",
        "build": "react-app-rewired build",
        "build:serve": "serve -s build",
        "test": "react-app-rewired test",
        "eject": "react-scripts eject"
      },

    Create src/sw.js:

    workbox.skipWaiting();
    workbox.clientsClaim();

    Run:

    npm run build
  • 相关阅读:
    数据结构之 直接插入排序
    (3)IP:网际协议
    node.js的global variable,和module.exports
    js实现雪花飘落效果的代码
    php 下载保存文件保存到本地的两种方法
    php读取图片内容并输出到浏览器的实现代码
    php中json_encode中文编码问题分析
    解析php开发中的中文编码问题
    jquery鼠标滑过提示title具体实现代码
    jquery弹出关闭遮罩层实例
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10192806.html
Copyright © 2011-2022 走看看