2015-08-04 2 views
0

Я ищу, чтобы сделать треугольную кнопку в правом верхнем углу моего сайта (фиксированное положение). Это только значок поверх фона с эффектом зависания. Мне было интересно, есть ли способ получить угловой div или если это должно быть фоновое изображение?создание кнопки угла div

CSS

#top-btn { 
    position: fixed; 
    top: 0; 
    right: 0; 
    background-color: red; 
} 

HTML

... 

<div id="top-btn">icon</div> 

EDIT - визуальное представление. расположенный в правом верхнем углу окна

enter image description here

+1

возможно дублировать [Как работают треугольники CSS?] (http://stackoverflow.com/questions/7073484/how-do-css-triangle s-work) –

ответ

3

Обновлено для треугольника справа с повернутой текстом

Используйте границы трюк, чтобы создать треугольник в CSS: DEMO

HTML:

<div id="corner-triangle"> 
    <div class="corner-triangle-text"><a href="http://shop.mimijumi.com/" target="_blank"><span class="corner-triangle-firstline">Free</span><br>Shipping!</a></div> 
</div> 

CSS - комментарии для корректировки размера и цвета треугольника; Кроме того, удалить transform: rotate(45) линии, если вы не хотите, чтобы текст повернуты:

div#corner-triangle { 
    display: block; 
    width: 100px; 
    height: 100px; 
    border-style: solid; 
    border-width: 0 200px 200px 0; /* adjust for size of triangle */ 
    border-color: transparent #da0039 transparent transparent; /* adjust for color of triangle */ 
    position: fixed; 
    top: 0; 
    right: 0; 
    z-index: 99999; 
    color: white; 
    text-shadow: 0 0 25px 9px #fff; 
    -webkit-filter: drop-shadow(0 1px 9px #000000); 
    filter: drop-shadow(0 1px 9px #000000); 
} 
div#corner-triangle .corner-triangle-text { 
    position: relative; 
    font-size: 2.1em; 
    top: 0; 
    right: -90px; 
    font-family: sans-serif, "Helvetica Neue", Helvetica, Arial; 
    font-weight: 200; 
    line-height: 1.1; 
    -webkit-transform: rotate(45deg); 
    -moz-transform: rotate(45deg); 
    -ms-transform: rotate(45deg); 
    -o-transform: rotate(45deg); 
    transform: rotate(45deg); 
} 
div#corner-triangle .corner-triangle-text span.corner-triangle-firstline { 
    margin-left: 29px; 
} 
div#corner-triangle .corner-triangle-text a { 
    color: white; 
} 
div#corner-triangle .corner-triangle-text a:hover, 
div#corner-triangle .corner-triangle-text a:link, 
div#corner-triangle .corner-triangle-text a:visited, 
div#corner-triangle .corner-triangle-text a:active, 
div#corner-triangle .corner-triangle-text a:focus { 
    text-decoration: none; 
} 
+0

много кода для простой вещи, но ваша скрипка выглядит хорошо – user3550879

2

В принципе, вы создаете элемент с шириной и высотой нуля, и использовать границы для создания треугольников.

[enter image description here]

Эта статья разделяет некоторый код. https://css-tricks.com/snippets/css/css-triangle/

.arrow-down { 
    width: 0; 
    height: 0; 
    border-left: 20px solid transparent; 
    border-right: 20px solid transparent; 

    border-top: 20px solid #f00; 
} 
+0

К сожалению, это неправильный тип треугольника, который я ищу, я обновлю свой вопрос с помощью изображений, чтобы помочь поддержать мой вопрос. – user3550879

0

В зависимости от того, что вам нужно сделать с ним, легкий путь будет использовать символ вроде следующего: ▴

Вы не можете просто скопировать и вставить его, хотя. Для отображения этого символа используйте следующие коды:

&utrif; 

Это может не устраивать любую ситуацию, но я использовал ее. Это так же просто, как любой другой текст, и вы можете легко изменить его размер, применить к нему цвет, фон или тень, потому что это просто текст.

Вот список всех символов, которые можно использовать, в зависимости, конечно, от шрифта, который вы используете, который будет ограничением этого метода я думаю:

http://dev.w3.org/html5/html-author/charref

Другое ограничение будет если вы хотите разместить текст или значок поверх него. Я уверен, что это возможно, но есть лучшие методы, если это ваше намерение.

+0

С другой стороны, я предполагаю, что вы хотите, чтобы треугольник подходил в угол экрана, не так ли? В этом случае мой ответ бесполезен, но я оставлю его здесь как любопытство или в надежде, что, может быть, кто-то найдет его полезным. – gordonzed

+0

точно, что я ищу, вставляя в угол экрана – user3550879

1

Если вы спрашиваете, как сделать треугольник без использования изображения, есть эти HTML символов: ▲ &#9650; и ▼ &#9660;

Вы также можете сделать треугольники в CSS, сделав элемент с шириной и высотой ноль и дает ему границу только с 3 сторон, причем две стороны прозрачны.

.arrow-down { 
    width: 0; 
    height: 0; 
    border-left: 5px solid transparent; 
    border-right: 5px solid transparent; 
    border-top: 5px solid black; 
} 

Более подробно здесь https://css-tricks.com/snippets/css/css-triangle/

+0

Мне в основном нужен фон, чтобы быть треугольником, который не так много создал внутри div. Мне было интересно, можно ли это сделать без специального фонового изображения, поэтому я мог бы центрировать «значок» лучше, чем если бы это был полный квадрат – user3550879

2
.triangle { 
    border-width: 50px; 
    border-style: solid; 
    border-color: red red transparent transparent; 
    position: fixed; 
    top:0; 
    right:0; 
    width:0; 
    height:0; 
} 

Working fiddle.

1

Это то, что я придумал:

.corner{ 
    width: 0; 
    height: 0; 
    border-top: 50px solid rgb(227, 37, 37); 
    border-bottom: 50px solid transparent; 
    border-left: 50px solid transparent; 
    border-right:50px solid rgb(227, 37, 37); 
    float:right; 
} 

.corner:hover{ 
    border-color: #A00404 #A00404 transparent transparent; 
    transition: border-color 1s; 
} 

Here is the JSfiddle demo

+0

вопрос, хотя я могу поместите что-то внутри (значок/текст) и сохраните форму треугольника – user3550879

Смежные вопросы