IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> iPhone6s iPhone6 P上通过dom.style或者 ref.current.style 的方式设置样式报错 但是其他手机上可以正常运行的问题及解决方法 -> 正文阅读

[移动开发]iPhone6s iPhone6 P上通过dom.style或者 ref.current.style 的方式设置样式报错 但是其他手机上可以正常运行的问题及解决方法

问题描述:iPhone6s, iPhone6 P上通过dom.style或者 ref.current.style 的方式设置样式报错, 但是其他手机上可以正常运行的问题及解决方法

介绍:最近在开发h5项目封装表单提交不通过文案的时候, 遇到了个兼容性的问题, iOS 10 以下不支持 dom.style 的方式来设置元素的样式, 但是其他手机都是ok的, 如下图代码:

@Override
		...
		if(pictureUrl !== ''){
			tipMessage.current.style = 'color:red;'//此处代码ios 10不生效
		}
		...
        return() {
            <div ref={tipMessage}></div>
        }
        ...

后面了解到 ios 10以下不支持这样方式,解决办法如下:


解决方案:

方案一:dom.style的方式不支持, 可以使用 dom.style.color 的方式直接来设置, 如下:

@Override
		...
		if(pictureUrl !== ''){
			tipMessage.current.style.color = 'red'// ok了
		}
		...
        return() {
            <div ref={tipMessage}></div>
        }
        ...

但是这种方式不是很优雅, 下面看第二种方式:

方案二:dom.style的方式不支持, 可以通过动态className的方式来设置样式, 可以定义一个状态, 正常状态下className的类名为正常样式下的类名, 并设置对应的样式, 特殊提示文案下的将状态改变, 这个时候切换为提示文案下的 className, 如下:

我这里用到是 函数组件, 类组件同理;

@Override
		import React,{useState} from 'react';
		...
		const [tipMessageClass, setTipMessageClass] = useState('normal');//useState创建一个状态,用来控制变量名
		...
		if(pictureUrl !== ''){
			setTipMessageClass('abnormal');//当需要提示文案红色高亮时,改变状态的值,这样就可以改变className,从而改变样式
		}
		...
        return() {
            <div className={tipMessageClass === 'norma' ? 'normal': 'abnormal'}>提示文案</div>
        }
        ...

当然了, 可能一个dom很多时候都不会只有一个唯一的className, 这个时候也可以通过安装classnames这个库, 用第三方库的形式改变classnames, 这样不会覆盖和影响原来的类名, 具体classnames安装和引入口怎么使用, 可以查看classnames的使用文档, 也可以我后面持续更新一篇关于classnames的内容.

原创很有趣, 希望能帮助到各位大佬! 一起进步.

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-08-23 16:48:38  更:2021-08-23 16:50:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 9:47:01-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码