css — 選擇器、盒子模型

来源:https://www.cnblogs.com/yangjie0906/archive/2019/09/16/11405105.html
-Advertisement-
Play Games

[TOC] css: 層疊樣式表 1. css引入方式 行內樣式 內嵌式 在head標簽內部書寫style 外接式 三種引入方式的優先順序: 1.行內樣式 內嵌式和外接式, 2.內嵌和外接要看誰在後面,在後面的優先順序高 2. css選擇器 2.1 基礎選擇器 1.id選擇器 特定屬性的元素(標簽)、唯 ...


目錄

css: 層疊樣式表

1. css引入方式

  • 行內樣式

    <div style='color:red;'>mjj</div>
  • 內嵌式

    在head標簽內部書寫style

    <style>
    /*css代碼*/
    #box{
                background-color: greenyellow;
            }
    </style>
  • 外接式

    <link href='css/index.css' rel='stylesheet'>

三種引入方式的優先順序:

  • 1.行內樣式>內嵌式和外接式,
  • 2.內嵌和外接要看誰在後面,在後面的優先順序高

2. css選擇器

2.1 基礎選擇器

1.id選擇器

特定屬性的元素(標簽)、唯一的

語法: #xxx

2.類選擇器

可以重覆歸類,類也可以設置多個

語法: .xxx

<style>
  .box{
    width:200px;
    height:200px;
    background-color:yellow;
 }
  <!--單獨設置 類1 中某個樣式與 類2 不一樣-->
  .active{
    border-radius: 200px; <!--設置盒子邊框-->
 }
</style>
<div class='box active'></div> <!--類1-->
<div class='box'></div>  <!--類2-->
<div class='box'></div>  <!--類2-->

3.標簽選擇器

標簽選擇器有:div{} 、p{} 、ul 、ol ...

<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        a{
            /*設置文本修飾*/
            text-decoration: none;
        }
        input{
            border:none;
            outline:none;
        }
        #user{
            border: 1px solid #555;
            height: 60px;
            font-size: 20px;
            padding: 0 10px;
        }
        .box {
            width: 200px;
            height: 200px;
            background-color: yellow;
        }
        .active {
            border-radius: 4px;
        }
        #box{
            color: red;
        }
        div{
            border:1px solid #000;
        }
    </style>
</head>
<body>
<div class='box active' id="box">wusir</div>
<hr>
<div class='box'></div>
<hr>
<div class='box'></div>
<a href="">百度一下</a>
<input type="text" id="user">
</body>

2.2 高級選擇器

1.後代選擇器

語法:

/*用空格連接*/
div p{
  color: red;
}

2.子代選擇器

語法:

/*用>連接*/
div>p{
  color: red;
}

3.組合選擇器

常用於重置樣式

語法:

/*用,連接*/
div,p,body,html,ul,ol....{
  padding: 0;
  margin: 0;
}
input,textarea{
            border:none;
            outline: 0;
        }

如何重置網頁樣式?

html,body,p,ul,ol{
    margin: 0;
    padding: 0;
}
/*通配符選擇器 */
*{
    margin: 0;
    padding: 0;
}
a{
    text-decoration: none;
}
/*清除input和textarea標簽的預設邊框和外線*/
input,textarea{
    border: none;
    outline: none;
}

4.交集選擇器

span.active

語法:

div.active{
 
}

2.3 偽類選擇器

對於a標簽,如果想設置a標簽的樣式,要作用於a標簽上,對於繼承性來說,a標簽不起作用的

“愛恨準則” — LoVe HAte :L - link 、V - visited 、H - hover 、A - active

/*LoVe HAte*/
/*a標簽沒有被訪問時候設置的屬性*/
a:link{
    /*color: red;*/
}
/*a標簽被訪問過後設置的屬性*/
a:visited{
    color:yellow;
}
/*a標簽被滑鼠懸浮時設置的屬性*/
a:hover{
    color: deeppink;
}
/*a標簽被摁住的時候設置的屬性*/
a:active{
    color: deepskyblue;
}

