关于opacity属性的探究

关于opacity属性的探究关于opacity属性的探究上问题!!在前一段时间我朋友和我讨论到了opcaity的属性问题问题如下:代码如下清重点关注opcaity<!–css样式–><style>.boxfather{width:500px;height:500px;background-color:blue;text-align:cen

大家好,又见面了,我是你们的朋友全栈君。

关于opacity属性的探究


上问题!!

在前一段时间我朋友和我讨论到了opcaity的属性问题问题如下:

代码如下清重点关注opcaity

    <!-- css样式 -->
    <style>
        .boxfather {
            width: 500px;
            height: 500px;
            background-color: blue;
            text-align: center;
            padding: 100px;
            box-sizing: border-box;
            opacity: 0.7;
        }
        .boxson {
            width: 300px;
            height: 300px;
            background-color: green;
            padding: 100px;
            box-sizing: border-box;
        }
        .boxgrandson {
            width: 100px;
            height: 100px;
            background-color: yellow;

        }
    </style>

    <!-- html结构 -->

    <div class="boxfather">
        <div class="boxson">
            <div class="boxgrandson">
            </div>
        </div>
    </div>

可见我们只是对父级元素设置了透明度,子元素和孙子元素都没有设置但是效果却是【左未设置透明度,右设置为0.7】

  关于opacity属性的探究  关于opacity属性的探究

然后我们去查手册看opacity属性是否存在继承性

关于opacity属性的探究

这是w3school给的答案,链接:https://www.w3school.com.cn/cssref/pr_opacity.asp

关于opacity属性的探究

这是某鸟教程给的答案,连接:https://www.runoob.com/cssref/css3-pr-opacity.html

那么问题来了,我们明明就没有给子孙元素设置透明度为啥就成这样了呢?

 

提出质疑:w3school和菜鸟教程写错了??


于是我们开始探索到底怎么回事,【质疑权威】是非常好的精神,但是一定要有根据的提出于是我们引入了jQuery辅助一探究竟

  <script src="./jquery.min.js"></script>
    <script>
        $(document).ready(function(){
           var sonop = $(".boxson").css('opacity')
           var grandsonop = $(".boxgrandson").css('opacity')
           console.log(sonop,grandsonop);
        })
  </script>

有了jQuery老大哥的帮助我们看一下结果:

关于opacity属性的探究

?????‍不该这样呀!!!【质疑无效!!!】



再提问题:在知道opacity属性不具有继承性的基础下我们的代码结果表现了“继承”的“性状”?(难道。。。这儿子不是亲生的??!?‍♂️)

 


解决思路:代码没问题,文档没问题,探究一下opacity实现机制

(翻阅好多资料后。。。。。)关于opacity属性的探究

1,发现了一个这样的教程

  关于opacity属性的探究

决定上手试一下试的过程中我又试着搜了一下这个

关于opacity属性的探究

没想到呀结果令我喜出望外   关于opacity属性的探究

在解决方法中这个解决方案令我激动不已,先上链接 https://blog.csdn.net/weixin_29947843/article/details/107752117

在这位博主的文章中有一个层级的概念使我找到了打开世界的大门!!!



正文开始:层级与蒙版

在经过多轮的代码实验后我发现opacity属性在实现的原理上极度类似于PS中的蒙版概念

大概的实现原理图如下:

关于opacity属性的探究

在原有的div盒子的区域上方添加了蒙版实现了opacity透明的效果而且这层所谓的“蒙版”的层级要高于div的默认层级

尝试性解决1:提高不要透明度的盒子层级

于是有了如下的css新增:

              .boxfather:position: relative;    z-index: 1;

              .boxson :   position: absolute;   z-index: 50;

              .boxgrandson :   position: absolute;   z-index: 100;

控制台输出结果:关于opacity属性的探究

目测是属性加上了但是:关于opacity属性的探究

依旧是这个鬼样子!!!!难道是药效不够?于是关于opacity属性的探究

尝试1 —结论:失败,opacity属性不受z-index影响他是最贴近我们脸上的一层东西

问题还在尝试继续

尝试性解决2:把opacity属性放到同级元素实现

于是有了如下改动我就直接上完整代码啦,要下班咯?

css部分:

<style>
        .boxfather {
            
            width: 500px;
            height: 500px;
            background-color: blue;
            text-align: center;
            padding: 100px;
            box-sizing: border-box;
            opacity: 0.5;
            position: absolute;
            z-index: 1;
        }
        .boxson {
           
            width: 300px;
            height: 300px;
            background-color: green;
            padding: 100px;
            box-sizing: border-box;
            position: absolute;
            top: 20%;
            left: 7%;
            z-index: 500;
        }
        .boxgrandson {
           
            width: 100px;
            height: 100px;
            background-color: yellow;
            position: absolute;
            z-index: 1000;

        }
</style>

HTML部分:

<body>
    <div class="boxfather">
    </div>
    <div class="boxson">
        <div class="boxgrandson">
        </div>
    </div>
</body>

神奇的事情发生了!!!这个时候生效了!!!

关于opacity属性的探究

但是我又有了新的质疑到底和层级有没有关系于是我们刻意的提高.boxfather的层级不可思议的事情又发生了

现在的层级关系是关于opacity属性的探究

效果:关于opacity属性的探究

哇哇哇。。。。。。。。。。。要疯(不行我还不能疯)

分析:因为最上层是蓝色的!!不设置透明的时候应该看不到下层的!!

          正因为加上了opacity属性所以才会使另外两个按起来变了色!!

          也就是说我们黄色的盒子绿色的盒子是在0.5透明度的蓝色滤层下展示了现在这个奇奇怪怪的颜色

很简单的原理嘛,差点轻易的疯掉了?



好了总结一下:

1、透明度opacity属性确实没有继承性!!!

2、表现出继承“性状”的原因是opacity属性生效原理类似蒙版!!

3、子元素或子盒子无论层级多高都无法突破父级元素透明度的那层阴影!!!

4、可以通过改变盒子的包含关系解决这个问题!!

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/141134.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 最新视频磨皮降噪神器 轻轻松松完成视频磨皮!Beauty box

    最新视频磨皮降噪神器 轻轻松松完成视频磨皮!Beauty box在视频后期中为了追求更好的视觉效果我们经常需要为画面中人物进行磨皮不过这种技术门槛还是比较高的那么有没有一款插件可以帮助我们让PR\FCP等软件也可以像PS一样轻松实现人像磨皮及小伙伴们所想为小伙伴带来一款全新的插件视频磨皮插件Beautybox(含WIN&MAC版本)支持PR\AECS6-CC2020或更高版本支持FCPX10.1.2或更高版本【插件介绍】▼它是人像润色磨皮滤镜,用于人像图片润色,磨.

    2022年7月22日
    36
  • 前端人员该怎么面试 经典Angular面试题有哪些[通俗易懂]

    前端人员该怎么面试 经典Angular面试题有哪些[通俗易懂]前端人员该怎么面试?经典Angular面试题有哪些?AngularJS是一个JavaScript框架,是一个以JavaScript编写的库。它可通过1、解释Angular2应用程序的生命周期hooks是什么?Angular2组件/指令具有生命周期事件,是由@angular/core管理的。@angular/core会创建组件,渲染它,创建并呈现它的后代。当@angular/core的数据绑定…

    2022年10月17日
    2
  • jsp include参数传送接收与应用

    jsp include参数传送接收与应用jspinclude参数传送接收与应用

    2022年7月15日
    16
  • convert dynamic命令在win10不可用_对目标文件系统,文件win7.gho过大

    convert dynamic命令在win10不可用_对目标文件系统,文件win7.gho过大全平台通过Termius,你可以安卓、Windows、macOS、Linux下来连接你的服务器,并且会在不同设备间同步,电脑做着做着要离开,换手机接着做官网链接:界面UI非常细腻win上面有xsheel,个人感觉xsheel更加强大。但是他不做Mac版本。由于在Mac上面用过Termius,所以习惯了他的界面。想要在win上面也用Termius汉化:手动方式打开当前这个js文件目录下面的这个js文件。然后全局搜索进行修改,但是一个一个改感觉麻烦创建一个termius.ini的文件,把下面这些复制进去

    2025年7月21日
    0
  • String字符串截取几种方法

    String字符串截取几种方法String截取字符串publicstaticvoidmain(String[]args){ Stringa="abcd-efg"; Stringa1=a.substring(a.lastIndexOf("-")+1); Stringa2=a.substring(0,a.indexOf("-")); System.out.println(a1);//efg …

    2022年5月19日
    51
  • 为什么从Java开发转测试?

    为什么从Java开发转测试?前言很多粉丝关注我可能是从乐优商城项目关注的,这确实是我曝光度最高的一篇blog了包括现在新增的粉丝的话也是从乐优商城项目blog关注的ps:大家有询问我要源码,我以前是有上传到github上的,但是由于里面用到了阿里云,github天天给我发邮件报警说有风险,然后我就删除了,所以源码的话,现在是没有了的但是我觉得乐优商城过于大,用的技术栈也很多,如果面试的时候不能充分讲明白的话,尽量不要用这个项目去面试大家如果要用他面试的话可以从以下几个思路去讲1、整体是一个什么项目?主体业务流程是什么

    2022年7月16日
    13

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号