站长资源网页制作

利用CSS中的 outline-offset 属性实现加号

整理:jimmy2025/1/11浏览2
简介假设有这么一个初始代码:</div> <div class="news_infos"><div id="MyContent"><p>假设有这么一个初始代码:</p> <div class="htmlcode"> <pre class="brush:css;"> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> div { margin-left: 100px; margin-top: 100px; padding: 0; width: 200px; height: 200px; background-color: green; outline: 20px solid #000; outline-offset: 10px; } </style> </head> <body> <div></div> </body> </html></pre> </div> <p>其效果如下:</p> <p><a href="javascript:;" onclick="showimg('/UploadFiles/2021-03-30/2020041716014379.png');"><img src="/UploadFiles/2021-03-30/2020041716014379.png" alt="利用CSS中的 outline-offset 属性实现加号" onmousewheel="return bbimg(this)" onload="javascript:resizepic(this)" border="0"/></a></p> <p>然后再把这个outline-offset属性的值改为-118px,那么就会把边框变成一个加号 当然我这里为了效果显著一些,我加了一个动画效果来显示,如下代码:</p> <div class="htmlcode"> <pre class="brush:css;"> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> div { margin-left: 100px; margin-top: 100px; padding: 0; width: 200px; height: 200px; background-color: green; outline: 20px solid #000; animation: move 3s infinite; } @keyframes move { 0% { outline-offset: 10px; } 100% { outline-offset: -118px; } } </style> </head> <body> <div></div> </body> </html></pre> </div> <p>其效果如下:</p> <p><a href="javascript:;" onclick="showimg('/UploadFiles/2021-03-30/2020041716014480.gif');"><img src="/UploadFiles/2021-03-30/2020041716014480.gif" alt="利用CSS中的 outline-offset 属性实现加号" onmousewheel="return bbimg(this)" onload="javascript:resizepic(this)" border="0"/></a></p> <p><strong><em>使用outline-offset做加号的总结</em></strong></p> <p>我觉得这个很有意思,在这里我试了很多次,在这里我总结了一下使用outline-offset属性负值的条件:</p> <ul> <li>容器必须是个正方形</li> <li>outline 边框本身的宽度不能太小</li> <li>outline-offset 负值 x 的取值范围为: -(容器宽度的一半 + outline宽度的一半) < x < -(容器宽度的一半 + outline宽度)</li> </ul> <p>在这个例子后,我又在想,CSS 属性可以取负值的属性和地方有很多,也有许多意想不到的效果。大家最为熟知的就是负margin,使用负的 marign,可以用来实现类似多列等高布局、垂直居中等等。那还有没有其他一些有意思的负值使用技巧呢?</p> <p>下文就再介绍一些 CSS 负值有意思的使用场景。</p> <p><strong>使用 scale(-1) 实现翻转</strong></p> <p>通常,我们要实现一个元素的 180° 翻转,我们会使用 <code>transform: rotate(180deg)</code> ,这里有个小技巧,使用  <code>transform: scale(-1)</code> 可以达到同样的效果。看个 Demo:</p> <div class="htmlcode"> <pre class="brush:css;"> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> .g_container { position: absolute; margin: 100px 0 0 500px; } .item { width: 100px; height: 100px; background-color: green; position: relative; border-radius: 50%; } .item { transform: rotate(0) translate(-80px, 0) ; } .item:nth-child(1) { animation: rotate 3s infinite linear; } .item:nth-child(2) { animation: rotate 3s infinite 1s linear; } .item:nth-child(3) { animation: rotate 3s infinite 2s linear; } @keyframes rotate { 100% { transform: rotate(360deg) translate(-80px, 0) ; } } </style> </head> <body> <div class="g_container"> <div class="item"></div> <div class="item"></div> <div class="item"></div> </div> </body> </html></pre> </div> <p>看看效果:</p> <p><a href="javascript:;" onclick="showimg('/UploadFiles/2021-03-30/2020041716014481.gif');"><img src="/UploadFiles/2021-03-30/2020041716014481.gif" alt="利用CSS中的 outline-offset 属性实现加号" onmousewheel="return bbimg(this)" onload="javascript:resizepic(this)" border="0"/></a></p> <p>当然,如果想要让三个球同时运动,去掉这个延迟,那么可以改成这样的代码:</p> <div class="htmlcode"> <pre class="brush:css;"> .item:nth-child(1) { animation: rotate 3s infinite linear; } .item:nth-child(2) { animation: rotate 3s infinite -1s linear; } .item:nth-child(3) { animation: rotate 3s infinite -2s linear; }</pre> </div> <p>其效果我就不说了,就是同时运动,可参照上面的那个效果</p> <p><strong>负值 margin</strong></p> <p>负值 margin 在 CSS 中算是运用的比较多的,元素的外边距可以设置为负值。</p> <p>在 flexbox 布局规范还没流行之前,实现多行等高布局还是需要下一番功夫的。其中一种方法便是使用正 padding 负 margin 相消的方法。</p> <p>有如下一个布局:</p> <p><a href="javascript:;" onclick="showimg('/UploadFiles/2021-03-30/2020041716014482.png');"><img src="/UploadFiles/2021-03-30/2020041716014482.png" alt="利用CSS中的 outline-offset 属性实现加号" onmousewheel="return bbimg(this)" onload="javascript:resizepic(this)" border="0"/></a></p> <p>左右两栏的内容都是不确定的,也就是高度未知。但是希望无论左侧内容较多还是右侧内容较多,两栏的高度始终保持一致。</p> <p>OK,其中一种 Hack 办法便是使用一个很大的正 padding 和相同的负 margin 相消的方法填充左右两栏:</p> <div class="htmlcode"> <pre class="brush:css;"> .left { ... padding-bottom: 9999px; margin-bottom: -9999px; } .right { ... padding-bottom: 9999px; margin-bottom: -9999px; }</pre> </div> <p>可以做到无论左右两栏高度如何变化,高度较低的那一栏都会随着另外一栏变化。</p> <p>总结一下</p> <p>除了这些,还有很多的属性,例子没有列出来(因作者的水平和时间有限),例如:</p> <ul> <li>使用负 marign 实现元素的水平垂直居中</li> <li>使用负 marign隐藏列表 li 首尾多余的边框</li> <li>使用负 text-indent 实现文字的隐藏</li> <li>使用负的 z-index 参与层叠上下文排序</li> </ul> <p><strong>总结</strong></p></div> </div> </div> <div class="share"> </div> <div class="nextinfo"> <p>上一篇:<a href="/3g/1/70464.html" title="用CSS播放声音的几种技巧方法">用CSS播放声音的几种技巧方法</a></p> <p>下一篇:<a href="/3g/1/70466.html" title="通过iframe监听一个DOM元素大小变化">通过iframe监听一个DOM元素大小变化</a></p> </div> <div class="otherlink"> <h2>最新资源</h2> <ul> <li><a href="/3g/1/623703.html" title="群星《奔赴!万人现场 第2期》[FLAC/分轨]">群星《奔赴!万人现场 第2期》[FLAC/分轨]</a></li> <li><a href="/3g/1/623702.html" title="群星《奇妙浪一夏 (上海迪士尼度假区音乐">群星《奇妙浪一夏 (上海迪士尼度假区音乐</a></li> <li><a href="/3g/1/623701.html" title="群星《奇妙浪一夏 (上海迪士尼度假区音乐">群星《奇妙浪一夏 (上海迪士尼度假区音乐</a></li> <li><a href="/3g/1/623700.html" title="【古典音乐】詹姆斯·高威《季节》1993[WA">【古典音乐】詹姆斯·高威《季节》1993[WA</a></li> <li><a href="/3g/1/623699.html" title="贝拉芳蒂《卡里普索之王》SACD[WAV+CUE]">贝拉芳蒂《卡里普索之王》SACD[WAV+CUE]</a></li> <li><a href="/3g/1/623698.html" title="小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE">小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE</a></li> <li><a href="/3g/1/623697.html" title="群星《欢迎来到我身边 电影原声专辑》[32">群星《欢迎来到我身边 电影原声专辑》[32</a></li> <li><a href="/3g/1/623696.html" title="群星《欢迎来到我身边 电影原声专辑》[FL">群星《欢迎来到我身边 电影原声专辑》[FL</a></li> <li><a href="/3g/1/623695.html" title="雷婷《梦里蓝天HQⅡ》 2023头版限量编号低">雷婷《梦里蓝天HQⅡ》 2023头版限量编号低</a></li> <li><a href="/3g/1/623694.html" title="群星《2024好听新歌42》AI调整音效【WAV分">群星《2024好听新歌42》AI调整音效【WAV分</a></li> </ul> </div> </div> <div class="sidebar"> <div class="cloud"><h2 class="hometitle">一句话新闻</h2><a href="/3G/1/604673.html"><ul>微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键<br><br>几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。<br>在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。</ul></a></div> </div> <div class="sidebar"> 友情链接:<a href="http://www.imxmx.com/" title="杰晶网络" target="_blank">杰晶网络</a> <a href="/" title="DDR爱好者之家" target="_blank">DDR爱好者之家</a> <a href="http://www.nqxw.com/" title="南强小屋" target="_blank">南强小屋</a> <a href="http://www.paidiu.com/" title="黑松山资源网" target="_blank">黑松山资源网</a> <a href="http://www.dyhadc.com/" title="白云城资源网" target="_blank">白云城资源网</a> <a href="/sitemap1.xml">站点地图</a> <a href="/sitemap.xml">SiteMap</a> </div> </article> <footer> <p>Design by <a href="http://m.ddrfans.com">DDR爱好者之家</a> <a href="http://m.ddrfans.com">http://m.ddrfans.com</a></p> </footer> <script src="/images3g/nav.js"></script> <script type="text/javascript"> jQuery.noConflict(); jQuery(function() { var elm = jQuery('#left_flow2'); var startPos = jQuery(elm).offset().top; jQuery.event.add(window, "scroll", function() { var p = jQuery(window).scrollTop(); jQuery(elm).css('position', ((p) > startPos) ? 'fixed' : ''); jQuery(elm).css('top', ((p) > startPos) ? '0' : ''); }); }); </script> </body> </html>