千家信息网

Vue怎么指定不编译的文件夹和favicon.ico

发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这篇文章主要介绍"Vue怎么指定不编译的文件夹和favicon.ico",在日常操作中,相信很多人在Vue怎么指定不编译的文件夹和favicon.ico问题上存在疑惑,小编查阅了各式资料,整理出简单好
千家信息网最后更新 2025年02月01日Vue怎么指定不编译的文件夹和favicon.ico

这篇文章主要介绍"Vue怎么指定不编译的文件夹和favicon.ico",在日常操作中,相信很多人在Vue怎么指定不编译的文件夹和favicon.ico问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"Vue怎么指定不编译的文件夹和favicon.ico"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

指定不编译的文件夹和favicon.ico

在Vue3.0中引入public文件夹,不希望被编译的文件都可以放到这个文件夹下,但是在vue2.0中实现类似的功能,需要自己在webpack.prod.conf.js中做一些配置

这里简单区分一下Vue2.0中的assets和static区别

  • assets:各组件中的依赖项,会被编译

  • static:不会被编译,原样放到dist文件夹下

言归正传,假设不希望被编译的文件全部放在public下,要修改的地方是webpack.prod.conf.js

// copy custom static assetsnew CopyWebpackPlugin([    //---static文件夹下的文件也不会被编译    {        from: path.resolve(__dirname, '../static'),        to: config.build.assetsSubDirectory,        ignore: ['.*']    },    {        from: path.resolve(__dirname, '../public'),        to: path.resolve(__dirname, '../dist'),        ignore: ['.*']    },    //---这里还能指定特定文件输出的位置和文件名    {        from: path.resolve(__dirname, '../public/strings-en.js'),        to: path.resolve(config.build.assetsRoot, 'strings.js'),        ignore: ['.*']    }])

指定项目的favicon.ico

同样是修改webpack.prod.conf.js

new HtmlWebpackPlugin({    filename: config.build.index,    template: 'index.html',    favicon: 'favicon.ico',   //------favicon的路径    inject: true,    minify: {        removeComments: true,        collapseWhitespace: true,        removeAttributeQuotes: true        // more options:        // https://github.com/kangax/html-minifier#options-quick-reference    },    // necessary to consistently work with multiple chunks via CommonsChunkPlugin    chunksSortMode: 'dependency'}),

favicon.ico不能正确显示问题

首先将favicon.ico图片放在根目录下,通过以下两种方法使其显示正确。

方法一:修改index.html文件

方法二:修改webpack配置文件

1、找到build下的webpack.dev.conf.js文件

new HtmlWebpackPlugin({      filename: 'index.html',      template: 'index.html',      inject: true,      favicon: path.resolve('favicon.ico') // 增加    }),

2、找到build下的webpack.prod.conf.js文件

 new HtmlWebpackPlugin({      filename: config.build.index,      template: 'index.html',      inject: true,      favicon: path.resolve('favicon.ico'), //新增      minify: {        removeComments: true,        collapseWhitespace: true,        removeAttributeQuotes: true        ...    }),

修改配置文件后重启npm run dev,大功告成。

注意:如果打包发布到线上,会导致ico图标不显示的问题,是因为执行npm run build打包后只有static文件夹和index.html文件,找不到根目录下的ico图标,解决办法:把ico图标放到static文件夹下就OK啦。

到此,关于"Vue怎么指定不编译的文件夹和favicon.ico"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

0