主頁 > 軟體設計 > 同樣是網頁前端小白你的頁面為什么更高級?

同樣是網頁前端小白你的頁面為什么更高級?

2021-08-11 07:50:39 軟體設計

文章目錄

  • 前言
  • 一、一個完整網頁的布局方法
  • 二、增加頁面布局高級感
    • 1.定位
    • 2.元素的顯示與隱藏
    • 3.巧用精靈圖、字體圖示、CSS三角
    • 4.CSS用戶頁面布局樣式
    • 5.圖片與文字之間的距離
    • 6.常見布局技巧
    • 總結


前言

學習了網頁前端中的HTML和CSS也許你的頁面已經有了一定的改善,在現有的技術你的頁面有了一定的雛形一些簡單的效果可以展示出來,但我們為了讓用戶有更好的使用體驗所以我們需要增加一些小技巧來讓頁面更加高級!


一、一個完整網頁的布局方法

  • 標準流
    可以讓盒子上下排列或者左右排列,垂直的塊級盒子顯示就用標準流布局,
  • 浮動
    可以讓多個塊級元素一行顯示或者左右對齊盒子,多個塊級盒子水平顯示就用浮動布局
  • 定位
    定位最大的特點是有層疊的概念,就是可以讓多個盒子前后疊壓來顯示,如果元素自由在某個盒子內移動就用定位布局

二、增加頁面布局高級感

1.定位

定位是指:將盒子定在某一位置,按照定位的方式來移動盒子,
定位的特殊性:

  • 行內元素添加絕對或者固定定位,可以設定高度和寬度
  • 塊級元素添加絕對或者固定定位,它的高度與寬度就是按內容的大(加了定位的塊級元素就不會有標準流的特性)

定位的型別:

  • 相對定位——選擇器{position:relative;}
    特點:
    1.目標移動的時候是相對自己原來的位置移動的
    2.原來在標準流的位置繼續占有,后面的盒子仍然以標準流的方式對待它(不脫離標準流)
  • 絕對定位——選擇器{position:absolute;}
    特點:
    1.如果沒有父元素或者祖先元素沒有定位(就是當祖先元素是標準流的話),那子元素的絕對定位是相對于瀏覽器進行移動,
    2.a.如果有父元素、祖父元素且有定位(相對、絕對、固定定位),則相對于最近一級的有定位的父元素為參考點移動位置,
    b.如果有父元素、祖元素但是父元素沒有定位,而祖元素有定位,那就以祖元素為參考點移動位置,
    3.絕對定位不再占有原先的位置(脫離標準流)絕對定位不占位置(下面的元素會填補)
  • 固定定位——選擇器{position:fixed;right: ;top: ;}
    特點:
    1.以瀏覽器的可視視窗為參照點移動元素,
    跟父元素沒有任何關系,不隨滾動條滾動,
    2.固定定位不再占有原先的位置
    3.一般使用情況:固定在版心的右側位置
    小演算法:
    a.讓固定定位的盒子 left: 50%. 走到瀏覽器可視區(也可以看做版心) 的一半位置,
    b.讓固定定位的盒子 margin-left: 版心寬度的一半距離, 多走 版心寬度的一半位置
    就可以讓固定定位的盒子貼著版心右側對齊了,
  • 父子盒子使用定位方法:子絕父相
    這個方法的含義:子盒子用絕對定位,父盒子用相對定位,
    代碼如下(示例):
.img {
            position: relative;
            width: 250px;
            height: 152px;
            line-height: 152px;
            margin-top: 30px;
            display: block;
        }
.showBox .category {
            position: absolute;
            display: inline-block;
            width: 38px;
            height: 22px;
            text-align: center;
            line-height: 22px;
            background: url('./images/label.png') no-repeat;
            color: #fff;
            position: absolute;
            right: 8px;
            top: -10px;
        }

(效果圖)
圖片注釋 這個就是父盒子——position:revative;
在這里插入圖片描述這個就是子盒子——position:absolute;

2.元素的顯示與隱藏

display屬性

       .box img {
            width: 500px;
            display: none;
            /* display 不再占有原來的位置 */
        }
        
        .box:hover img {
            display: block;
        }

visibility屬性

.box {
            width: 800px;
            height: 800px;
            background-color: pink;
            text-align: center;
        }
        
.box img {
            visibility: hidden;
            /* 雖然看不到了但是還是占有位置 */
        }
        
