CSS布局解決方案(終結版)

前端布局非常重要的一環就是頁面框架的搭建,也是最基礎的一環。在頁面框架的搭建之中,又有居中布局、多列布局以及全局布局,今天我們就來總結總結前端干貨中的CSS布局。

居中布局

水平居中

1)使用inline-block+text-align
(1)原理、用法

  • 原理:先將子框由塊級元素改變為行內塊元素,再通過設置行內塊元素居中以達到水平居中。
  • 用法:對子框設置display:inline-block,對父框設置text-align:center。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.child{display:inline-block;
}
.parent{text-align:center;
}

(3)優缺點

  • 優點:兼容性好,甚至可以兼容ie6、ie7
  • 缺點:child里的文字也會水平居中,可以在.child添加text-align:left;還原

2)使用table+margin
(1)原理、用法

  • 原理:先將子框設置為塊級表格來顯示(類似 <table>),再設置子框居中以達到水平居中。
  • 用法:對子框設置display:table,再設置margin:0 auto。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.child {display:table;margin:0 auto;
}

(3)優缺點:

  • 優點:只設置了child,ie8以上都支持
  • 缺點:不支持ie6、ie7,將div換成table

3)使用absolute+transform
(1)原理、用法

  • 原理:將子框設置為絕對定位,移動子框,使子框左側距離相對框左側邊框的距離為相對框寬度的一半,再通過向左移動子框的一半寬度以達到水平居中。當然,在此之前,我們需要設置父框為相對定位,使父框成為子框的相對框。
  • 用法:對父框設置position:relative,對子框設置position:absolute,left:50%,transform:translateX(-50%)。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {position:relative;
}
.child {position:absolute;left:50%;transform:translateX(-50%);
}

(3)優缺點

  • 優點:居中元素不會對其他的產生影響
  • 缺點:transform屬于css3內容,兼容性存在一定問題,高版本瀏覽器需要添加一些前綴

4)使用flex+margin
(1)原理、用法

  • 原理:通過CSS3中的布局利器flex將子框轉換為flex item,再設置子框居中以達到居中。
  • 用法:先將父框設置為display:flex,再設置子框margin:0 auto。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {display:flex;
}
.child {margin:0 auto;
}

(3)優缺點

  • 缺點:低版本瀏覽器(ie6 ie7 ie8)不支持

5)使用flex+justify-content
(1)原理、用法

  • 原理:通過CSS3中的布局利器flex中的justify-content屬性來達到水平居中。
  • 用法:先將父框設置為display:flex,再設置justify-content:center。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {display:flex;justify-content:center;
}

(3)優缺點

  • 優點:設置parent即可
  • 缺點:低版本瀏覽器(ie6 ie7 ie8)不支持

垂直居中

1)使用table-cell+vertical-align
(1)原理、用法

  • 原理:通過將父框轉化為一個表格單元格顯示(類似 <td> 和 <th>),再通過設置屬性,使表格單元格內容垂直居中以達到垂直居中。
  • 用法:先將父框設置為display:table-cell,再設置vertical-align:middle。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {display:table-cell;vertical-align:middle;
}

(3)優缺點

  • 優點:兼容性較好,ie8以上均支持

2)使用absolute+transform
(1)原理、用法

  • 原理:類似于水平居中時的absolute+transform原理。將子框設置為絕對定位,移動子框,使子框上邊距離相對框上邊邊框的距離為相對框高度的一半,再通過向上移動子框的一半高度以達到垂直居中。當然,在此之前,我們需要設置父框為相對定位,使父框成為子框的相對框。
  • 用法:先將父框設置為position:relative,再設置子框position:absolute,top:50%,transform:translateY(-50%)。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {position:relative;
}
.child {position:absolute;top:50%;transform:translateY(-50%);
}

(3)優缺點

  • 優點:居中元素不會對其他的產生影響
  • 缺點:transform屬于css3內容,兼容性存在一定問題,高版本瀏覽器需要添加一些前綴

