多页面应用,vue cli 配置不生成 html 文件

这篇具有很好参考价值的文章主要介绍了多页面应用,vue cli 配置不生成 html 文件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

已解决

使用的 vue-cli v5.0.8 版本。

原本生成的 html 文件为 index.htmlcallback.htmlerror.html,所以删除处理 html 的 plugin 即可。

chainWebpack: (config) => {
  config.plugins.delete('html-index')
  config.plugins.delete('html-callback')
  config.plugins.delete('html-error')
}

可以打印看看 config.plugins 就知道使用了那些 plugin 了。

例如下面这个,public 目录的内容就不会复制到 dist 目录了。

config.plugins.delete('copy')

以上。


下面是之前尝试过的解决方法,留作记录。

1,需求

前端多页面应用。打包后的文件

  • html 文件放到 Nginx
  • 其他文件放到 CDN

打包后的 js 没有使用 hash 来命名,所以每次打包后的 js 名称都一样。

这样的话 html 文件中引入的 js 文件名不变,所以 html 文件内容也不会变。

所以第一次打包后,将 html 放到 Nginx 上,之后的打包就不需要生成 html 文件,只生成 js,css,img。通过 devOps 运行打包命令,并自动压缩 dist 目录,接着上传到 CDN

2,解决方案

经过调研,有 3 种解决方案

1,保持现状

即便打包后的 dist 目录中有 html 文件也是可以的,一起上传到 CDN 上也不会影响功能,只是有了多余文件。

2,不生成 html 文件

3,将生成的 html 文件放到其他目录。

因为设置了 devOps 只会处理指定的目录。

这2种实现的原理相同,都是指定 html 文件的输出路径

  • filename: ''
  • filename: '其他目录'

有一个问题,当 filename: '' 打包时,结果符合预期,但打包命令会执行出错!

因为打包命令运行到处理 html 文件时,会报错退出执行。原因是 filename 目录必须合法:是字符串类型而且不为空。

ERROR  Error: EISDIR: illegal operation on a directory, open 'D:\xxx\dist'
Error: EISDIR: illegal operation on a directory, open 'D:\xxx\dist'
ELIFECYCLE  Command failed with exit code 1.
WARN   Local package.json exists, but node_modules missing, did you mean to install?

3,实现

1,项目结构

-- public
   -- images
-- src
   -- api
   -- components
   -- pages
      -- callback
         -- index.vue
         -- main.js
      -- index
         -- index.vue
         -- main.js
      -- error
         -- index.vue
         -- main.js
-- package.json
-- vue.config.js

2,vue.config.js 核心配置

多页面 pages 配置参考

const glob = require('glob')
const path = require('path')

function resolve(dir) {
  return path.join(__dirname, dir)
}

function getEntries(globPath) {
  const files = glob.sync(globPath), entries = {}
  /* 
    files [
      'src/pages/callback/main.js',
      'src/pages/error/main.js',
      'src/pages/index/main.js',
      'src/pages/payconfirm/main.js'
    ]
    获取所有匹配文件的路径,取倒数第二层(pages下面的文件夹)做包名
  */
  files.forEach(function (filepath) {
    const split = filepath.split('/')
    const name = split[split.length - 2]
   	/* 
      entries[name] 可以是字符串,表示文件路径。其他参数默认即可。
      entries[name] = filepath
      也可以是对象,有更多的配置项,这里只用到 filename:指定打包后的 html 文件名称。
    */
    entries[name] = {
      entry: filepath,
      // filename 如果为 '',其他文件会正常打包,但不会输出 html 文件!因为打包命令运行到处理 html 文件时会报错退出执行。
      filename: resolve('dist2/') + name + '.html'
    }
  })
  return entries
}

// 获取所有匹配src下目录的文件夹名字,其中文件夹里main.js为页面入口
const pages = getEntries('src/**/main.js')

module.exports = {
  pages,
}

3,打包结果

-- dist
   -- images
   -- js
      -- callback.js
      -- chunk-common.js
      -- chunk-vendors.js
      -- error.js
      -- index.js
-- dist2
   -- callback.html
   -- error.html
   -- index.html 

4,vue.config.js 完整配置

const glob = require('glob')
const path = require('path')

function resolve(dir) {
  return path.join(__dirname, dir)
}

function getEntries(globPath) {
  const files = glob.sync(globPath), entries = {}
  files.forEach(function (filepath) {
    const split = filepath.split('/')
    const name = split[split.length - 2]
    entries[name] = {
      entry: filepath,
      filename: resolve('dist2/') + name + '.html'
    }
  })
  return entries
}

// 获取所有匹配src下目录的文件夹名字,其中文件夹里main.js为页面入口
const pages = getEntries('src/**/main.js')

module.exports = {
  publicPath: process.env.VUE_APP_PUBLIC_PATH, // 本地 '/' 其他 'CDN路径'
  pages,
  chainWebpack: (config) => {
    config.resolve.alias.set('@', resolve('src'))
  },
  css: {
    loaderOptions: {
      scss: {
        // 全局 scss 变量
        additionalData: `@import "@/styles/var.scss";`
      }
    }
  },
  devServer: {
    port: 8080,
    // 解决本地运行时,因为内网导致热更新失败的问题。
    client: {
      webSocketURL: 'ws://0.0.0.0:8080/ws'
    },
    proxy: {
      '/cashier_core': {
        target: 'https://xxx.com.cn/',
        changeOrigin: true
      }
    }
  }
}

其他

设置更改 js 的打包路径(相对于 outputDir 目录(默认 dist ))。也可以通过指定 assetsdir 来实现。

chainWebpack: (config) => {
   config.output.set('filename', 'static/js/[name].[chunkhash].js')
},

以上。文章来源地址https://www.toymoban.com/news/detail-670688.html

到了这里,关于多页面应用,vue cli 配置不生成 html 文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包