• 前端研究CSS之内联元素块级化/区域大小/文字和图标的位置


    做了一天的小按钮基本都是文字+小图标的组合,问题挺多处理的不好,现在总结一下做个了断。

    //页面结构
    <span class="b">
      <a href="#" title="订阅博客">订阅博客</a>
      <em class="ico"></em>
    </span>

    其实结构可以很简单一个a元素设置padding-right或者padding-left的距离设置添加背景图标。

    但是这样的话用合并的背景图不好使,尤其是一个图标反复用在对应不同大小元素的时候,每次都需要对css做出调整,而且对背景图标的位置要很好的前期规划。

    这种父元素套文本和ico的方法虽然增加了dom数,但是开发和反复使用还是很方便的。

    两种方法,酌情选择。

    没有添加宽和高的内联元素

    仔细看看 没有一个浏览器是一样的

    inline-block之后的内联元素

    ie8有变化

    设置宽100px 高12px和inline-block之后的内联元素

    ie6没变化

    ie8还有点纠结

    最终方案

    IE6/IE8文本位置靠左1px

    IE8图标差1px

    最后我决定就到这了,有人肯定会说用通过hark能调整到最最完美,是的。

    可是文字图标的大小不同肯定还会有很多细微的变化,项目里的变化更是。。。

    想想明天还有很多工作要干,我决定先睡了。

    <!DOCTYPE HTML>
    <html>
    <head>
      <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
      <title>内联元素块级化文字和图标的位置</title>
      <style type="text/css">
      *{margin: 0;padding: 0;line-height: 1;}
      a{text-decoration: none;}
      a:hover{text-decoration: underline;}
      .ico{background: url(http://static.blog.csdn.net/images/ico_view.png) no-repeat;position: relative;display: inline-block;}
      .b{font-size: 12px;width:65px;height:12px;margin:200px auto;background-color: #ececec;border: 1px solid #ccc;text-align: center;margin-left: 20px;font-size: 0;display: inline-block;overflow: hidden;}
      .b a{font-size: 12px;}
      .b em{width: 10px;height: 10px;}
      </style>
    </head>
    <body style="padding-top:20px;">
      
    <span class="b">
      <a href="#" title="订阅博客">订阅博客</a>
      <em class="ico"></em>
    </span>
    </body>
    </html>

     

  • 相关阅读:
    置换笔记
    7.23
    Conveyor Belts
    CF #134 A~D
    Blocks && Fixing the Great wall
    Kakuro
    Deadlock Detection
    关于KeyFile的破解,含注册机源代码
    BMP位图之代码实现
    BMP位图之8位位图(三)
  • 原文地址:https://www.cnblogs.com/dtdxrk/p/3581523.html
Copyright © 2020-2023  润新知