3)使用flex+align-items
(1)原理、用法

  • 原理:通過設置CSS3中的布局利器flex中的屬性align-times,使子框垂直居中。
  • 用法:先將父框設置為position:flex,再設置align-items:center。

(1)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {position:flex;align-items:center;
}

(3)優缺點

  • 優點:只設置parent
  • 缺點:兼容性存在一定問題

水平垂直居中

1)使用absolute+transform
(1)原理、用法

  • 原理:將水平居中時的absolute+transform和垂直居中時的absolute+transform相結合。詳見:水平居中的3)和垂直居中的2)。
  • 見水平居中的3)和垂直居中的2)。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {position:relative;
}
.child {position:absolute;left:50%;top:50%;transform:tranplate(-50%,-50%);
}

(3)優缺點

  • 優點:child元素不會對其他元素產生影響
  • 缺點:兼容性存在一定問題

2)使用inline-block+text-align+table-cell+vertical-align
(1)原理、用法

  • 原理:使用inline-block+text-align水平居中,再用table-cell+vertical-align垂直居中,將二者結合起來。詳見:水平居中的1)和垂直居中的1)。
  • 見水平居中的1)和垂直居中的1)。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {text-align:center;display:table-cell;vertical-align:middle;
}
.child {display:inline-block;
}

(3)優缺點

  • 優點:兼容性較好

3)使用flex+justify-content+align-items
(1)原理、用法

  • 原理:通過設置CSS3布局利器flex中的justify-content和align-items,從而達到水平垂直居中。詳見:水平居中的4)和垂直居中的3)。
  • 見水平居中的4)和垂直居中的3)。

(2)代碼實例

<div class="parent"><div class="child>DEMO</div>
</div>
.parent {display:flex;justify-content:center;align-items:center;
}

(3)優缺點

  • 優點:只設置了parent
  • 缺點:兼容性存在一定問題

多列布局

定寬+自適應

1)使用float+overflow
(1)原理、用法

  • 原理:通過將左邊框脫離文本流,設置右邊規定當內容溢出元素框時發生的事情以達到多列布局。
  • 用法:先將左框設置為float:left、width、margin-left,再設置實際的右框overflow:hidden。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.left {float:left;width:100px;margin-right:20px;
}
.right {overflow:hidden;
}

(3)優缺點

  • 優點:簡單
  • 缺點:不支持ie6

2)使用float+margin
(1)原理、用法

  • 原理:通過將左框脫離文本流,加上右框向右移動一定的距離,以達到視覺上的多列布局。
  • 用法:先將左框設置為float:left、margin-left,再設置右框margin-left。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.left {float:left;width:100px;
}
.right {margin-left:120px;
}

(3)優缺點

  • 優點:簡單,易理解
  • 缺點:兼容性存在一定問題,ie6下有3px的bug。right下的p清除浮動將產生bug

3)使用float+margin(改良版)
(1)原理、用法

  • 原理:在1)的基礎之上,通過向右框添加一個父框,再加上設置左、右父框屬性使之產生BFC以去除bug。
  • 用法:先將左框設置為float:left、margin-left、position:relative,再設置右父框float:right、width:100%、margin-left,最后設置實際的右框margin-left。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="rigth-fix"><div class="right"><p>right</p><p>right</p></div></div>
</div>
.left {float:left;width:100px;position:relative;
}
.right-fix {float:right;width:100%;margin-left:-100px;
}
.right {margin-left:120px;
}

(3)優缺點

  • 優點:簡單,易理解

4)使用table
(1)原理、用法

  • 原理:通過將父框設置為表格,將左右邊框轉化為類似于同一行的td,從而達到多列布局。
  • 用法:先將父框設置為display:table、width:100%、table-layout:fixed,再設置左右框display:table-cell,最后設置左框width、padding-right。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.parent {display:table;width:100%;table-layout:fixed;
}
.left {width:100px;padding-right:20px;
}
.right,.left {display:table-cell;    
}