2.4 屬性選擇器

<style>
    input[type='text']{
        background-color: red;
    }
    input[type='checkbox']{

    }
    input[type='submit']{

    }
</style>

2.5 偽元素選擇器

<style>
    /*設置內容中的第一個文字*/
    p::first-letter{
        color: red;
        font-size: 20px;
        font-weight: bold;
    }
    /*在內容前加一個@*/
    p::before{
        content:'@';
    }
    /*::after是解決浮動佈局常用的一種方法*/
    /*在內容後面加一個$*/
    p::after{
        /*通過偽元素添加的內容為行內元素*/
        content:'$';
    }
</style>

註意:

  • 1.通過偽元素添加的內容為行內元素
  • 2.::after是解決浮動佈局常用的一種方法
  • 3.1個':'是偽類選擇器,2個':'是偽元素選擇器

3. css的盒模型

1.盒子模型的屬性及含義:

  • width: 內容的寬度

  • height:內容的高度

  • padding:內邊距(又叫內填充),盒子的border到內容的距離

    • 1.單個屬性分別設置不同方向的padding

      padding-top  頂部填充的距離
      padding-right  右側填充的距離
      padding-bottom  底部填充的距離
      padding-left  左側填充的距離
    • 2.綜合屬性,多個屬性用空格隔開。

      /*綜合設置:四個方向的內邊距為:*/
      padding: 20px;
      
      /*盒子的上下內邊距設置為第一個數值,左右內邊距設置第二個數值*/
      
      
      /*上  左右  下*/
      padding: 0 20px 30px;
      
      /*上  右  下  左*/
      padding: 10px 20px 30px 40px;
  • border:盒子的邊框

    boder邊框三要素:粗細 、線性樣式 、顏色

    • 1.按照三要素書寫border
    border-width:3px;  /*邊框四邊線的粗細*/
    border-style:solid; /*邊框線樣式*/
    border-color:red;  /*邊框線顏色*/
    /*上面三句代碼相當於一句代碼:*/
    border:3px solid red;
    
    /*同樣,也可以分別設置邊框四個方向的粗細 線性樣式 顏色,跟padding的四個方向一樣。*/
    /*上下5px  左右10px*/
    border-width:5px 10px;
    /*上:實線  右:點狀線  下:雙線  左:虛線*/
    border-style: solid dotted double dashed;
    /*上:紅色 左右:綠色 下:黃色*/
    border-color: red green yellow;
    • 2.按照方向劃分
    /*boder的頂部邊框*/
    border-top-width: 10px;
    border-top-color: red;
    border-top-style: solid;
    /*可以簡寫成*/
    border-top: 10px solid red;
    
    /*boder的右側邊框*/
    border-right-width: 10px;
    border-right-color: red;
    border-right-style: solid;
    /*可以簡寫成*/
    border-right: 10px solid red;
    
    /*boder的底部邊框*/
    border-bottom-width: 10px;
    border-bottom-color: red;
    border-bottom-style: solid;
    /*可以簡寫成*/
    border-bottom: 10px solid red;
    
    /*boder的左側邊框*/
    border-left-width: 10px;
    border-left-color: red;
    border-left-style:solid;
    /*可以簡寫成*/
    border-left: 10px solid red;
    • 3.清除預設邊框

      清除某些標簽預設的邊框 :border:none; 或者 border:0;

      清除某些標簽預設的外邊框 :outline: none; 或者 border:0;

    • 4.邊框屬性

      • 1.設置為圓角或者圓

        語法: border-radius:20px;

        <style>
                #box{
                    width: 300px;
                    height: 300px;
                    background-color: red;
                    /*border-radius: 50%;*/
                    border-radius: 4px;
                    border: 3px solid blue;
                }
                 #box:hover{
                     background-color: #000;
                 }
            </style>

        除了同時設置四個圓角以外,還可以單獨對每個角進行設置。對應四個角,CSS3提供四個單獨的屬性:

        • border-top-left-radius
        • border-top-right-radius
        • border-bottom-right-radius
        • border-bottom-left-radius

        這四個屬性都可以同時設置1到2個值。如果設置1個值,表示水平半徑與垂直半徑相等。如果設置2個值,第一個值表示水平半徑,第二個值表示垂直半徑。

      • 2.設置陰影效果

        語法:box-shadow: h-shadow v-shadow blur color inset;

        h-shadow 水平陰影的位置、距離

        v-shadow 垂直陰影的位置、距離

        blur 模糊距離、程度

        color 陰影的顏色

        inset 將外部陰影 (outset,預設值) 改為內部陰影。

        <style>
            .box{
                width: 200px;
                height: 200px;
                background-color: #000;
                margin: 100px auto;
                position: relative;
                transition: all .2s linear;
            }
            .box:hover{
                top: -2px;
                box-shadow: 0 0  20px red;
            }
        </style>
  • margin:盒子的外邊距,一個盒子到另一個盒子的距離。

    • 水平方向的外邊距

      /*左外邊距*/
      margin-left: 30px;
      /*右外邊距*/
      margin-right: 20px;
    • 垂直方向外邊距

      margin在水平方向上不會出現問題,但在垂直方向上會出現外邊距合併(或重疊)現象,這種現象叫做塌陷問題,會以設置的最大的magrin距離為基準。

      如何避免出現這種問題呢?

      • 為了避免出現塌陷問題,只需要設置一個盒子的一個方向的margin即可。
      /*頂部外邊距*/
      margin-top:50px;
      /*底部外邊距*/
      margin-bottom:30px;
    • 也可以綜合設置水平與垂直方向的外邊距

      /*水平居中*/
      margin:0 auto;

