Vue项目改index.html不生效的解决方法

改了根目录index.html不生效

有时要在index.html 引入一些外部资源改个title什么的,用有些模板创建的Vue项目在根目录下有index.html,但无论怎么修改都不会生效。经摸索,用以下方式完美解决。

把index.html移到public目录

把根目录下的index.html移到public 目录即可,如果根目录下没有public创建一个就行。
示例.jpg
再试下修改title,即可生效。

### 更 Vue.js 项目中的 Favicon.ico 图标 #### 使用配置文件统一管理 Favicon 路径 为了简化不同项目的Favicon管理,可以在配置文件中设置Favicon路径。通过这种方式,在多个地方使用的HTML模板可以引用同一个配置项,从而减少重复劳动和错误发生的可能性。 对于Vue CLI创建的应用程序来说,可以通过`vue.config.js`来进行全局性的配置调整[^1]: ```javascript // vue.config.js module.exports = { chainWebpack: config => { config.plugin('html').tap(args => { args[0].favicon = './src/assets/favicon.ico'; return args; }); } } ``` 此段代码会告诉HtmlWebpackPlugin使用指定位置的图片作为网页标签页的小图标。 #### 利用 JavaScript 动态加载 Favicon 另一种方式是在应用初始化阶段利用JavaScript动态变文档头部链接元素指向的新图标资源地址[^2]: ```javascript function changeFavIcon(url){ let link = document.querySelector("link[rel*='icon']") || document.createElement('link'); link.type = 'image/x-icon'; link.rel = 'shortcut icon'; link.href = url; document.getElementsByTagName('head')[0].appendChild(link); } changeFavIcon('/path/to/new-favicon.ico'); // 替换成实际图标URL ``` 这种方法的好处在于不需要重新编译整个应用程序就可以即时更新浏览器Tab上的显示图像。 #### 修 Webpack 配置以支持静态资源处理 如果上述两种方法未能达到预期效果,则可能是因为构建工具链对静态资产的支持不够完善所致。此时应该检查并适当修WebPack的相关配置选项,比如在`build/webpack.dev.conf.js`里面加入如下所示的一行配置[^3]: ```javascript new HtmlWebpackPlugin({ ... favicon: path.resolve(__dirname, '../static/bitbug_favicon.ico'), }) ``` 这一步骤确保打包过程中能够正确识别并引入所需的Favicon文件。 #### 手动编辑 HTML 文件指明新图标路径 最直接的办法就是直接操作位于`public/index.html`内的<link>标记,把其`href`属性更为所要替换的那个`.ico`文件的位置[^4]: ```html <!-- public/index.html --> <!DOCTYPE html> <html lang="en"> <head> <!-- Other meta tags and links... --> <link rel="icon" href="%PUBLIC_URL%/new-favicon.ico"> </head> <body> ... </body> </html> ``` 完成以上任一或组合措施之后,请记得重启开发服务器以便使动生效,并确认新的Favicon已经成功应用于页面之上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值