How to increase space between dotted border dots

Go To StackoverFlow.com

241

I am using dotted style border in my box like

.box {
    width: 300px;
    height: 200px;
    border: dotted 1px #f00;
    float: left;
}

I want to the increase the space between each dot of the border.

2011-06-06 10:00
by Kali Charan Rajput


356

This trick works for both horizontal and vertical borders:

/*Horizontal*/
background-image: linear-gradient(to right, black 33%, rgba(255,255,255,0) 0%);
background-position: bottom;
background-size: 3px 1px;
background-repeat: repeat-x;

/*Vertical*/
background-image: linear-gradient(black 33%, rgba(255,255,255,0) 0%);
background-position: right;
background-size: 1px 3px;
background-repeat: repeat-y;

You can adjust the size with background-size and the proportion with the linear-gradient percentages. In this example I have a dotted line of 1px dots and 2px spacing. This way you can have multiple dotted borders too using multiple backgrounds.

Try it in this JSFiddle or take a look at the code snippet example:

div {
  padding: 10px 50px;
}
.dotted {
  border-top: 1px #333 dotted;
}
.dotted-gradient {
  background-image: linear-gradient(to right, #333 40%, rgba(255, 255, 255, 0) 20%);
  background-position: top;
  background-size: 3px 1px;
  background-repeat: repeat-x;
}
.dotted-spaced {
  background-image: linear-gradient(to right, #333 10%, rgba(255, 255, 255, 0) 0%);
  background-position: top;
  background-size: 10px 1px;
  background-repeat: repeat-x;
}
.left {
  float: left;
  padding: 40px 10px;
  background-color: #F0F0DA;
}
.left.dotted {
  border-left: 1px #333 dotted;
  border-top: none;
}
.left.dotted-gradient {
  background-image: linear-gradient(to bottom, #333 40%, rgba(255, 255, 255, 0) 20%);
  background-position: left;
  background-size: 1px 3px;
  background-repeat: repeat-y;
}
.left.dotted-spaced {
  background-image: linear-gradient(to bottom, #333 10%, rgba(255, 255, 255, 0) 0%);
  background-position: left;
  background-size: 1px 10px;
  background-repeat: repeat-y;
}
<div>no
  <br>border</div>
<div class='dotted'>dotted
  <br>border</div>
<div class='dotted-gradient'>dotted
  <br>with gradient</div>
<div class='dotted-spaced'>dotted
  <br>spaced</div>

<div class='left'>no
  <br>border</div>
<div class='dotted left'>dotted
  <br>border</div>
<div class='dotted-gradient left'>dotted
  <br>with gradient</div>
<div class='dotted-spaced left'>dotted
  <br>spaced</div>

2013-08-05 17:52
by Eagorajose
Should be the selected answer - Kevin Jurkowski 2014-05-06 21:21
Used this answer to do the following pen: http://codepen.io/Elyx0/pen/bLld - Elyx0 2014-08-27 19:00
@Elyx0 Awesome - Eagorajose 2014-08-28 13:22
Wow, that is sweet. For horizontal line pretty easy to add to an :after definition - bloke_zero 2015-05-07 15:53
imho it's a hack of n degree - Muhammad Umer 2015-06-06 17:12
I want to do the same thing but dotted border width is 3px rather than 1px and now it becomes square rather than dotted - Bhojendra Rauniyar 2015-06-08 06:10
I've made a SCSS mixin to implement this and change colors and spacing quickly. Check it out at https://github.com/florbraz/Dotted-Border-w-custom-spacing-SCSS-Mixin - Flor Braz 2015-08-31 21:13
@FlorBraz – thx for the scss mixin. Just had to convert the color location number to percent to get it working in chrome.. - Kjell 2015-12-12 09:22
@MuhammadUmer So, iyho what's the non-hacky way of doing this - AndyJ 2017-12-06 16:27
This answer is genius. This is perfect for progress/status bars in video games - Joe Leonard 2018-05-14 16:21
This hack is wrong for one wanting to generate PDFs with tables using such borders. It makes one page table PDF weight 2.5 MB (generated with Chrome 66.0.3359.170), where using regular dashed borders (eg. border:1px dashed black) makes file only 40 kB of size - Marecky 2018-05-16 12:11
What if I want all 4 edges dashed - Ryan Shillington 2018-06-13 13:53
can you do 2 or more borders of a cell using this trick - Kunal 2018-10-05 20:24
I have now added an answer which uses radial-gradient in order to get round dots. Also, it can be applied on all four sides/edges - Marten Koetsier 2018-11-21 08:47


136

Here's a trick I've used on a recent project to achieve nearly anything I want with horizontal borders. I use <hr/> each time I need an horizontal border. The basic way to add a border to this hr is something like

 hr {border-bottom: 1px dotted #000;}

But if you want to take control of the border and, for example increase, the space between dots, you may try something like this:

hr {
height:14px; /* specify a height for this hr */
overflow:hidden;
}

And in the following, you create your border (here's an example with dots)

hr:after {
content:".......................................................................";
letter-spacing: 4px; /* Use letter-spacing to increase space between dots*/
}

This also means that you can add text-shadow to the dots, gradients etc. Anything you want...

Well, it works really great for horizontal borders. If you need vertical ones, you may specify a class for another hr and use the CSS3 rotation property.

2012-08-09 17:54
by Matt
Is this cross-browser compatible - J82 2013-05-31 21:52
I can't imagine what a pain in the a** that would be to maintain - Kzqai 2013-09-04 22:24
how to get same effect for vertical one - Rinku 2013-11-25 07:47
@Rinku with transform:rotate(90deg); display:block - Jeroen K 2013-12-27 09:20
so ugly, but so clever :) I also notice that I can have finer control over placement if I set height:0; and use padding to control placement. So I wanted the dotted line on the bottom with a little room below so I used padding: 0 0 10px - MatthewLee 2014-03-22 21:44
@Rinku See answer below for vertical border without extra HTM - Eagorajose 2014-03-29 16:27
can't really calculate how much dots I need for responsive layou - Raptor 2014-08-06 08:47
@Raptor How to allow for any text size: [link] (https://jsfiddle.net/rd5v0qa6/3/ - justinsAccount 2015-05-10 23:15
-1. This hack will make things much more difficult for responsive web design. The background-image gradient trick is a much better practice, so that one should become the accepted answer - Jeremy Moritz 2015-05-18 14:47
To make it responsive:

hr {border: none; overflow: hidden; max-width: 1145px; /* or whatever you need */ width: 100%; }iorgu 2017-02-03 10:36

Or increase the border-width: border: 2px solid greenMarian07 2018-12-05 00:54


116

You cannot do it with pure CSS - the CSS3 spec even has a specific quote about this:

Note: There is no control over the spacing of the dots and dashes, nor over the length of the dashes. Implementations are encouraged to choose a spacing that makes the corners symmetrical.

You can, however, use either a border-image or a background image that does the trick.

2011-06-06 10:06
by Shadikka
You may use gradients (pure CSS) for a fully customisable border. See answer belo - Eagorajose 2014-03-29 16:04
-1, @Shadikka, What the CSS3 spec says is that it cannot be done using border: dotted, but it is possible to do it using gradients as Eagorajose's answer has shown - Pacerier 2014-09-18 13:58


17

See the MDN docs for the available values for border-style:

  • none : No border, sets width to 0. This is the default value.
  • hidden : Same as 'none', except in terms of border conflict resolution for table elements.
  • dashed : Series of short dashes or line segments.
  • dotted : Series of dots.
  • double : Two straight lines that add up to the pixel amount defined as border-width.
  • groove : Carved effect.
  • inset : Makes the box appear embedded.
  • outset : Opposite of 'inset'. Makes the box appear 3D (embossed).
  • ridge : Opposite of 'groove'. The border appears 3D (coming out).
  • solid : Single, straight, solid line.

Apart from those choices, there is no way to influence the standard border's style.

If the possibilities there are not to your liking, you could use CSS3's border-image but note that browser support for this is still very spotty.

2011-06-06 10:03
by Pekka 웃
thanks pekka, that mean i can't use border property ... so i have to use image for it - Kali Charan Rajput 2011-06-06 10:30
@kc if none of the border styles is to your liking, yes - Pekka 웃 2011-06-06 10:47


16

This uses the standard CSS border and a pseudo element+overflow:hidden. In the example you get three different 2px dashed borders: normal, spaced like a 5px, spaced like a 10px. Is actually 10px with only 10-8=2px visible.

div.two{border:2px dashed #FF0000}

div.five:before {
  content: "";
  position: absolute;
  border: 5px dashed #FF0000;
  top: -3px;
  bottom: -3px;
  left: -3px;
  right: -3px;
}

div.ten:before {
  content: "";
  position: absolute;
  border: 10px dashed #FF0000;
  top: -8px;
  bottom: -8px;
  left: -8px;
  right: -8px;
}

div.odd:before {left:0;right:0;border-radius:60px}

div {
  overflow: hidden;
  position: relative;


  text-align:center;
  padding:10px;
  margin-bottom:20px;
}
<div class="two">Kupo nuts here</div>
<div class="five">Kupo nuts<br/>here</div>
<div class="ten">Kupo<br/>nuts<br/>here</div>
<div class="ten odd">Kupo<br/>nuts<br/>here</div>

Applied to small elements with big rounded corners may make for some fun effects.

2016-10-15 01:44
by lenioia
Strong work! This is the only one of these answers that really works without being terrible to maintain, IMO. Even the accepted answer only works for one edge of the div. This works for the whole border - Ryan Shillington 2018-06-13 13:52


6

This is a really old question but it has a high ranking in Google so I'm going to throw in my method which could work depending on your needs.

In my case, I wanted a thick dashed border that had a minimal break in between dashes. I used a CSS pattern generator (like this one: http://www.patternify.com/) to create a 10px wide by 1px tall pattern. 9px of that is solid dash color, 1px is white.

In my CSS, I included that pattern as the background image, and then scaled it up by using the background-size attribute. I ended up with a 20px by 2px repeated dash, 18px of that being solid line and 2px white. You could scale it up even more for a really thick dashed line.

The nice thing is since the image is encoded as data you don't have the additional outside HTTP request, so there's no performance burden. I stored my image as a SASS variable so I could reuse it in my site.

2014-11-10 16:12
by Nick Angiolillo
Works for me! th - pztrick 2014-11-13 15:22


5

So starting with the answer given and applying the fact that CSS3 allows multiple settings - the below code is useful for creating a complete box:

#border {
  width: 200px;
  height: 100px;
  background: yellow;
  text-align: center;
  line-height: 100px;
  background: linear-gradient(to right, orange 50%, rgba(255, 255, 255, 0) 0%), linear-gradient(blue 50%, rgba(255, 255, 255, 0) 0%), linear-gradient(to right, green 50%, rgba(255, 255, 255, 0) 0%), linear-gradient(red 50%, rgba(255, 255, 255, 0) 0%);
  background-position: top, right, bottom, left;
  background-repeat: repeat-x, repeat-y;
  background-size: 10px 1px, 1px 10px;
}
<div id="border">
  bordered area
</div>

Its worth noting that the 10px in the background size gives the area that the dash and gap will cover. The 50% of the background tag is how wide the dash actually is. It is therefore possible to have different length dashes on each border side.

2018-05-16 10:33
by Ukuser32


2

Short answer: You can't.

You will have to use border-image property and a few images.

2011-06-06 10:04
by Crozin


2

IF you're only targeting modern browsers, AND you can have your border on a separate element from your content, then you can use the CSS scale transform to get a larger dot or dash:

border: 1px dashed black;
border-radius: 10px;
-webkit-transform: scale(8);
transform: scale(8);

It takes a lot of positional tweaking to get it to line up, but it works. By changing the thickness of the border, the starting size and the scale factor, you can get to just about thickness-length ratio you want. Only thing you can't touch is dash-to-gap ratio.

2013-12-06 19:16
by Dave
By doing so content will also gets applied scale(8)Pardeep Jain 2018-08-09 07:36


2

So many people are say "You can't". Yes you can. It's true that there is not a css rule to control the gutter space between the dashes but css has other abilities. Don't be so quick to say that a thing can not be done.

.hr {
    border-top: 5px dashed #CFCBCC;
    margin: 30px 0;
    position: relative;
}

.hr:before {
    background-color: #FFFFFF;
    content: "";
    height: 10px;
    position: absolute;
    top: -2px;
    width: 100%;
}

.hr:after {
    background-color: #FFFFFF;
    content: "";
    height: 10px;
    position: absolute;
    top: -13px;
    width: 100%;
}

Basically the border-top height (5px in this case) is the rule that determines the gutter "width". OIf course you would need to adjust the colors to match your needs. This also is a small example for a horizontal line, use left and right to make the vertical line.

2014-03-01 17:23
by devinfd
To be fair, I think most people are saying you can't do it to the literal question of adjusting the border dotted styling. They're not saying something similar isn't possible using other CSS properties. In my opinion it makes a lot more sense from a semantic point of view to use a background image or border-image as others have shown, than use pseudo elements and a dozen lines of CSS - Alex 2014-03-03 11:49


1

This is an old, but still very relevant topic. The current top answer works well, but only for very small dots. As Bhojendra Rauniyar already pointed out in the comments, for larger (>2px) dots, the dots appear square, not round. I found this page searching for spaced dots, not spaced squares (or even dashes, as some answers here use).

Building on this, I used radial-gradient. Also, using the answer from Ukuser32, the dot-properties can easily be repeated for all four borders. Only the corners are not perfect.

div {
    padding: 1em;
    background-image:
        radial-gradient(circle at 2.5px, #000 1.25px, rgba(255,255,255,0) 2.5px),
        radial-gradient(circle, #000 1.25px, rgba(255,255,255,0) 2.5px),
        radial-gradient(circle at 2.5px, #000 1.25px, rgba(255,255,255,0) 2.5px),
        radial-gradient(circle, #000 1.25px, rgba(255,255,255,0) 2.5px);
    background-position: top, right, bottom, left;
    background-size: 15px 5px, 5px 15px;
    background-repeat: repeat-x, repeat-y;
}
<div>Some content with round, spaced dots as border</div>

The radial-gradient expects:

  • the shape and optional position
  • two or more stops: a color and radius

Here, I wanted a 5 pixel diameter (2.5px radius) dot, with 2 times the diameter (10px) between the dots, adding up to 15px. The background-size should match these.

The two stops are defined such that the dot is nice and smooth: solid black for half the radius and than a gradient to the full radius.

2018-11-21 08:44
by Marten Koetsier


0

AFAIK there isn't a way to do this. You could use a dashed border or perhaps increase the width of the border a bit, but just getting more spaced out dots is impossible with CSS.

2011-06-06 10:03
by Bojangles


0

You could create a canvas (via javascript) and draw a dotted line within. Within the canvas you can control how long the dash and the space in between shall be.

2013-04-25 13:39
by velop
That is a very convoluted solution. I can't help but feel that this would also cost a tiny bit more in performance and perceived load times, depending on the weight of the rest of the JS on the page - Emmett R. 2016-05-24 16:48


0

Building 4 edges solution basing on @Eagorajose's answer with shorthand syntax:

background: linear-gradient(to right, #000 33%, #fff 0%) top/10px 1px repeat-x, /* top */
linear-gradient(#000 33%, #fff 0%) right/1px 10px repeat-y, /* right */
linear-gradient(to right, #000 33%, #fff 0%) bottom/10px 1px repeat-x, /* bottom */
linear-gradient(#000 33%, #fff 0%) left/1px 10px repeat-y; /* left */

#page {
    background: linear-gradient(to right, #000 33%, #fff 0%) top/10px 1px repeat-x, /* top */
    linear-gradient(#000 33%, #fff 0%) right/1px 10px repeat-y, /* right */
    linear-gradient(to right, #000 33%, #fff 0%) bottom/10px 1px repeat-x, /* bottom */
    linear-gradient(#000 33%, #fff 0%) left/1px 10px repeat-y; /* left */
    
    width: 100px;
    height: 100px;
}
<div id="page"></div>

2018-11-14 21:54
by Aleksander Stelmaczonek


0

<div style="width: 100%; height: 100vh; max-height: 20px; max-width: 100%; background: url('https://kajabi-storefronts-production.global.ssl.fastly.net/kajabi-storefronts-production/themes/853636/settings_images/Ei2yf3t7TvyRpFaLQZiX_dot.jpg') #000; background-repeat: repeat;">&nbsp;</div>

this is what I did - use an image enter image description here

2019-02-21 14:49
by Christine Nicole Yu
Ads