ios + vue3 Teleport + inset 兼容性问题

阿里云国际,腾讯云国际,AWS 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov8

目录

1问题表现

使用 vue3 的 Teleport 实现的 dialog 弹窗但是在 ios app 中嵌套的 h5 中无法打开。

直接在ios手机浏览器中打开没有问题。
安卓手机也没有这个问题。

初始关键问题代码如下

<template>
  <Teleport to="body">
    <Transition name="modal">
	  <div v-if="open" class="fixed inset-0">
	    <div class="content"><!-- 内容 --></div>
	  </div>
	</Transition>
  </Teleport>
</template>

<style scoped>
.fixed {
  position: fixed;
}
.inset-0 {
  inset: 0;
}
</style>

2解决步骤

1teleport 的问题

因为这是旧项目jsp做前后端分离使用 vue3 重写的。之前没有这个问题所以猜测是 vue3 新语法问题。

果然去掉 Teleport 后弹窗可以出现了但样式又出问题了。

<template>
  <Transition name="modal">...</Transition>
</template>

可是即便元素没有插入 body 中但使用的是 fixed 定位并且任何祖先元素中都没有设置transformperspective 或者 filter 样式属性所以也应该正常显示样式。

有问题的样式表现和 top right bottom left 使用默认值一致。

2inset 的问题

所以猜测使用了 inset 这个 css 属性导致的。

因为我想实现 dialog 的蒙层是固定定位+铺满全屏。所以样式设置如下

.fixed {
  position: fixed;
}
.inset-0 {
  /* top: 0; right: 0; bottom: 0; left: 0; */
  inset: 0;
}

inset-0 这个 class 样式替换如下样式就可以正常显示了。

.inset-0 {
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

至此问题虽然已经解决但弹窗组件使用时的结构还是有问题应该将 dialog 的根组件插入到 body 中才合理。

3teleport 的问题之二

既然 <Teleport to="body"> 无法使用那插入目标从 body 替换为其他元素是否可行

经过测试html 也不行最终设置为 <Teleport to="#app"> html结构也算满意了。


以上。

阿里云国际,腾讯云国际,AWS 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov8

“ios + vue3 Teleport + inset 兼容性问题” 的相关文章

nodejs如何查看版本 - web开发

今天小编给大家分享一下nodejs如何查看版本的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。 方法一:使用命令行查看 Nod...

VI的常用命令

VI的常用命令 文章目录 VI的常用命令vi/vim是什么VI普通模式命令VI编辑模式命令VI指令模式 vi/vim是什么 VI是Unix操作系统和类Unix操作系统中最通用的文本编辑器 VIM编辑器是从VI发展出来的一个性能更强大的文本编辑器。可以主动的将字体颜色辨别...

Linux硬件状况

sensors:测试主机状况(温度什么的) lsmod:usb芯片版本 iostat: cpu与存储设备状态...

【docker】使用docker安装宝塔面板

在使用docker安装宝塔面板之前请先确保服务器已经安装并开启了docker 拉取centos基础镜像用容器启动该基础镜像直接在这个容器中部署 1.拉取纯净系统镜像 $ docker pull centos:7.2.1511    2.启动镜像映射主机与容器内8888宝塔面板、88...

JAVA中使用FTPClient上传下载 java利用ftp协议上传文件(by me)

package com.longboo.fangan; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import org....

#yyds干货盘点 前端小知识点扫盲笔记记录2

前言大家好 我是歌谣 今天继续进行前端知识的一些总结 想加入前端巅峰交流群私信我innerHTML和innerText的使用<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"&g...