css入門

来源:https://www.cnblogs.com/-xct/archive/2019/12/03/11977760.html
-Advertisement-
Play Games

css 層疊樣式表,作用是為標簽加效果 基本選擇器 元素選擇器 標簽名稱{css屬性:值} id選擇器 id{} 類選擇器 .class1{屬性:值} 屬性選擇器 後代選擇器 html代碼: 組合選擇器 div,a{ color: yellow;} css樣式引入方式 head標簽中引入 外部文件引 ...


css

層疊樣式表,作用是為標簽加效果

<div style="background: red">123</div>

基本選擇器

元素選擇器

標簽名稱{css屬性:值}

div{width:100px;}

id選擇器

id{}

html代碼:
<div id="d1">

    </div>

css寫法:
    #d1{
        background-color: green;
        width: 100px;
        height: 100px;
    }

類選擇器

.class1{屬性:值}

html代碼:
<div id="d1" class="c1">
    baby
</div>

<div id="d2" class="c2">
   熱巴
</div>

<div id="d3" class="c1">
    唐藝昕
</div>


css寫法:
.c1{
    background-color: green;
    width: 100px;
    height: 100px;
}

屬性選擇器

html代碼:
<div id="d5" class="c1" xx="ss">
    baby
</div>

<div id="d2" class="c2" xx="kk">
   熱巴
</div>

css寫法:
[xx]{
           /*屬性查找*/
           background-color: green;
    width: 100px;
    height: 200px;
       }


        [xx='ss']{
            /*屬性帶屬性值查找*/
    background-color: green;
    width: 100px;
    height: 200px;
}

後代選擇器

html代碼:

div id="d1" class="c1" xx="ss">
        <span>
            <a href="http://www.baidu.com">baby</a>
        </span>
    </div>
    <div id="d2" class="c2" xx="kk">
        <a href="http://www.baidu.com">熱巴</a>
    </div>
    <div id="d3" class="c1">
        唐藝昕
    </div>
    <a href="http://www.baidu.com">xxxxxxx</a>
div a{    color: yellow;}

組合選擇器

div,a{ color: yellow;}

html代碼:
div id="d1" class="c1" xx="ss">
        <span>
            <a href="http://www.baidu.com">baby</a>
        </span>
    </div>
    <div id="d2" class="c2" xx="kk">
        <a href="http://www.baidu.com">熱巴</a>
    </div>
    <div id="d3" class="c1">
        唐藝昕
    </div>
    <a href="http://www.baidu.com">xxxxxxx</a>
    
    
css代碼: 
註意:a標簽字體顏色設置,必須找到a標簽才能設置
    #d1 a,#d3 a{
        background-color: pink;
        color:yellow;
    }

css樣式引入方式

head標簽中引入

<style>
    /* 選擇器{css屬性名稱:屬性值;css屬性名稱:屬性值;} */
    div{                               用了基本選擇器中的元素選擇器
        width: 200px;
        height: 200px;
        background-color: red;
    }
</style>
給所有div標簽加樣式

外部文件引入

(工作中常用的)

創建一個css文件,stylesheet文件,比如test.css文件。裡面寫上以下代碼
div{
    /* css註釋 */
    width: 200px;
    height: 200px;
    background-color: red;
}

在想使用這些css樣式的html文件的head標簽中寫上下麵的內容
<link rel="stylesheet" href="test.css"> href對應的是文件路徑

內聯樣式

<div style="background-color: red;height: 100px;width: 100px;"></div>

multiple="multiple"?

css樣式相關

display屬性

改變標簽屬性:
inline: 將塊級標簽變成了內聯標簽
block:將內聯標簽變成塊級標簽
inline-block: 同時具備內聯標簽和塊級標簽的屬性,也就是不獨占一行,但是可以設置高度寬度
none: 設置標簽隱藏 (瞭解,後面用)

html代碼

 <span>
        我是span標簽
    </span>
    <div class="c1">
        鵝鵝鵝,曲項向天歌!
    </div>

    <div class="c2">
        白毛浮綠水
    </div>

css寫法

span{display: block;}             將內聯標簽變成塊級標簽
    .c1{
        background-color: red;    內容背景顏色
        height: 100px;            內容背景高度
        width: 100px;             內容背景寬度
        display: inline;          將塊級標簽變成內聯標簽
        /*display: inline-block;*/  同時具備內聯標簽和塊級標簽的屬性
         }

顏色設置

英文單詞:red;
十六進位: #ff746d;
rgb: rgb(155, 255, 236);

背景顏色透明度: rgba(255, 0, 0,0.3);      
單純的就是顏色透明度

標簽透明度(例如背景圖片透明度): opacity: 0.3;         
0到1的數字,這是整個標簽的透明度

盒子模型

標簽占空間總大小=margin+border+padding+content

html代碼

<div>
    窗前明月光
</div>

css寫法