5)使用flex
(1)原理、用法

  • 原理:通過設置CSS3布局利器flex中的flex屬性以達到多列布局。
  • 用法:先將父框設置為display:flex,再設置左框flex:1,最后設置左框width、margin-right。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.parent {display:flex;
}
.left {width:100px;margin-right:20px;
}
.right {flex:1;
}

(3)優缺點

  • 優點:flex很強大
  • 缺點:兼容性存在一定問題,性能存在一定問題

兩列定寬+一列自適應

(1)原理、用法

  • 原理:這種情況與兩列定寬查不多。
  • 用法:先將左、中框設置為float:left、width、margin-right,再設置右框overflow:hidden。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="center"><p>center</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.left,.center {float:left;width:100px;margin-right:20px;
}
.right {overflow:hidden;
}

不定寬+自適應

1)使用float+overflow
(1)原理、用法

  • 原理:這種情況與兩列定寬查不多。
  • 用法:先將左框設置為float:left、margin-right,再設置右框overflow: hidden,最后設置左框中的內容width。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.left{float: left;margin-right: 20px;}
.right{overflow: hidden;
}
.left p{width: 200px;
}

(3)優缺點

  • 優點:簡單
  • 缺點:ie6下兼容性存在一定問題

2)使用table
(1)原理、用法

  • 原理:通過將父框改變為表格,將左右框轉換為類似于同一行的td以達到多列布局,設置父框寬度100%,給左框子元素一個固定寬度從而達到自適應。
  • 用法:先將父框設置為display: table、width: 100%,再設置左、右框display: table-cell,最后設置左框width: 0.1%、padding-right以及左框中的內容width。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.parent{display: table; width: 100%;}
.left,.right{display: table-cell;
}
.left{width: 0.1%;padding-right: 20px;
}
.left p{width:200px;
}

(3)優缺點

  • 缺點:ie6 ie7不支持

3)使用flex
(1)原理、用法

  • 原理:通過設置CSS3布局利器flex中的flex屬性以達到多列布局,加上給左框中的內容定寬、給右框設置flex達到不定款+自適應。
  • 用法:先將父框設置為display:flex,再設置右框flex:1,最后設置左框margin-right:20px、左框中的內容width。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.parent {display:flex;
}
.left {margin-right:20px;
}
.right {flex:1;
}
.left p{width: 200px;
}

(3)優缺點

  • 優點:flex很強大
  • 缺點:兼容性存在一定問題,性能存在一定問題

兩列不定寬+一列自適應

(1)原理、用法

  • 原理:這個情況與一列不定寬+一列自適應查不多。
  • 用法:先將左、中框設置為float:left、margin-right,再設置右框overflow:hidden,最后給左中框中的內容設置width。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="center"><p>center</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.left,.center{float: left;margin-right: 20px;
}
.right{overflow: hidden;
}
.left p,.center p{width: 100px;
}

等分布局

圖片描述

公式轉化:
l = w * n + g * (n-1) -> l = w * n + g * n - g -> l + g = (w + g) * n

圖片描述

因此,我們需要解決兩個問題:

  • 如何讓總寬度增加g(即:L+g)
  • 如何讓每個寬包含g(即:w+g)

1)使用float
(1)原理、用法

  • 原理:增大父框的實際寬度后,使用CSS3屬性box-sizing進行布局的輔助。
  • 用法:先將父框設置為margin-left: -*px,再設置子框float: left、width: 25%、padding-left、box-sizing: border-box。

(2)代碼實例

<div class="parent"><div class="column"><p>1</p></div><div class="column"><p>2</p></div><div class="column"><p>3</p></div><div class="column"><p>4</p></div>
</div>
.parent{margin-left: -20px;//l增加g
}
.column{float: left;width: 25%;padding-left: 20px;box-sizing: border-box;//包含padding區域 w+g
}

