伙计们!我正在尝试将时间轴功能添加到部分中,但是我不明白为什么它不可以左移而只停留在中心?很抱歉,这么长的代码,但我无法仅将链接指向jsfiidle。您发现代码有什么问题吗?
我的html看起来像:
<section class="timeline">
<section class="container left">
<article class="content">
<h2>Year</h2>
<p>Line 1</p>
<p>Line 2</p>
</article>
</section>
<section class="container right">
<article class="content">
<h2>Year</h2>
<p>Line 1</p>
<p>Line 2</p>
</article>
</section>
和这样的CSS:
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
word-wrap: break-word;
}
html,
body,
section,
article {
height: 100%;
}
body {
background-color: #474e5d;
}
/* ----- Sections ----- */
section {
margin: 0.1em auto;
padding-top: 0.5em;
padding-bottom: 0.5em;
max-width: 960px;
}
/* --- Portfolio - timeline --- */
/* The actual timeline (the vertical ruler) */
.timeline {
border: 1px solid green;
position: relative;
height: auto;
overflow: hidden;
}
/* The actual timeline (the vertical ruler) */
.timeline::after {
content: '';
position: absolute;
width: 6px;
background-color: white;
top: 0;
bottom: 0;
left: 50%;
margin-left: -3px;
}
/* Container around content */
.container {
border: 1px solid green;
padding: 10px 40px;
position: relative;
background-color: inherit;
width: 50%;
}
/* The circles on the timeline */
.container::after {
content: '';
position: absolute;
width: 25px;
height: 25px;
right: -17px;
background-color: white;
border: 4px solid #FF9F55;
top: 15px;
border-radius: 50%;
z-index: 1;
}
/* Place the container to the left */
.left {
left: 0;
}
/* Place the container to the right */
.right {
left: 50%;
}
/* Add arrows to the left container (pointing right) */
.left::before {
content: " ";
height: 0;
position: absolute;
top: 22px;
width: 0;
z-index: 1;
right: 30px;
border: medium solid white;
border-width: 10px 0 10px 10px;
border-color: transparent transparent transparent white;
/* nuoli */
}
/* Add arrows to the right container (pointing left) */
.right::before {
content: " ";
height: 0;
position: absolute;
top: 22px;
width: 0;
z-index: 1;
left: 30px;
border: medium solid white;
border-width: 10px 10px 10px 0;
border-color: transparent white transparent transparent;
}
/* Fix the circle for containers on the right side */
.right::after {
left: -16px;
}
/* The actual content */
.content {
padding: 20px 30px;
background-color: white;
position: relative;
border-radius: 6px;
}
答案 0 :(得分:2)
您必须考虑元素本身的宽度。要解决此问题,请分别为每个.left
和.right
元素在x轴上添加一点平移。
/* Place the container to the left */
.left {
right: 50%;
transform: translateX(50%);
}
/* Place the container to the right */
.right {
left: 50%;
transform: translateX(-50%);
}
对于移动设备,您可以删除transform
和left
百分比。
@media screen and (max-width: 600px) {
.left,
.right {
transform: none;
left: 0;
}
}
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
html {
word-wrap: break-word;
}
html,
body,
section,
article {
height: 100%;
}
body {
background-color: #474e5d;
}
/* ----- Sections ----- */
section {
margin: 0.1em auto;
padding-top: 0.5em;
padding-bottom: 0.5em;
max-width: 960px;
}
/* --- Portfolio - timeline --- */
/* The actual timeline (the vertical ruler) */
.timeline {
border: 1px solid green;
position: relative;
height: auto;
overflow: hidden;
}
/* The actual timeline (the vertical ruler) */
.timeline::after {
content: '';
position: absolute;
width: 6px;
background-color: white;
top: 0;
bottom: 0;
left: 50%;
margin-left: -3px;
}
/* Container around content */
.container {
border: 1px solid green;
padding: 10px 40px;
position: relative;
background-color: inherit;
width: 50%;
}
/* The circles on the timeline */
.container::after {
content: '';
position: absolute;
width: 25px;
height: 25px;
right: -17px;
background-color: white;
border: 4px solid #FF9F55;
top: 15px;
border-radius: 50%;
z-index: 1;
}
/* Place the container to the left */
.left {
right: 50%;
transform: translateX(50%);
}
/* Place the container to the right */
.right {
left: 50%;
transform: translateX(-50%);
}
/* Add arrows to the left container (pointing right) */
.left::before {
content: " ";
height: 0;
position: absolute;
top: 22px;
width: 0;
z-index: 1;
right: 30px;
border: medium solid white;
border-width: 10px 0 10px 10px;
border-color: transparent transparent transparent white;
/* nuoli */
}
/* Add arrows to the right container (pointing left) */
.right::before {
content: " ";
height: 0;
position: absolute;
top: 22px;
width: 0;
z-index: 1;
left: 30px;
border: medium solid white;
border-width: 10px 10px 10px 0;
border-color: transparent white transparent transparent;
}
/* Fix the circle for containers on the right side */
.right::after {
left: -16px;
}
/* The actual content */
.content {
padding: 20px 30px;
background-color: white;
position: relative;
border-radius: 6px;
}
/* Media queries - Responsive timeline on screens less than 600px wide */
@media screen and (max-width: 600px) {
/* Place the timelime to the left */
.timeline::after {
left: 31px;
}
/* Full-width containers */
.container {
width: 100%;
padding-left: 70px;
padding-right: 25px;
}
/* Make sure that all arrows are pointing leftwards */
.container::before {
left: 60px;
border: medium solid white;
border-width: 10px 10px 10px 0;
border-color: transparent white transparent transparent;
}
.left,
.right {
transform: none;
left: 0;
}
/* Make sure all circles are at the same spot */
.left::after,
.right::after {
left: 15px;
}
/* Make all right containers behave like the left ones */
.right {
left: 0%;
}
}
<section class="timeline">
<section class="container left">
<article class="content">
<h2>Year</h2>
<p>Line 1</p>
<p>Line 2</p>
</article>
</section>
<section class="container right">
<article class="content">
<h2>Year</h2>
<p>Line 1</p>
<p>Line 2</p>
</article>
</section>
</section>
答案 1 :(得分:1)
这是因为该部分的margin: auto;
section {
margin: 0.1em 0;
padding-top: 0.5em;
padding-bottom: 0.5em;
max-width: 960px;
}
答案 2 :(得分:1)
您应该将display:inline-block
添加到您的左右班级