div{ width: 200px;                           內容寬度
     height: 100px;                          內容高度
     background-color: rgba(255, 0, 0,0.3);  內容背景顏色
     background-image: url("fage.png");      內容背景圖片 url寫圖片路徑,也可以是網路地址路徑
     margin: 10px 15px              外邊距:上下 左右  距離無顏色
     border: 4px solid red;         邊框:大小 樣式 顏色 
     padding: 4px 2px 6px 8px;   上4右2下6左8  內邊距       
}

margin 外邊距

距離其他標簽或者自己父級標簽的距離

html代碼

    <div>
        窗前明月光
    </div>
    <div class="c1">
        <div class="c2">
        </div>
    </div>

css寫法

  .c1{
        background-color: red;
        height: 100px;
        width: 100px;
     /*margin: 10px 15px;*/     上下10,左右15
        margin-left: -10px;
    }
    .c2{
        background-color: green;
        height: 20px;
        width: 20px;
        /*margin: 10px 15px;*/
        margin-left: 20px;
    }

讓外邊距為零

body{
    margin: 0;
}

border 邊框

html代碼

<div>
    窗前明月光
</div>

css寫法

邊框簡寫方式,對四個邊框進行設置
<div style="border:1px solid red; ">           /*寬度/樣式/顏色*/
窗前明月光
</div>                                         

order-left: 1px solid green;  單對左邊邊框設置   
border-top: 1px solid blue;   上邊邊框       


細寫
border-width: 5px;  邊框寬度
border-style: dashed;  邊框樣式
border-color: aqua; 邊框顏色

padding 內邊距

內容和邊框之間的距離

html寫法

<div style="padding:1px solid red; ">   /*寬度/樣式/顏色*/
窗前明月光
</div>

padding: 6px 8px;           上下6左右8
padding: 4px 2px 6px 8px;   上4右2下6左8
padding-left: 20px;
padding-top: 20px;
padding-right: 20px;
padding-bottom: 20px;

content: 內容部分

背景

html代碼

<div>
    窗前明月光
</div>

css寫法

background-color: #ff746d;            背景顏色
background-color: rgba(255, 0, 0,0.3);背景顏色
background-image: url("fage.png");   url寫圖片路徑,也可以是網路地址路徑

background-repeat: no-repeat;        不重覆
background-repeat: repeat-y;         y方向上
background-position: right top;      右上
(lift top,center top,right top,center bpttom)
background-position: 100px 50px;     離左邊邊多少,離右邊多少  一般通過css設置

簡寫方式: 
    background: #ff0000 url("fage.png") no-repeat right bottom;
高度寬度
css寫法:
    div{
        height: 100px;
        width: 100px;
        background-color: pink;
    }
    span{                        !!!行級標簽不能設置高度寬度
        height: 100px;
        width: 100px;
        background-color: green;
    }

可以設置百分比,會按照父級標簽的高度寬度來計算

<div class="c1"><div class="c2">234</div></div>

css寫法:
        .c1{
        width: 200px;
        height: 100px;
        background: red;
    }
        .c2{
            width: 50%;
            height: 50%;
            background: gold;
        }
字體相關

html代碼

<div>
    窗前明月光
</div>

css寫法

font-size: 50px;    /* 預設字體大小是16px */
color:green;        /* 字體顏色 */

font-family:        '楷體', '宋體';      瀏覽器如果不支持第一個選第二個。。。

font-weight: 400;    /* 字體粗細 100-900,預設是400 */
字體對齊

字體對齊

html代碼:
    <div>
        窗前明月光
    </div>

css寫法