(3)優缺點

  • 優點:兼容性較好
  • 缺點:ie6 ie7百分比兼容存在一定問題

2)使用table
(1)原理、用法

  • 原理:通過增加一個父框的修正框,增大其寬度,并將父框轉換為table,將子框轉換為tabel-cell進行布局。
  • 用法:先將父框的修正框設置為margin-left: -*px,再設置父框display: table、width:100%、table-layout: fixed,設置子框display: table-cell、padding-left。

(2)代碼實例

<div class="parent-fix"><div class="parent"><div class="column"><p>1</p></div><div class="column"><p>2</p></div><div class="column"><p>3</p></div><div class="column"><p>4</p></div></div>
</div>
.parent-fix{margin-left: -20px;//l+g
}
.parent{display: table;width:100%;table-layout: fixed;
}
.column{display: table-cell;padding-left: 20px;//w+g
}

(3)優缺點

  • 優點:結構和塊數無關聯
  • 缺點:增加了一層

3)使用flex
(1)原理、用法

  • 原理:通過設置CSS3布局利器flex中的flex屬性以達到等分布局。
  • 用法:將父框設置為display: flex,再設置子框flex: 1,最后設置子框與子框的間距margin-left。

(2)代碼實例

<div class="parent"><div class="column"><p>1</p></div><div class="column"><p>2</p></div><div class="column"><p>3</p></div><div class="column"><p>4</p></div>
</div>
.parent{display: flex;
}
.column{flex: 1;
}
.column+.column{margin-left:20px;
}

(3)優缺點

  • 優點:代碼量少,與塊數無關
  • 缺點:兼容性存在一定問題

定寬+自適應+兩塊高度一樣高

1)使用float
(1)原理、用法

  • 原理:通過過分加大左右子框的高度,輔助超出隱藏,以達到視覺上的等高。
  • 用法:將父框設置overflow: hidden,再設置左右子框padding-bottom: 9999px、margin-bottom: -9999px,最后設置左框float: left、width、margin-right,右框overflow: hidden。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
p{background: none!important;
}
.left,.right{background: #444;
}
.parent{overflow: hidden;
}
.left,.right{padding-bottom: 9999px;margin-bottom: -9999px;
}
.left{float: left; width: 100px;margin-right: 20px;
}
.right{overflow: hidden;
}

(3)優缺點

  • 優點:兼容性好
  • 缺點:偽等高,不是真正意義上的等高

2)使用table
(1)原理、用法

  • 原理:將父框轉化為tabel,將子框轉化為tabel-cell布局,以達到定寬+自適應+兩塊高度一樣高。
  • 用法:先將父框設置為display:table、width:100%、table-layout:fixed,再設置左右框為display:table-cell,最后設置左框width、padding-right。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.parent {display:table;width:100%;table-layout:fixed;
}
.left {width:100px;padding-right:20px;
}
.right,.left {display:table-cell;
}

3)使用flex
(1)原理、用法

  • 原理:通過設置CSS3布局利器flex中的flex屬性以達到定寬+自適應+兩塊高度一樣高。
  • 用法:將父框設置為display: flex,再設置左框width、margin-right,最后設置右框flex:1。

(2)代碼實例

<div class="parent"><div class="left"><p>left</p></div><div class="right"><p>right</p><p>right</p></div>
</div>
.parent {display:flex;
}
.left {width:100px;margin-right:20px;
}
.right {flex:1;
}

(3)優缺點

  • 優點:代碼少,flex很強大
  • 缺點:兼容性存在一定問題

4)使用display
(1)原理、用法

  • 原理:通過設置display中的CSS3的-webkit-box屬性以達到定寬+自適應+兩塊高度一樣高。
  • 用法:將父框設置為display: -webkit-box、width: 100%,再設置左框width、margin-right,最后設置右框-webkit-box-flex: 1。

(2)代碼實例