2.盒子模型圖


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天在學習查閱代碼的時候,發現了一個不認識的CSS代碼,於是進行學習。 效果圖 使圖片在對應的元素內以不同的方式進行垂直對齊 ...
  • 工廠模型抽象了創建具體對象的過程,以下示例代碼說明工廠類型: 部分摘自《JavaScript高級程式設計(第3版)》 ...
  • JavaScript 基礎入門 JavaScript 的組成 JS 由三部分組成,它們分別是:ECMAScript、DOM、BOM. ECMAScript 因為網景開發了JavaScript,一年後微軟又模仿JavaScript開發了JScript,為了讓JavaScript成為全球標準,幾個公司聯 ...
  • <!DOCTYPE>標簽的定義 <!DOCTYPE> 聲明位於文檔中最前面的位置,處於<html>標簽之前。<!DOCTYPE> 聲明不是一個HTML標簽,它是告知Web瀏覽器該頁面使用了哪種HTML版本(規範),瀏覽器用此版本(規範)對該文檔進行解析,渲染。 <!DOCTYPE> 可聲明的 DTD ...
  • 利用快速原型獲取軟體需求 在客戶 開發商 用戶 之間 旨在啟發客戶 引導客戶真正知道和瞭解自己的可行需求 快速搭建原型 高效準確地確定用戶需求 我們可能要用到一個軟體需求方面的知識-快速原型 例子 以CSS語言為例從一個最最最的教務系統入手 代碼如下: <html><center><h2>歡迎返校! ...
  • 以下通過一段示例代碼,說明原型模型中的基本概念以及知識點。 部分摘自《JavaScript高級程式設計(第3版)》 ...
  • 前言 最近在看 React 的新語法—— ,只能一句話概括:React 語法真的是越來越強大,越寫代碼越少。 強烈推薦還沒看 React Hooks 的同學去學習下,這會讓你寫react 項目變得非常爽! 以前 React 組件可以看成是: 無狀態組件(function定義)和有狀態組件(class ...
  • [TOC] 1. 繼承性 繼承性:在css有某些屬性是可以繼承下來,如 color,text xxx,line height,font xxx,letter spacing,word spacing是可以繼承下來,但有些屬性是不可以繼承下來的,如 border:1px solid green; 2. ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...