div{  height: 100px;
      width:200px;
      background-color: yellow;
      text-align: center;  水平居中  
      line-height: 100px;  和height高度相同,標簽文本垂直居中
        /*垂直居中*/ 
      text-align: right;右對齊

浮動

浮動的元素,不獨占一行,並且可以設置高度寬度

html代碼

<div class="cc"> 

<div class="c1"></div>
<div class="c2"></div>
</div> 

<div class="c3"></div>

scc寫法

body{ margin: 0; }   要浮動,先讓預設為8的外邊距為0

c1{
background-color: red;  height: 100px;
width: 200px;  float: left;
}
.c2{
background-color: green;  height: 100px;
width: 200px;  float: right;
}

.c3{
background-color: pink;
height: 100px;
width: 100%;}
塌陷解決

父級標簽沒有高度了,子標簽一浮動,會讓下麵的標簽頂上來

方式1:給父級標簽加高度 不常用

方式2:清除浮動(clear屬性) 不常用

.c3{
background-color: pink;  height: 100px;
width: 100%;
clear: both;    (這個標簽上面不允許有浮動的元素)
}

方式3:子標簽底下加一個空白的帶clear屬性的div標簽 常用

html代碼:

<div class="cc clearfix">
<div class="c1"></div>
<div class="c2"></div>
<div style="clear: both;"></div>
</div>
<div class="c3"></div>

方式4:div標簽後面用after拼一個內容為空的帶clear屬性的塊

需要先用偽元素選擇器

html代碼:

<div class="cc clearfix">
    <div class="c1"></div>
    <div class="c2"></div>
</div>
<div class="c3"></div>

css代碼:

.clearfix:after{
    content:'';         設置內容
    display:block;       設置塊
    clear:both;         設置clear屬性
}

偽元素 after

html代碼:

<div>
    一段文字
<div>

css代碼:

div{
    background-color:pink;
    height:100px;
    width:200px;}
div:after{
content:'?';
color:white;}

偽類 hover

html代碼:

<divclass="c1">

</div>

css寫法:

.c1{
    background-color:red;
    height:300px;
    width:300px;}

.c1:hover{                                     /*滑鼠懸浮時設置效果*/
/*background-color:green;*/
background-image:url("a.png");
cursor:pointer;}      pointer 手
                      default 箭頭,crosshair 十字,progress 箭頭和沙漏

懸浮顯示其他標簽效果

html代碼:

<divclass="c1">
<divclass="c2">  </div>

</div>

css寫法:

.c1{background:black;
    height:400px;
    width:400px;
}

.c2{background:aqua;
    height:40px;
    width:40px;
    display:none;          改display為隱藏屬性
}

.c1:hover.c2{
    display:block;          滑鼠懸浮時顯示c2,改display為塊屬性
}

positon 定位

做一些小的範圍佈局

html代碼:

<div class="cc ">
    <div class="c1"></div>
    <div class="c2"></div>
</div>
<div class="c3"></div>

static 靜態定位

也就是標簽預設

relative 相對定位

相對於父級標簽移動,原來的位置還占著,不會造成下麵的標簽頂上去的情況

css代碼:

position:relative;
left:100px;   離左邊
top:-100px;   離上面
/*bottom:*/   離下麵
/*right:*/    離右邊

absolute 絕對定位

相對於父級標簽移動,原來的位置不占著,會造成下麵的標簽頂上去的情況

css代碼:

position:absolute;
top:20px;
left:80px;

fixed 固定定位

按照瀏覽器視窗的位置進行移動

html代碼:

<spanclass="s1"><ahref="">返回頂部</a></span>

css代碼:

.s1{
position:fixed;
left:40px;
bottom:20px;
}

優先順序

!important>行內樣式>ID選擇器>類選擇器>標簽

越精準的定位優先順序越高

繼承

標簽

id

!important

無敵

練習(下周一之前完成即可):

通過html和css完成小米商城首頁的開發,暫不需要完成動態效果,有頁

面展示效果就可以(https://www.mi.com/

註意:前端頁面效果可以通過很多種方式實現,沒有標準答案,大家

可以參考小米官網源碼,也可以根據自己想法去實現


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

-Advertisement-
Play Games
更多相關文章
  • 隨著Kotlin的推廣,一些國內公司的安卓項目開發,已經從Java完全切成Kotlin了。雖然Kotlin在各類編程語言中的排名比較靠後(據TIOBE發佈了 19 年 8 月份的編程語言排行榜,Kotlin竟然排名45位),但是作為安卓開發者,掌握該語言,卻已是大勢所趨了。 Kotlin的基礎用法, ...
  • 協程中的Channel用於協程間的通信, 它的宗旨是: ``` Do not communicate by sharing memory; instead, share memory by communicating. ``` ...
  • 閑來無事看到了一個關於Vue的MVVM的簡單講解,覺得寫得不錯,做個分享。 文章地址 https://github.com/DMQ/mvvm 文章內容我就不貼出,比較簡潔明瞭,我記錄一下我的一些思考總結。 PS:建議先仔細讀這篇文章。 MVVM MVVM即雙向數據綁定,是一種設計模式,一般是Web前 ...
  • 使用three.js創建大小不隨著場景變化的文字,需要以下兩步: 1、將文字繪製到畫布上。 2、創建著色器材質,把文字放到三維場景中。 優點: 1、跟用html實現文字相比,這些文字可以被模型遮擋,更具有三維效果。 2、不會隨著場景旋轉縮放改變尺寸,不存在遠處看不清的情況,適用於三維標註。 效果圖: ...
  • 五類 IP 地址 TOP 網路地址:用於識別主機所在的網路; 主機地址:用於識別該網路中的主機。 IP地址分為五類: A 類保留給政府機構 B 類分配給中等規模的公司 C 類分配給任何需要的人 D 類用於用於特殊用途. 又稱做廣播地址 E 類暫時保留 各類可容納的地址數目不同。其中A類、B類、和C類 ...
  • cookie,sessionstorage,localstorage區別 ...
  • 1、filter() 方法創建一個新的數組,新數組中的元素是通過檢查指定數組中符合條件的所有元素。 原數組不變 不會對空數組進行檢測 2、find() 對於空數組,函數是不會執行的。 不會改變原數組 返回符合測試條件的第一個數組元素值 3、some 用於檢測數組中的元素是否滿足指定條件會依次執行數組 ...
  • 基本包裝類型 普通變數不能直接調用屬性或者方法 對象可以直接調用屬性和方法 基本包裝類型: 本身是基本類型, 但是在執行代碼的過程中, 如果這種類型的變數調用了屬性或者是方法, 那麼這種類型就不再是基本類型了, 而是基本包裝類型, 這個變數也不是普通的變數了, 而是基本包裝類型對象 string n ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...