文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

js如何判断并告知支持css属性的情况

2023-06-08 04:40

关注

这篇文章主要介绍js如何判断并告知支持css属性的情况,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

当我们想用某个css新特性时,总是会在意它的兼容性情况,或许我们会去搜索它的兼容性,哪些浏览器合适哪些不合适,在这些已知的情况下再选择是不是使用或如何使用,这是一个已知我们即将用于什么浏览器下作出的选择。

但我们往往不知道自己开发的页面用户会在哪个浏览器上进行打开,这时我们需要根据实际使用浏览器情况来判断采用何策略。这时就需要用js来判断,我们要使用css属性能否起效。

css属性的兼容性,是有两类的,一类是,css属性本身,如 position ;另一类是,css属性值,如,对于 position 属性的 sticky 值

目标

我们想知道某个css属性(值)是否起效,一般被告知结果是“起效”或“不起效”。但是css属性存在浏览器私有属性一说,即会有加了浏览器前缀才会生效的css属性。

所以你更加需要知道,对于目前浏览器来说,哪个前缀或不需要前缀的css属性才会起效,而不仅仅是知道起效与否(自己每个前缀作为输入值进行校验,是繁琐的!网络上的很多资料往往会告诉你是否支持你指定的css,返回的boolean值)

所以下面的方法, 只需要你把css属性(值)作为输入值,不需要带上前缀,便能告知你,当前使用的浏览器支持哪个前缀的用法或压根不需要前缀。

检查css属性名

该方法检查的是css的属性本身,即属性名,即写css的时候 : 的左侧。如果返回值是空,那么证明浏览器不支持该属性。

function validateCssKey(key) {    const jsKey = toCamelCase(key); // 有些css属性是连字符号形成    if (jsKey in document.documentElement.style) {        return key;    }    let validKey = '';    // 属性名为前缀在js中的形式,属性值是前缀在css中的形式    // 经尝试,Webkit 也可是首字母小写 webkit    const prefixMap = {        Webkit: '-webkit-',        Moz: '-moz-',        ms: '-ms-',        O: '-o-'    };    for (const jsPrefix in prefixMap) {        const styleKey = toCamelCase(`${jsPrefix}-${jsKey}`);        if (styleKey in document.documentElement.style) {            validKey = prefixMap[jsPrefix] + key;            break;        }    }    return validKey;}function toCamelCase(value) {    return value.replace(/-(\w)/g, (matched, letter) => {       return letter.toUpperCase();   });}

检查css属性值

该方法检查的是css的属性的值,即写css的时候 : 的右侧。如果返回值是空,那么证明浏览器不支持该属性值。

这里分为两个版本,一个是es6版本,一个是基础的js版本。

纯属自己多余写了两个版本

function valiateCssValue (key, value) {    const prefix = ['-o-', '-ms-', '-moz-', '-webkit-', ''];    const prefixValue = prefix.map(item => {        return item + value;    });    const element = document.createElement('div');    const eleStyle = element.style;    // 应用每个前缀的情况,且最后也要应用上没有前缀的情况,看最后浏览器起效的何种情况    // 这就是最好在prefix里的最后一个元素是''    prefixValue.forEach(item => {        eleStyle[key] = item;    });    return eleStyle[key];}function valiateCssValue (key, value) {    var prefix = ['-o-', '-ms-', '-moz-', '-webkit-', ''];    var prefixValue = [];    for (var i = 0; i < prefix.length; i++) {        prefixValue.push(prefix[i] + value)    }    var element = document.createElement('div');    var eleStyle = element.style;    for (var j = 0; j < prefixValue.length; j++) {         eleStyle[key] = prefixValue[j];    }    return eleStyle[key];}

总结

我们可以简单地上述对于两种形式的css兼容性进行合并,不用显式地采用调用检查属性名还是属性值的方法,直接传入css,告知浏览器支持的情况。

function validCss (key, value) {    const validCss = validateCssKey(key);    if (validCss) {        return validCss;    }    return valiateCssValue(key, value);}

以上是“js如何判断并告知支持css属性的情况”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