当前位置:首页 » 《关注互联网》 » 正文

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

27 人参与  2021年08月23日 14:43  分类 : 《关注互联网》  评论

点击全文阅读


问题描述: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的内容.

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


点击全文阅读


本文链接:http://zhangshiyu.com/post/26010.html

方式  文案  样式  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 爱也沧沧,恨也沧沧章节限时抢先看‌_「贺景川宋南乔贺景明」小说精彩章节免费试读
  • 被逼退婚后,我成了极道女王小说节选免费试读_「梁书沈漓冷笑」后续更新+番外
  • 人皇觉醒,屠天灭神限时免费章节抢先看_[墨如渊苏明明薇]小说精彩章节免费试读
  • (番外)+(全书)乔喜商凛(也曾偷藏欢喜结局+番外)全书在线_(乔喜商凛)列表_笔趣阁(也曾偷藏欢喜结局+番外)
  • 「为你归雪满舟」精彩章节试读_谢景期俞诗俞家独家章节限时试读
  • (番外)+(全书)男友帮假千金冒充我,我靠弹幕杀疯了(陈子期林依然+番外+全书)_(男友帮假千金冒充我,我靠弹幕杀疯了+番外+全书)免费_笔趣阁(陈子期林依然)
  • (番外)+(全书)商凛乔喜乔雪眠(乔喜商凛乔雪眠+后续+结局)_商凛乔喜乔雪眠免费列表_笔趣阁(乔喜商凛乔雪眠+后续+结局)
  • 许我三千繁星愿结局+番外(楚砚风慕星眠)完结_(许我三千繁星愿结局+番外)列表_笔趣阁(楚砚风慕星眠)
  • 时年田野田欣瑶男友为妹妹推迟婚宴后我上了别人的婚车全书+后续+结局列表_笔趣阁(男友为妹妹推迟婚宴后我上了别人的婚车全书+后续+结局时年田野田欣瑶)
  • 裴谨言桑年你是我未拆的遗书结局+番外列表_笔趣阁(你是我未拆的遗书裴谨言桑年结局+番外)
  • 也曾偷藏欢喜全书+后续列表_也曾偷藏欢喜全书+后续(乔喜商凛)
  • 许我永远爱你结局+番外免费_(沧溟星茗姬俏)许我永远爱你结局+番外全书列表

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1