CSSで背景としてテキストを使用する方法はありますか?


90

タグ内の特定の要素の背景としてダイナミックテキストを使用したいと思います。そのため、画像(ダイナミックテキスト)を使用できます。CSSまたはJavaScriptだけでどうすればよいですか?

回答:


81

相対配置要素内に絶対配置要素を含めることができます。

<div id="container">
    <div id="background">
    Text to have as background
    </div>
    Normal contents
</div>

そして、CSS:

#container {
   position: relative;
}

#background {
   position: absolute;
   top: 0;
   left: 0;
   bottom: 0;
   right: 0;
   z-index: -1;
   overflow: hidden;
}

以下はその例です


144

SVGテキスト背景画像

body {
    background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' height='50px' width='120px'><text x='0' y='15' fill='red' font-size='20'>I love SVG!</text></svg>");
}
<p>I hate SVG!</p><p>I hate SVG!</p><p>I hate SVG!</p><p>I hate SVG!</p>
<p>I hate SVG!</p><p>I hate SVG!</p><p>I hate SVG!</p><p>I hate SVG!</p>

これは、CSSのインデントバージョンであり、理解を深めることができます。これは機能しないことに注意してください。代わりに、上記のスニペットのシングルライナーSVGを使用する必要があります。

body {
  background-image:url("data:image/svg+xml;utf8,
  <svg xmlns='http://www.w3.org/2000/svg' version='1.1'
       height='50px' width='120px'>
    <text x='0' y='15' fill='red' font-size='20'>I love SVG!</text>
  </svg>");
}

これがどれほど移植可能か(Firefox 31とChrome 36で機能)はわかりません。技術的には画像ですが、ソースはインラインでプレーンテキストであり、無限に拡大縮小します。

@senectusは、base64でエンコードするとIEでよりうまく機能することを発見しました:https ://stackoverflow.com/a/25593531/895245


面白い。私はChromeのみ36またはSafariの7のFirefox 31で動作するようにこれを取得するが、ことができませんでした
JPリチャードソン

@JPRichardson True、同じです。Chrome 36では背景があるよう見えますが、非常に小さな文字です。多分私はいくつかの背景/ SVGサイズパラメータを設定するのを忘れていますか?
Ciro Santilli郝海东冠状病六四事件法轮功

ええ、私は今それを実験しています...多分「viewBox」のように見えますか?まだいじっています。
JPリチャードソン

1
Ciro:あなたの答えに基づいて、私はこれをまとめることができました...かなりうまくいきました!ありがとう!codepen.io/jprichardson/pen/GnxKr
JPリチャードソン

2
@CiroSantilli烏竜事件2016六四事件法轮功素晴らしい答え!Chromeでのレンダリングを改善する方法について何かアイデアはありますか?本当に悪いようです。事前の感謝
アレハンドロガルシアイグレシアス

46

:beforeまたは:after疑似要素を使用するCSSのみで可能です(ただし、非常にハック)。

.bgtext {
  position: relative;
}

.bgtext:after {
  content: "Background text";
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
<div class="bgtext">
  Foreground text
</div>

これは機能するようですが、おそらく少し調整する必要があります。また、がサポートされていないため、IE6では機能しません:after


更新:今のところ、すべての最新のブラウザーは疑似要素をサポートしています。たとえば、CSSアイコンに対してFontAwesomeが機能する方法です(インライン要素で:beforeを使用)。
セドリックフランソワ2016年

21

テキストを含むSVGデータURIの背景に関するCiroの解決策は非常に巧妙です。

ただし、単純なSVGソースをデータURIに追加しただけでは、IEで機能しません。

これを回避してIE9以降で機能させるには、SVGをbase64にエンコードします。これは素晴らしいツールです。

したがって、この:

background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg"><text x="5%" y="5%" font-size="30" fill="red">I love SVG!</text></svg>');

これになる:

background:url('');

テスト済みで、IE9-10-11、WebKit(Chrome 37、Opera 23)、Gecko(Firefox 31)で動作します。

http://jsfiddle.net/qapp5dLn/


1
これは優れたツールです。jpillora.com / base64 - encoder simpile、エラーなし、自動入力、画像プレビュー。うん、それは飛躍的に優れています。
Jack Giffin 2017

9

@Ciro

あなたはバックスラッシュでインラインsvgコードを壊すことができます "\"

Chrome 54およびFirefox 50で以下のコードでテスト済み

body {
    background: transparent;
    background-attachment:fixed;
    background-image: url(
    "data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='170px' height='50px'> \
    <rect x='0' y='0' width='170' height='50' style='stroke:white; fill:gray; stroke-opacity: 0.3; stroke-width: 3px; fill-opacity: 0.7; stroke-dasharray: 10 5; stroke-linecap=round; '/> \
    <text x='85' y='30' style='fill:lightBlue; text-anchor: middle' font-size='16' transform='rotate(10,85,25)'>I love SVG!</text></svg>");
}

私もこれをテストしました、

background-image: url("\
data:image/svg+xml;utf8, \
  <svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='170px' height='50px'> \
    <rect x='0' y='0' width='170' height='50'\
      style='stroke:white; stroke-width: 3px; stroke-opacity: 0.3; \
             stroke-dasharray: 10 5; stroke-linecap=round; \
             fill:gray;  fill-opacity: 0.7; '/> \
    <text x='85' y='30' \
      style='fill:lightBlue; text-anchor: middle' font-size='16' \
      transform='rotate(10,85,25)'> \
      I love SVG! \
    </text> \
  </svg>\
");

そしてそれは機能します(少なくともChrome 54とFirefox 50では==> NWjsとElectronでの使用が保証されています)


5

純粋なCSSの使用:

(ただし、HTMLメソッドが推奨される方法であるため、まれにこれを使用してください)。

.container{
	position:relative;
}
.container::before{ 
	content:"";
	width: 100%; height: 100%; position: absolute; background: black; opacity: 0.3; z-index: 1;  top: 0;   left: 0;
	background: black;
}
.container::after{ 
	content: "Your Text"; position: absolute; top: 0; left: 0; bottom: 0; right: 0; z-index: 3; overflow: hidden; font-size: 2em; color: red;    text-align: center; text-shadow: 0px 0px 5px black; background: #0a0a0a8c; padding: 5px;
	animation-name: blinking;
	animation-duration: 1s;
	animation-iteration-count: infinite;
	animation-direction: alternate;
}
@keyframes blinking {
	0% {opacity: 0;}
	100% {opacity: 1;}
}
<div class="container">here is main content, text , <br/> images and other page details</div>


2

bgテキストを含む要素に低いスタック順序(z-index、position)を設定し、場合によっては不透明度を設定することもできます。したがって、一番上に必要な要素にはより高いスタック順序(z-index:5; position:relative; for ex)が必要で、後ろの要素にはより低いものが必要です(デフォルトまたは3やposition:relativeのようなより低いz-indexのみ)。 ;)。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.