在使用vue写移动端页面时,发现iPhone手机中的X5内核浏览器不会改变title,原因是对于SPA这类单页面应用,路由的变化并不会触发页面更新document.title = to.meta.title
,所以需要我们自己创建一个隐藏的iframe
来实现触发。
以下是解决方案的实现代码:
main.js文件
router.beforeEach((to, from, next) => {
let title = to.meta.title
if(title) {
document.title = title
// 下面是关键的地方,匹配苹果设备
if(/ip(hone|od|ad)/i.test(navigator.userAgent)) {
let i = document.createElement('iframe')
i.src =