Jadual Kandungan
我们将要使用什么
布局
HTML
CSS
Rumah hujung hadapan web html tutorial 使用 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> 
Salin selepas log masuk

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

CSS

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

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

.comment{  display: flex;} 
Salin selepas log masuk

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

.comment.author-comment{    justify-content: flex-end;} 
Salin selepas log masuk

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

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

.comment.author-comment .info{    order: 3;} .comment.author-comment .avatar{    order: 2;} .comment.author-comment p{    order: 1;} 
Salin selepas log masuk

正如你所看到的,在 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;    }} 
Salin selepas log masuk

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

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1672
14
Tutorial PHP
1276
29
Tutorial C#
1256
24
HTML: Struktur, CSS: Gaya, JavaScript: Tingkah Laku HTML: Struktur, CSS: Gaya, JavaScript: Tingkah Laku Apr 18, 2025 am 12:09 AM

Peranan HTML, CSS dan JavaScript dalam pembangunan web adalah: 1. HTML mentakrifkan struktur laman web, 2. CSS mengawal gaya laman web, dan 3. JavaScript menambah tingkah laku dinamik. Bersama -sama, mereka membina kerangka, estetika dan interaktiviti laman web moden.

Masa Depan HTML, CSS, dan JavaScript: Trend Pembangunan Web Masa Depan HTML, CSS, dan JavaScript: Trend Pembangunan Web Apr 19, 2025 am 12:02 AM

Trend masa depan HTML adalah semantik dan komponen web, trend masa depan CSS adalah CSS-in-JS dan CSShoudini, dan trend masa depan JavaScript adalah webassembly dan tanpa pelayan. 1. Semantik HTML meningkatkan kebolehcapaian dan kesan SEO, dan komponen web meningkatkan kecekapan pembangunan, tetapi perhatian harus dibayar kepada keserasian penyemak imbas. 2. CSS-in-JS meningkatkan fleksibiliti pengurusan gaya tetapi boleh meningkatkan saiz fail. Csshoudini membolehkan operasi langsung rendering CSS. 3.Webassembly mengoptimumkan prestasi aplikasi penyemak imbas tetapi mempunyai keluk pembelajaran yang curam, dan tanpa pelayan memudahkan pembangunan tetapi memerlukan pengoptimuman masalah permulaan sejuk.

Masa Depan HTML: Evolusi dan Trend dalam Reka Bentuk Web Masa Depan HTML: Evolusi dan Trend dalam Reka Bentuk Web Apr 17, 2025 am 12:12 AM

Masa depan HTML penuh dengan kemungkinan yang tidak terhingga. 1) Ciri -ciri dan piawaian baru akan merangkumi lebih banyak tag semantik dan populariti komponen web. 2) Trend reka bentuk web akan terus berkembang ke arah reka bentuk yang responsif dan boleh diakses. 3) Pengoptimuman prestasi akan meningkatkan pengalaman pengguna melalui pemuatan imej yang responsif dan teknologi pemuatan malas.

HTML vs CSS vs JavaScript: Gambaran Keseluruhan Perbandingan HTML vs CSS vs JavaScript: Gambaran Keseluruhan Perbandingan Apr 16, 2025 am 12:04 AM

Peranan HTML, CSS dan JavaScript dalam pembangunan web adalah: HTML bertanggungjawab untuk struktur kandungan, CSS bertanggungjawab untuk gaya, dan JavaScript bertanggungjawab untuk tingkah laku dinamik. 1. HTML mentakrifkan struktur laman web dan kandungan melalui tag untuk memastikan semantik. 2. CSS mengawal gaya laman web melalui pemilih dan atribut untuk menjadikannya cantik dan mudah dibaca. 3. JavaScript mengawal tingkah laku laman web melalui skrip untuk mencapai fungsi dinamik dan interaktif.

HTML vs CSS dan JavaScript: Membandingkan Teknologi Web HTML vs CSS dan JavaScript: Membandingkan Teknologi Web Apr 23, 2025 am 12:05 AM

HTML, CSS dan JavaScript adalah teknologi teras untuk membina laman web moden: 1. HTML mentakrifkan struktur laman web, 2. CSS bertanggungjawab untuk kemunculan laman web, 3.

HTML: Adakah bahasa pengaturcaraan atau yang lain? HTML: Adakah bahasa pengaturcaraan atau yang lain? Apr 15, 2025 am 12:13 AM

Htmlisnotaprogramminglanguage; itisamarkuplanguage.1) htmlstructuresandformatswebcontentusingtags.2) itworkswithcssforstylingandjavascriptforinteractivity, meningkatkan pembangunan semula.

Apakah perbezaan antara & lt; strong & gt;, & lt; b & gt; tags dan & lt; em & gt;, & lt; i & gt; Tags? Apakah perbezaan antara & lt; strong & gt;, & lt; b & gt; tags dan & lt; em & gt;, & lt; i & gt; Tags? Apr 28, 2025 pm 05:42 PM

Artikel ini membincangkan perbezaan antara tag HTML ,, dan, memberi tumpuan kepada kegunaan semantik dan presentasi mereka dan kesannya terhadap SEO dan kebolehaksesan.

Beyond HTML: Teknologi Penting untuk Pembangunan Web Beyond HTML: Teknologi Penting untuk Pembangunan Web Apr 26, 2025 am 12:04 AM

Untuk membina laman web dengan fungsi yang kuat dan pengalaman pengguna yang baik, HTML sahaja tidak mencukupi. Teknologi berikut juga diperlukan: JavaScript memberikan laman web dinamik dan interaktif, dan perubahan masa nyata dicapai dengan mengendalikan DOM. CSS bertanggungjawab untuk gaya dan susun atur laman web untuk meningkatkan estetika dan pengalaman pengguna. Rangka kerja moden dan perpustakaan seperti React, Vue.js dan sudut meningkatkan kecekapan pembangunan dan struktur organisasi kod.

See all articles