<div class="parent"><div class="left">left</div><div class="right">right </div>
</div>
.parent {width: 100%;display: -webkit-box;
}
.left {width:100px;margin-right: 20px;
}
.right {-webkit-box-flex: 1;
}

(3)優缺點

  • 缺點:兼容性存在較大的問題

全屏布局

全屏布局的特點

  • 滾動條不是全局滾動條,而是出現在內容區域里,往往是主內容區域
  • 瀏覽器變大時,撐滿窗口

全屏布局的方法

圖片描述

1)使用position
(1)原理、用法

  • 原理:將上下部分固定,中間部分使用定寬+自適應+兩塊高度一樣高。
  • 用法:見實例。

(2)代碼實例

<div class="parent"><div class="top">top</div><div class="left">left</div><div class="right"><div class="inner">right</div></div><div class="bottom">bottom</div>
</div>
html,body,.parent{margin:0;height:100%;overflow:hidden;
}
body{color:white;
}
.top{position:absolute;top:0;left:0;right:0;height:100px;background:blue;
}
.left{position:absolute;left:0;top:100px;bottom:50px;width:200px;background:red;
}
.right{position:absolute;left:200px;top:100px;bottom:50px;right:0;background:pink;overflow: auto;
}
.right .inner{min-height: 1000px;
}
.bottom{position:absolute;left:0;right:0;bottom:0;height:50px;background: black;
}

(3)優缺點

  • 優點:兼容性好,ie6下不支持

2)使用flex
(1)原理、用法

  • 原理:通過靈活使用CSS3布局利器flex中的flex屬性和flex-direction屬性以達到全屏布局。
  • 用法:見實例。

(2)代碼實例

<div class="parent"><div class="top">top</div><div class="middle"><div class="left">left</div><div class="right"><div class="inner">right</div></div></div><div class="bottom">bottom</div>
</div>
html,body,.parent{margin:0;height:100%;overflow:hidden;
}
body{color: white;
} 
.parent{display: flex;flex-direction: column;
}
.top{height:100px;background: blue;
}
.bottom{height:50px;background: black;
}
.middle{flex:1;display:flex;
}
.left{width:200px;background: red;
}
.right{flex: 1;overflow: auto;background:pink;
}
.right .inner{min-height: 1000px;
}

(3)優缺點

  • 缺點:兼容性差,ie9及ie9以下不兼容

圖片描述

1)使用flex
(1)原理、用法

  • 原理:通過靈活使用CSS3布局利器flex中的flex屬性和flex-direction屬性以達到全屏布局。
  • 用法:見實例。

(2)代碼實例

<div class="parent"><div class="top">top</div><div class="middle"><div class="left">left</div><div class="right"><div class="inner">right</div></div></div><div class="bottom">bottom</div>
</div>
html,body,.parent{margin:0;height:100%;overflow:hidden;
}
body{color:white;
} 
.parent{display:flex;flex-direction:column;
}
.top{background:blue;
}
.bottom{background:black;
}
.middle{flex:1;display:flex;
}
.left{background: red;
}
.right{flex:1;overflow:auto;background: pink;
}
.right .inner{min-height:1000px;
}

全屏布局相關方案的兼容性、性能和自適應一覽表

方案兼容性性能是否自適應
Position部分自適應
Flex較差可自適應
Grid較好可自適應

當然,最最最最最后,如果您喜歡這片文章,可以瘋狂點贊和收藏喔!!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/283975.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/283975.shtml
英文地址,請注明出處:http://en.pswp.cn/news/283975.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

基于ABP和Magicodes實現Excel導出操作

前端使用的vue-element-admin框架&#xff0c;后端使用ABP框架&#xff0c;Excel導出使用的Magicodes.IE.Excel.Abp庫。Excel導入和導出操作幾乎一樣&#xff0c;不再介紹。文本主要介紹Excel導出操作和過程中遇到的坑&#xff0c;主要是Excel文件導出后無法打開的問題。一.Mag…

消息模式在實際開發應用中的優勢

