목차
我们将要使用什么
布局
HTML
CSS
웹 프론트엔드 HTML 튜토리얼 使用 Flexbox 创建一个响应式的留言板(译)_html/css_WEB-ITnose

使用 Flexbox 创建一个响应式的留言板(译)_html/css_WEB-ITnose

Jun 24, 2016 am 11:19 AM

原文链接:http://tutorialzine.com/2015/11/using-flexbox-to-create-a-responsive-comment-section/

查看演示

下载源码

Flexbox 是网页布局的一个强大的新方式,使得一些具有挑战性的 web 开发变得简单。现在几乎所有的浏览器都支持它,所以现在已经是时候让它融入到你的前台开发中了。

这就是为什么要在这个快速教程中,我们使用 Flexbox 构建一个留言板。我们将看一看 Flexbox 布局模式提供的一些有趣的特性,并告诉你该如何充分利用。

我们将要使用什么

Flexbox 有大量的 CSS 属性,下面这些使我们今天要用到的:

  • display: flex ——这将激活 flex 布局,并且使元素的子元素遵守 flexbox 规则。
  • justify-content ——这个属性定义了一个让子元素对齐的一个方法(类似于 text-align)。
  • order ——order 可以控制元素排列的顺序,数值越小,排列越靠前,默认为0。
  • flex-wrap ——可控制元素的换行,使用这个属性,让我们在小屏幕上也能获得支持。

布局

我们希望我们的留言本能够满足下面的几点要求:

  • 每一个留言应该有一个头像,昵称,时间和内容。
  • 留言的类型应该有两种,一种是作者写的(蓝色的部分和右侧的头像),另一种是其他人写的。
  • 这两种类型的 HTML 标记必须要尽可能的相似,为了能够很容易的通过代码生成评论。
  • 整个页面能都能响应,适配不同的屏幕。

HTML

我们的 HTML 非常的简单,我们有一个留言的列表,和一个留言框。

<ulclass="comment-section">     <liclass="comment user-comment">        <divclass="info">            <a href="#">AnieSilverston</a>            <span>4 hoursago</span>        </div>        <a class="avatar" href="#">            <img src="/static/imghw/default1.png"  data-src="images/avatar_user_1.jpg"  class="lazy"    style="max-width:90%" alt="Profile Avatar" title="Anie Silverston" />        </a>        <p>Suspendissegravidasem?</p>    </li>     <liclass="comment author-comment">        <divclass="info">            <a href="#">JackSmith</a>            <span>3 hoursago</span>        </div>        <a class="avatar" href="#">            <img src="/static/imghw/default1.png"  data-src="images/avatar_author.jpg"  class="lazy"    style="max-width:90%" alt="Profile Avatar" title="Jack Smith" />        </a>        <p>Loremipsumdolorsitamet, consecteturadipiscingelit. Suspendissegravidasemsitametmolestieportitor.</p>     </li>     <!-- Morecomments -->     <liclass="write-new">         <formaction="#" method="post">            <textareaplaceholder="Write your comment here" name="comment"></textarea>            <div>                <img src="/static/imghw/default1.png"  data-src="images/avatar_user_2.jpg"  class="lazy"    style="max-width:90%" alt="Profile of Bradley Jones" title="Bradley Jones" />                <buttontype="submit">Submit</button>            </div>        </form>     </li> </ul> 
로그인 후 복사

如果你仔细观察上面的代码,你会注意到用户留言和作者留言这两部分的 html 几乎是相同的。这两者之间的风格和布局差异都将通过 CSS 实现,分别对应这两个 CSS 类: .user-comment 和 .author-comment 。

CSS

我们看一下使用 Flexbox 布局时使用的相关技术。如果你想查看全部的 css 样式,可以在文章的顶部下载整个 css 文件。

首先我们要给所有的评论设置 display: flex ,这使我们能够在评论以及子元素中使用 Flexbox 的属性。

.comment{  display: flex;} 
로그인 후 복사

这些 flex 容器要这充满当前布局的宽度,并且能够包含用户信息、头像和消息内容。因为我们想让作者写的评论向右对齐,我们可以使用下面的属性来调整。

.comment.author-comment{    justify-content: flex-end;} 
로그인 후 복사

现在我们的评论看起来像是这样:

现在已经是右对齐了,但好似我们希望这其中的元素能够倒序显示,让消息内容显示在第一位,然后才是头像和右侧的信息。要做到这一点,我们将使用 order 属性。

.comment.author-comment .info{    order: 3;} .comment.author-comment .avatar{    order: 2;} .comment.author-comment p{    order: 1;} 
로그인 후 복사

正如你所看到的,在 Flexbox 的帮助下,整个东西实现起来很容易。

我们的留言板看起来已经是我们想要的样子了,剩下的唯一一件事就是确保它在小设备上也能友好的显示。由于小设备上的屏幕空间有限,我们不得不重新做一些布局,使我们的内容更易阅读。

我们设置了一个媒体查询,使得留言内容部分扩大,占用容器的整个宽度。这将导致头像和用户信息移动到下一行,因为他们的 ·flex-wrap·属性设置为·wrap·。

