Vue怎么指定不编译的文件夹和favicon.ico
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
//copycustomstaticassetsnewCopyWebpackPlugin([//---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
newHtmlWebpackPlugin({filename:config.build.index,template:'index.html',favicon:'favicon.ico',//------favicon的路径inject:true,minify:{removeComments:true,collapseWhitespace:true,removeAttributeQuotes:true//moreoptions://https://github.com/kangax/html-minifier#options-quick-reference},//necessarytoconsistentlyworkwithmultiplechunksviaCommonsChunkPluginchunksSortMode:'dependency'}),
favicon.ico不能正确显示问题
首先将favicon.ico图片放在根目录下,通过以下两种方法使其显示正确。
方法一:修改index.html文件
<linkrel="shortcuticon"type="image/x-icon"href="favicon.ico"rel="externalnofollow"/>
方法二:修改webpack配置文件
1、找到build下的webpack.dev.conf.js文件
newHtmlWebpackPlugin({filename:'index.html',template:'index.html',inject:true,favicon:path.resolve('favicon.ico')//增加}),
2、找到build下的webpack.prod.conf.js文件
newHtmlWebpackPlugin({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”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注恰卡编程网网站,小编会继续努力为大家带来更多实用的文章!
推荐阅读
-
vue表格组件教程学习(vue proxytable只能在开发环境跨域吗)
vueproxytable只能在开发环境跨域吗?跨域问题来源于JavaScript的同源策略,即只有协议主机名端口号(如...
-
Vue组件的自定义事件和全局事件总线怎么使用
Vue组件的自定义事件和全局事件总线怎么使用这篇“Vue组件的自定...
-
vue中消息订阅与发布如何使用
vue中消息订阅与发布如何使用这篇文章主要介绍“vue中消息订阅与...
-
Vue显示图片的方式有哪些
Vue显示图片的方式有哪些这篇文章主要介绍“Vue显示图片的方式有...
-
vue引入静态jquery报错如何解决
vue引入静态jquery报错如何解决这篇文章主要介绍“vue引入...
-
vue-cropper怎么实现裁剪图片
-
怎么用Vue+NodeJS实现大文件上传
怎么用Vue+NodeJS实现大文件上传本文小编为大家详细介绍“怎...
-
Vue如何实现简易跑马灯效果
Vue如何实现简易跑马灯效果本文小编为大家详细介绍“Vue如何实现...
-
Vue中的插槽怎么使用
-
Vue WebPack怎么忽略指定文件或目录
Vue WebPack怎么忽略指定文件或目录本篇内容介绍了“Vue...