1

10px by 10pxバブルの右側に矢印を作成しようとしていますが、矢印が表示されません。これまでのところ、私は持っています:

CSS:

.pageHelp{
    float:right;
    margin:10px 20px 0 0;
    width:85px;
    height:25px;
    background-color:#354E69;
    border-radius:3px;
}
.pageHelp:before{
    content:"";
    position:absolute;
    right:100%;
    top:26px;
    width:0;
    height:0;
    border-top:13px solid transparent;
    border-right:26px solid #354E69;
    border-top:13px solid transparent;
}

HTML:

<div class="pageHelp"><p>In Page Help</p></div>

ルイス:

.pageHelp{
    float:right;
    margin:10px 20px 0 0;
    width:85px;
    height:25px;
    background-color:#354E69;
    border-radius:3px;
    position: relative;
}
.pageHelp:after, .pageHelp:before {
    left: 100%;
    border: solid transparent;
    content: " ";
    height: 0;
    width: 0;
    position: absolute;
    pointer-events: none;
}
.pageHelp:after {
    border-left-color: #354E69;
    border-width: 10px;
    top: 50%;
    margin-top: -10px;
}
.pageHelp:before {
    border-left-color: ##354E69;
    border-width: 16px;
    top: 50%;
    margin-top: -16px;
}
4

3 に答える 3

4

このフレンドリーなcss-arrow-maker-helpを使ってみることができます

于 2012-05-28T21:40:19.783 に答える
2

指定する必要があります

position: relative;

あなたの.pageHelpクラスで; それ以外の場合、position: absoluteコンテンツの:beforeはそれを参照しません。

また、border-top2 回指定しました。そのうちの 1 つがborder-bottom.

これらの 2 つを修正すると、少なくとも div の横に三角形が表示されるはずです。

ここでの作業モックアップ: http://jsfiddle.net/Nzazm/

于 2012-05-28T21:01:19.950 に答える
1

多分これが役立つかもしれません:http://jsfiddle.net/EkaMc/

最初に追加position:relativeするのは.pageHelp

.pageHelp{
    [...]
    position:relative;
}

これは、矢印をバブルに対して相対的に配置するのに役立ちます。

次に、疑似要素については、を使用することから始めることをお勧めしますcontent:" "。コンテンツなしで疑似要素のスタイルを設定しようとして不運に見舞われましたが、その理由は正確にはわかりません。おそらく、より経験豊富なユーザーが明確にするのに役立ちます。

.pageHelp:before{
    [...]
    content:" ";
}

矢印right:100%をスタイリングすると、バブルの左端にぶつかります。さらに、 を設定しないposition:relative;と、矢印が強制的にページからはみ出してしまいます。

.pageHelp:before{
    content:" ";
    position:absolute;
    right:-23px;
    top:6px;
    width:0;
    height:0;
    border-top:7px solid transparent;
    border-left:13px solid #354E69;
    border-bottom:7px solid transparent;
    border-right:13px solid transparent;
}​

境界線のサイズを試してみて、何がうまくいくかを確認してください。

于 2012-05-28T21:03:34.107 に答える