曾經.NET面試過程中經常問的一個問題是&#xff0c;如果程序集A&#xff0c;引用B &#xff0c;B 引用C&#xff0c;那么C怎么去訪問A中的方法呢。 這個問題初學.net可能一時想不出該咋處理&#xff0c;這涉及到循環引用問題。但有點經驗的可能就簡單了&#xff0c;通過委托的方…

微服務:注冊中心ZooKeeper、Eureka、Consul 、Nacos對比

前言 服務注冊中心本質上是為了解耦服務提供者和服務消費者。對于任何一個微服務&#xff0c;原則上都應存在或者支持多個提供者&#xff0c;這是由微服務的分布式屬性決定的。更進一步&#xff0c;為了支持彈性擴縮容特性&#xff0c;一個微服務的提供者的數量和分布往往是動…

MyBatis總結七:動態sql和sql片段

開發中&#xff0c;sql拼接很常見&#xff0c;所以說一下動態sql&#xff1a; 1if2chose,when,otherwise3where,set4foreach用法解析(現有一張users表 內有id username age 三個字段)&#xff1a; <!--查詢所有用戶&#xff0c;傳遞參數type&#xff0c;如果值為0&#xff0…

iOS - OC Copy 拷貝

前言 copy&#xff1a;需要先實現 NSCopying 協議&#xff0c;創建的是不可變副本。mutableCopy&#xff1a;需要實現 NSMutableCopying 協議&#xff0c;創建的是可變副本。淺拷貝&#xff1a;指針拷貝&#xff0c;源對象和副本指向的是同一個對象。對象的引用計數器 &#xf…

三.選擇結構(一)

1.if結構: if(條件){ 代碼塊 } 2.隨機產生數: int randon (int)(Math.random()*10); 3.多重if選擇結構: if(條件1){ 代碼塊1 }else if (條件2){ 代碼塊2 }else{ 代碼塊3 } 4.嵌套if選擇結構: if(條件1){ if(條件2){ 代碼塊1 }else{ 代碼塊2 } }else{ 代碼塊3 } 轉載于:https://…

為了高性能、超大規模的模型訓練,這個組合“出道”了

點擊上方藍字關注我們&#xff08;本文閱讀時間&#xff1a;3分鐘)近年來&#xff0c;在大量數據上訓練的基于 transformer 的大規模深度學習模型在多項認知任務中取得了很好的成果&#xff0c;并且被使用到一些新產品和功能背后&#xff0c;進一步增強了人類的能力。在過去五年…

SVN就是這么簡單

什么是SVN SVN全稱&#xff1a;Subversion&#xff0c;是一個開放源代碼的版本控制系統 Svn是一種集中式文件版本管理系統。集中式代碼管理的核心是服務器&#xff0c;所有開發者在開始新一天的工作之前必須從服務器獲取代碼&#xff0c;然后開發&#xff0c;最后解決沖突&…

SpringCloud必會知識點大全

為什么要學習Spring Cloud 在項目開發中隨著業務越來越多&#xff0c;導致功能之間耦合性高、開發效率低、系統運行緩慢難以維護、不穩定。微服務 架構可以解決這些問題&#xff0c;而Spring Cloud是微服務架構最流行的實現. 1.微服務 微服務架構是使用一套小服務來開發單個應用…

thinkphp3.22 多項目配置

1.index.php if(version_compare(PHP_VERSION,5.3.0,<)) die(require PHP > 5.3.0 !); // 開啟調試模式 建議開發階段開啟 部署階段注釋或者設為false define(APP_DEBUG,true); // 創建 //define(BIND_MODULE,Login); define(erp,true); // 定義應用目錄 define(APP_PAT…

30分鐘掌握 C#7

1. out 變量&#xff08;out variables&#xff09; 以前我們使用out變量必須在使用前進行聲明&#xff0c;C# 7.0 給我們提供了一種更簡潔的語法 “使用時進行內聯聲明” 。如下所示&#xff1a; 1 var input ReadLine(); 2 if (int.TryParse(input, out var result)) 3 …