@media (max-width: 800px){    /* Reverse the order of elements in the user comments,    so that the avatar and info appear after the text. */    .comment.user-comment .info{        order: 3;    }     .comment.user-comment .avatar{        order: 2;    }     .comment.user-comment p{        order: 1;    }     /* Make the paragraph in the comments take up the whole width,    forcing the avatar and user info to wrap to the next line*/    .comment p{        width: 100%;    }      /* Align toward the beginning of the container (to the left)    all the elements inside the author comments. */    .comment.author-comment{        justify-content: flex-start;    }} 
로그인 후 복사

你可以看看下面的图片与上面的进行对比,你也可以在文章的开始,点击演示,并调整你的浏览器的大小查看留言板的变化。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

공식 계정 웹 페이지의 캐싱 업데이트에 어려움 : 버전 업데이트 후 사용자 경험에 영향을 미치는 이전 캐시를 피하는 방법은 무엇입니까? 공식 계정 웹 페이지의 캐싱 업데이트에 어려움 : 버전 업데이트 후 사용자 경험에 영향을 미치는 이전 캐시를 피하는 방법은 무엇입니까? Mar 04, 2025 pm 12:32 PM

공식 계정 웹 페이지 업데이트 캐시, 이것은 간단하고 간단하며 냄비를 마시기에 충분히 복잡합니다. 공식 계정 기사를 업데이트하기 위해 열심히 노력했지만 사용자는 여전히 기존 버전을 열었습니까? 이 기사에서는이 뒤에있는 비틀기와 회전을 살펴 보고이 문제를 우아하게 해결하는 방법을 살펴 보겠습니다. 읽은 후에는 다양한 캐싱 문제를 쉽게 처리 할 수있어 사용자가 항상 가장 신선한 콘텐츠를 경험할 수 있습니다. 기본 사항에 대해 먼저 이야기 해 봅시다. 액세스 속도를 향상시키기 위해 브라우저 또는 서버는 일부 정적 리소스 (예 : 그림, CSS, JS) 또는 페이지 컨텐츠를 저장합니다. 다음에 액세스 할 때 다시 다운로드하지 않고도 캐시에서 직접 검색 할 수 있으며 자연스럽게 빠릅니다. 그러나 이것은 또한 양날의 검입니다. 새 버전은 온라인입니다.

HTML5 양식 유효성 검사 속성을 사용하여 사용자 입력을 유효성있게하려면 어떻게합니까? HTML5 양식 유효성 검사 속성을 사용하여 사용자 입력을 유효성있게하려면 어떻게합니까? Mar 17, 2025 pm 12:27 PM

이 기사에서는 브라우저에서 직접 사용자 입력을 검증하기 위해 필요한, Pattern, Min, Max 및 Length 한계와 같은 HTML5 양식 검증 속성을 사용하는 것에 대해 설명합니다.

HTML5의 크로스 브라우저 호환성에 대한 모범 사례는 무엇입니까? HTML5의 크로스 브라우저 호환성에 대한 모범 사례는 무엇입니까? Mar 17, 2025 pm 12:20 PM

기사는 HTML5 크로스 브라우저 호환성을 보장하기위한 모범 사례에 대해 논의하고 기능 감지, 점진적 향상 및 테스트 방법에 중점을 둡니다.

웹 페이지의 PNG 이미지에 뇌졸중 효과를 효율적으로 추가하는 방법은 무엇입니까? 웹 페이지의 PNG 이미지에 뇌졸중 효과를 효율적으로 추가하는 방법은 무엇입니까? Mar 04, 2025 pm 02:39 PM

이 기사는 CSS를 사용한 웹 페이지에 효율적인 PNG 테두리 추가를 보여줍니다. CSS는 JavaScript 또는 라이브러리에 비해 우수한 성능을 제공하며, 미묘하거나 눈에 띄는 효과를 위해 테두리 너비, 스타일 및 색상 조정 방법을 자세히 설명합니다.

& lt; datalist & gt의 목적은 무엇입니까? 요소? & lt; datalist & gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:33 PM

이 기사는 HTML & LT; Datalist & GT에 대해 논의합니다. 자동 완성 제안을 제공하고, 사용자 경험을 향상시키고, 오류를 줄임으로써 양식을 향상시키는 요소. 문자 수 : 159

html5 & lt; time & gt; 의미 적으로 날짜와 시간을 나타내는 요소? html5 & lt; time & gt; 의미 적으로 날짜와 시간을 나타내는 요소? Mar 12, 2025 pm 04:05 PM

이 기사는 html5 & lt; time & gt; 시맨틱 날짜/시간 표현 요소. 인간이 읽을 수있는 텍스트와 함께 기계 가독성 (ISO 8601 형식)에 대한 DateTime 속성의 중요성을 강조하여 Accessibilit를 향상시킵니다.

& lt; Progress & Gt의 목적은 무엇입니까? 요소? & lt; Progress & Gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:34 PM

이 기사는 HTML & lt; Progress & Gt에 대해 설명합니다. 요소, 그 목적, 스타일 및 & lt; meter & gt의 차이; 요소. 주요 초점은 & lt; progress & gt; 작업 완료 및 & lt; meter & gt; Stati의 경우

& lt; meter & gt의 목적은 무엇입니까? 요소? & lt; meter & gt의 목적은 무엇입니까? 요소? Mar 21, 2025 pm 12:35 PM

이 기사는 HTML & lt; meter & gt에 대해 설명합니다. 범위 내에 스칼라 또는 분수 값을 표시하는 데 사용되는 요소 및 웹 개발의 일반적인 응용 프로그램. & lt; meter & gt; & lt; Progress & Gt; 그리고 Ex

See all articles