css3で0.5pxの細い線を作成した例を共有します

小云云
リリース: 2018-01-19 09:47:21
オリジナル
1756 人が閲覧しました

この記事では、CSS3を使用して0.5pxの細い線を作成するサンプルコードに関する情報を中心に紹介します。編集者が非常に優れていると考えたので、参考として共有します。エディターをフォローして見てみましょう

Webapp の CSS3 は 0.5px の細い線を実装しています

最近ブログ生活が比較的安定してきたので、また書き始めなければなりません。いつか忘れてしまい、ブログを見返してまた思い出してしまうのではないかと心配なので、記録を残すことです。それだけです。

淘宝網、JD.com、Yixun、Yihaodian などの電子商取引サイトのモバイル サイトを見てきましたが、これらの大手電子商取引サイトの共通の特徴は、レイアウトの点で優れた仕上がりと優れたユーザー エクスペリエンスです。この線は 1px の線よりもはるかに洗練されています。

方法 1: グラデーションを使用して実行します

html コード:


<p></p>
ログイン後にコピー
ログイン後にコピー

css コード:


.bd-t{
  position:relative;
}

.bd-t::after {
  content: " ";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(0deg, transparent 50%, #e0e0e0 50%);
}
ログイン後にコピー

ここには落とし穴があることに注意してください。 ! ! :

さまざまなブラウザとの互換性を確保するには、次のような異なるプレフィックスを使用する必要があります:


-webkit-linear-gradient
-ms-linear-gradient 
-o-linear-gradient
ログイン後にコピー

これらのプレフィックスに落とし穴があります: コード内の高さ 1px を 100px に変更し、パラメータは < と同じです。 code>0deg、transparent 50%、#e0e0e0 50% を選択し、最新バージョンの Chrome を使用してテストします。 0deg, transparent 50%, #e0e0e0 50% 并使用最新版的chrome来测试 。

linear-gradient 有如下结果:

经过一系列的测试总结,我们可以推理出下面的渐变方式:

webkit-linear-gradient 的代码效果图如下:

经总结,我们看到-webkit前缀的渐变方式为:

其他的前缀如果用到,还请小伙伴们自己来尝试填坑!

说明:

推荐这种写法,这是百度糯米移动站的做法(如果没改版的话):http://m.nuomi.com/ ,从上述代码的描述中,可以看到,为了实现盒子顶部边框0.5px的伪代码:border-top:0.5px solid #e0e0e0; 的效果,使用after,作为一个钩子,宽度100%,高度1px,背景渐变,一半透明,一半有颜色,这么干是可以的。同理,底部,左边和右边的细线,都是同一个道理了。当然,如果需要组合使用,盒子之间的嵌套使用,也是可以的,或者你有自己的想法(当然做法有很多种!)…

方式二: 使用缩放

html代码:


<p></p>
ログイン後にコピー
ログイン後にコピー

css代码:


.bd-t{
  position:relative;
}

.bd-t:after{
  content: "  ";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 1px;
  background-color: #e0e0e0;
  /* 如果不用 background-color, 使用 border-top:1px solid #e0e0e0; */
  -webkit-transform: scaleY(.5);
  transform:scaleY(.5);
}
ログイン後にコピー

说明

这是实现盒子上边框0.5px的做法, 不是很推荐这种做法,因为经过测试,一些手机端浏览器显示的不是太好。这种实现的原理是: 在Y轴方向上,压缩一半。就像上面注释的那样。
如果你觉得效果不太好,这里有一个 fallback or workaround, whatsoever: 就是上面注释掉的那种做法:可以尝试使用border-top:1px solid #e0e0e0; 代替background-color的做法,京东就是这么做的(如果没改版的话): http://m.jd.com/

方式二的拓展 : 如果要实现四周全是0.5px的线条的话 :

html代码:


<p class=&#39;bd-all&#39;></p>
ログイン後にコピー

css代码:


  .bd-all{
      position:relative;
  }

 .bd-all:after{
      content: "  ";
      position: absolute;
      left: 0;
      top: 0;
      z-index:-1;
      width: 200%;
      height:200%;
      border:1px solid #e0e0e0;
      -webkit-transform-origin: 0 0;
      transform-origin: 0 0;
      -webkit-transform: scale(.5, .5);
      transform: scale(.5, .5);
 }
ログイン後にコピー

说明 :

这是实现一个盒子四周0.5px的做法, 如果加入border-radius圆角效果,会发现,有些手机会有圆角发虚的情况,不过影响不是很大。如果有两个盒子,上面一个盒子没有边框效果,下面盒子有边框效果,两个盒子一样宽,上下在一起的布局方式,你会发现,在手机上有时候会对不齐… 错开了0.5px,原因已经很明了了…还有那个z-index

linear-gradient の結果は次のとおりです:

一連のテストの要約の後、次の勾配法を推定できます: <p></p>


webkit-linear-gradient コードのレンダリングは次のとおりです:

要約すると、-webkit プレフィックスの勾配メソッドが次のとおりであることがわかります:


他の接頭辞が使用されている場合は、自分で穴を埋めてみてください。 <p></p>注:


これは、Baidu Nuomi モバイル ステーションのアプローチです (改訂されていない場合): http://m.nuomi.com/。ボックスの上枠 0.5px の疑似コードを実現するには、次のことを確認してください: border-top: 0.5px Solid #e0e0e0; 効果は、フックとして after を使用し、幅 100%、高さ 1px、背景のグラデーション、半分透明、半分 色がある場合は、これを行うことができます。同様に、下左右の細い線も同じです。もちろん、組み合わせて使用​​する必要がある場合は、ボックス間のネストも可能です。または、独自のアイデアがあります (もちろん、方法はたくさんあります!)...

<p></p>方法 2: ズームを使用する

html コード: <p></p> <p></p>
├─demo/ ························ demo 目录
        └─┬─ test.html  ··············· test.html 文件
        └─── pic.png ·················· png 图片文件
ログイン後にコピー
🎜 css コード: 🎜🎜🎜🎜
<p class="bd-t"></p>
ログイン後にコピー
🎜手順🎜🎜 これは、ボックス上に 0.5 ピクセルの境界線を実現するためのアプローチです。テストの結果、一部のモバイル ブラウザーでは境界線が 0.5 ピクセルになるため、このアプローチはあまりお勧めできません。うまく表示されません。この実装の原理は、Y 軸方向に半分を圧縮することです。上で述べたように。 🎜効果があまり良くないと思われる場合は、フォールバックまたは回避策を以下に示します。これは上記でコメントアウトされた方法です。border-top:1px Solid #e0e0e0; を使用してみてください。背景色の代わりに これは JD のやり方です (改訂されていない場合): http://m.jd.com/🎜🎜🎜 方法 2 の拡張: 周囲に 0.5px の線を実現したい場合: 🎜 🎜🎜html コード: 🎜🎜🎜🎜
.bd-t{
   position: relative;
}
.bd-t::after {
content: " ";
position: absolute;
left: 0;
top: 0;
width: 100%;
border-top: 1px solid transparent;
/* 下面用 stretch 和 round 都可以 */
border-image: url(&#39;pic.png&#39;) 2 1 1 1 stretch; 
-webkit-border-image: url(&#39;pic.png&#39;) 2 1 1 1 stretch;
}
ログイン後にコピー
🎜 css コード: 🎜🎜🎜🎜
.weui-cell:before{
   content: " ";
   position: absolute;
   left: 0;
   top: 0;
   right: 0;
   height: 1px;
   border-top: 1px solid #D9D9D9;
   color: #D9D9D9;
   -webkit-transform-origin: 0 0;
   transform-origin: 0 0;
   -webkit-transform: scaleY(0.5);
   transform: scaleY(0.5);
}
ログイン後にコピー
ログイン後にコピー
🎜 説明: 🎜🎜これは、境界線の半径の角丸効果を追加すると、ボックスの周囲に 0.5 ピクセルを実現する方法です。一部の携帯電話では角が丸く薄くなっている場合がありますが、影響はそれほど大きくありません。ボックスが 2 つある場合、上のボックスには境界線の効果がなく、下のボックスには境界線の効果があり、2 つのボックスは同じ幅で上下が重なって配置されないことがあります。携帯電話...それらは0.5ピクセルずつずらされています、その理由はすでに非常に明らかです...可能であれば、さまざまなニーズに応じて調整して使用できるz-indexもあります。使わなくても大丈夫です。 🎜🎜🎜方法 3: 背景画像と CSS3 を使用して 9 マスグリッドの切断🎜🎜🎜Jingdong は以前これを実行していましたが、現在は使用されていません。具体的な方法については、以下のデモ構造を参照してください。 🎜🎜🎜🎜rrreee🎜 test.html には次のキーコードがあります: 🎜🎜html 構造: 🎜🎜🎜🎜rrreee🎜 css 構造: 🎜🎜🎜🎜rrreee🎜 そしてpic.png 以下に示す 9 正方形グリッドの切断方法: 🎜🎜🎜🎜🎜 インターネット上には、border-image の具体的な使用法がたくさんあります: 🎜🎜 w3c のこれは、あまり具体的ではありません: http://www.jb51 .net/w3school/cssref/pr_border-image.htm🎜

在 MDN 上 有明确的介绍,并且有很多配图,包括兼容性等等:https://developer.mozilla.org/en-US/docs/Web/CSS/border-image

但是不推荐这种写法,毕竟图片质量比较大,能用代码解决的,不用图片。在这里border-width 是 1px , 但是 背景是有2px的距离,所以在1px的border-top上,显示出有颜色的高度就是0.5px, 同理,底边,左边和右边的0.5px,也都很容易实现。 这个就是css3的魅力体现(这个现在兼容性也不是很好,在一些较低端的安卓浏览器和一些版本的safari 支持的也不是很好)。

方式四 (推荐): weui的实现方式 :

这是一款微信团队开发的UI 组件 详情见: weui , 它的使用方式是这样的:


.weui-cell:before{
   content: " ";
   position: absolute;
   left: 0;
   top: 0;
   right: 0;
   height: 1px;
   border-top: 1px solid #D9D9D9;
   color: #D9D9D9;
   -webkit-transform-origin: 0 0;
   transform-origin: 0 0;
   -webkit-transform: scaleY(0.5);
   transform: scaleY(0.5);
}
ログイン後にコピー
ログイン後にコピー

方式五: 使用同周边相似的浅色,利用视觉效果,让用户产生错觉

这个就考验设计师的功力了 :)

其他说明:不是很推荐使用渐变来做 , 在移动设备上可以看到,但在一些浏览器上看不到,不便于调试。

相关推荐:

css3实现冲击波效果

css3绘制一个圆圆的loading转圈动画实例分享

CSS3中transform功能

以上がcss3で0.5pxの細い線を作成した例を共有しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!