在 C# 中如何檢查參數是否為 null

前言前不久&#xff0c;微軟宣布從 C# 11 中移除參數空值檢查功能&#xff0c;該功能允許在方法開始執行之前&#xff0c;在參數名稱的末尾提供參數空值檢查&#xff08;!!操作符&#xff09;。那么&#xff0c;在 C# 中如何檢查參數是否為 null 呢&#xff1f;1. null這個可能…

什么是Maven快照(SNAPSHOT)

本文來說下Maven的SNAPSHOT版本有什么作用 文章目錄 問題解決 正式版本"abc-1.0"快照版本"abc-1.0-SNAPSHOT"本文小結問題 在使用maven進行依賴管理時&#xff0c;有的版本號后面會帶有"-SNAPSHOT"&#xff0c;有什么作用呢&#xff1f; <dep…

帶你剖析WebGis的世界奧秘----Geojson數據加載(高級)

前言&#xff1a;前兩周我帶你們分析了WebGis中關鍵步驟瓦片加載點擊事件&#xff08;具體的看前兩篇文章&#xff09;&#xff0c;下面呢&#xff0c;我帶大家來看看Geojson的加載及其點擊事件 Geojson數據解析 GeoJSON是一種對各種地理數據結構進行編碼的格式。GeoJSON對象可…

如果要存ip地址,用什么數據類型比較好

在看高性能MySQL第3版&#xff08;4.1.7節&#xff09;時&#xff0c;作者建議當存儲IPv4地址時&#xff0c;應該使用32位的無符號整數&#xff08;UNSIGNED INT&#xff09;來存儲IP地址&#xff0c;而不是使用字符串。但是沒有給出具體原因。為了搞清楚這個原因&#xff0c;查…

微軟 .NET Core 3.1 年底將結束支持,請升級到.NET 6

微軟近日宣布&#xff0c;將于 2022 年 12 月 13 日停止為 .NET Core 3.1 提供服務更新、安全修復和技術支持。.NET Core 是一個免費開源的、用于 Windows、Linux 和 macOS 操作系統的軟件框架。該項目主要由微軟員工通過 .NET 基金會開發&#xff0c;并在 MIT 許可下發布。202…

軟件團隊的模式選擇

軟件團隊的模式分為&#xff1a;主治醫生模式、明星模式、社區模式、業余劇團模式、秘密團隊、特工團隊、交響樂團模式、爵士樂模式、功能團隊模式和官僚模式。 經過小組的討論&#xff0c;我們決定選用交響樂團模式獲得功能團隊模式。 交響樂團模式的優點是種類多&#xff0c;…

Angular 2

1. Angular2 官網 https://angular.io/guide/quickstart Node.js 下載 https://nodejs.org/en/ 怎么在vs code中使用angualr2 https://code.visualstudio.com/docs/nodejs/angular-tutorial moment.js:(javacript日期處理庫) http://momentjs.cn/ 2. ng2-hightCharts https://…

「Docker入門指北」容器很難理解?帶你從頭到尾捋一遍

文章目錄 1. 初始虛擬化 &#x1f351; 虛擬化概念&#x1f351; 硬件虛擬化2. Docker容器 &#x1f351; Docker技術的誕生&#x1f351; 容器與虛擬化&#x1f351; 性能差別&#x1f351; Docker優勢 編排有序高效易遷移快速部署3. 容器生態系統 &#x1f351; 核心技術 容器…

微服務:事務管理

幾乎所有的信息管理系統都會涉及到事務&#xff0c;事務的目的是為了保證數據的一致性&#xff0c;這里說的一致性是數據庫狀態的一致性。說到數據庫狀態的一致性&#xff0c;相信大家都會想到 ACID &#xff1a;原子性&#xff08;Atomic&#xff09;&#xff1a;在一個事件的…