.box span {
            display: block;
            width: 300px;
            margin: 0 auto;
        }

overflow屬性
占據原來的位置

 overflow: hidden;
            /* 元素隱藏,但是仍占有原來的位置 */
            overflow:visible;
            /*不減切內容也不添加滾動發條  */
            overflow:scroll;
            /* 不管超出內容否總是顯示滾動條 */
            overflow:auto;
            /* 超出自動顯示滾動條,不超出不顯示滾動條 */

opacity屬性
占據原來的位置(它的屬性相當于是給元素添加透明度當opacity:0就是透明了

.box p {
            width: 200px;
            opacity: 0.5;
        }

3.巧用精靈圖、字體圖示、CSS三角

精靈圖核心原理:
將網頁中的一些小背景影像整合到一張大圖中,這樣服務器只需要一次請求就可以了
CSS三角頁面常見應用
可以呈現出如下圖的效果
在這里插入圖片描述價格商標顯示效果
在這里插入圖片描述代碼如下:

.box {
            position: relative;
            width: 200px;
            height: 400px;
            background-color: pink;
        }
        
.box span {
            position: absolute;
            left: 190px;
            top: -10px;
            width: 0;
            height: 0;
            line-height: 0;
            font-size: 0;
            border: 5px solid transparent;
            border-bottom-color: pink;
        }

在這里插入圖片描述代碼如下:

.box1 {
            width: 0;
            height: 0;
            /* border-top: 100px solid #000;
            border-bottom: 0px solid pink;
            border-left: 0px solid blue;
            border-right: 50px solid yellow;對其進行簡寫 */
            border-color: transparent red transparent transparent;
            border-style: solid;
            /* 上邊框要長一些 右邊的邊框稍小一些 其余邊框為0 */
            border-width: 100px 50px 0 0;
        }

4.CSS用戶頁面布局樣式

滑鼠點擊在不同界面展現出不同的現象:

{cursor:default}--小白 默認形狀
{cursor:pointer}--小手形狀
{cursor:move}--移動
{cursor:text}-插入文本時的樣子
{cursor:not-allowed}--禁止符號

當在文本框搜索欄中取消邊框輪廓線:

<style>中表單元素
 input{outline:none;}
textarea{resize:none;}

5.圖片與文字之間的距離

在style中使用vertical-align:middle/bottom/top;
在網頁中的圖片與文字之間的對齊原理
在這里插入圖片描述
不設定任何屬性時是這種效果:
在這里插入圖片描述文字與圖片并沒有對齊

<style>
        img {
            vertical-align: middle;
            /* 使用場景:圖片和文字垂直居中 */
        }
 </style>
 <body>
    <img src="1.jpg" alt="">hello world!
</body>

在這里插入圖片描述這樣圖片和文字就垂直居中了,這個方法還可以讓圖片在一個文本框內沒有縫隙,

6.常見布局技巧

在這里插入圖片描述1.在網頁中頁常會出現這種圖示,那他們是如何實作的呢?

* {
            margin: 0;
            padding: 0;
        }
        
.box {
            width: 300px;
            height: 70px;
            background-color: pink;
            margin: 0 auto;
            padding: 5px;
        }
        
.pic {
            float: left;
            width: 120px;
            height: 60px;
            margin-left: 5px;
        }
        
.pic img {
            width: 100%;
        }

注意:就不需要給文字添加浮動效果了,只需要給圖片添加浮動效果,
在這里插入圖片描述2.ul li中的盒子相鄰會有交叉的邊所以我們需要用margin來解決,

 ul li {
            float: left;
            list-style: none;
            width: 150px;
            height: 200px;
            border: 1px solid red;
            margin-left: -1px;
        }

3.當滑鼠點擊盒子時四條邊能夠顯現出來
在這里插入圖片描述這種常被使用在商品顯示場景

 ul li {
            float: left;
            list-style: none;
            width: 150px;
            height: 200px;
            border: 1px solid red;
            margin-left: -1px;
        }
        
 ul li:hover {
            position: relative;
            border: 1px solid blue;
        }

總結

以上就是對網頁設計方面的小心思可以讓你的網頁頁面在小細節中讓用戶體驗更加!

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/292996.html

標籤:其他

上一篇:C++編程經驗(7):delete之后到底要不要置空?

下一篇:使用 GitLab + Jenkins 實作持續集成(CI)環境

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more