做爲前端,在工做中不免會遇到關於排版的問題,如下是我整理的一些關於CSS的技巧,但願對你能有幫助。css
通常咱們會用JS實現,其實CSS就能夠實現。
JS代碼:前端
var str = 'hello world'; str.replace(/( |^)[a-z]/g,(L)=>L.toUpperCase() Heool World
css實現:css3
text-transform:capitalize; ( 文本中每一個單詞以大寫字母開頭) text-transform的屬性值有: uppercase (所有大寫) lowercase (所有小寫) capitalize (首字母大寫) none (默認)
如input元素: input:checked + .check { color:red; }
有時候咱們給元素設置border-top的時候,並不想給第一個元素設置web
li+li { border-top: 1px solid red; }
display:table;
display:flow-root;
在input的type類型爲text/password時,size的屬性值表明input可容納的字符的個數,除此以外size 屬性會告訴用戶端其初始寬度,寬度以 ‘px’ 的形式給出
position的屬性你們常見的應該就是absolute、fixed、static
爲你們介紹一個新的屬性 stickyapi
position:sticky; 設置sticky的同時給元素一個(top,botton,left,right)便可使用 使用條件: 一、父元素不能overflow:hidden 或者 overflow:auto 二、必須指定 top、bottom、left、right 三、父元素的高度不能低於sticky元素的搞丟 四、sticky元素僅在其父元素內生效
原始的button按鈕要重置挺麻煩的,要設置好幾個屬性瀏覽器
button { background: none; border: none; color: inherit; font: inherit; outline: none; padding: 0; } 其實值須要設置 button { all:unset; }
文本省略號,相信你們都很經常使用字體
這是不折行的狀況 div { white-space:nowrap;/* 規定文本是否折行 */ overflow: hidden;/* 規定超出內容寬度的元素隱藏 */ text-overflow: ellipsis; /* 規定超出的內容文本省略號顯示,一般跟上面的屬性連用,由於沒有上面的屬性不會觸發超出規定的內容 */ } 折行 div { overflow: hidden; text-overflow: ellipsis; display: -webkit-box; /* 將對象做爲彈性伸縮盒子模型顯示 */ -webkit-line-clamp: 4; /* 控制最多顯示幾行 */ -webkit-box-orient: vertical; /* 設置或檢索伸縮盒對象的子元素的排列方式 */ }
div { width: 100px; padding: 0 10px; background: pink; margin-bottom: 10px; text-align-last:justify; /* 關鍵屬性 */ }
當給元素添加行高咱們須要分別添加到每個元素上p、h,可是其實咱們直接添加到body上就能夠了url
body { line-height:1; }
p:first-letter{ display:block; float:left; margin: 5px 5px 0 0; color:red; font-size:1.4rem; background:#ddd; }
a{ outline:none 或者 outline:0 }
div { width:calc(100%-100px) 讓寬度爲100%的減去100px }
<ul contenteditable="true"> <li>11111111 </li> <li>2222222</li> <li>3333333</li> </ul>
p{ font-size:0; } p{ text-indent:-1000; }
img { object-fit:cover; 或者 contain }
div { filter:blur(2px) }
div { width:fill-available; // 等同於block } div { width:fill-content; // 等同於inline-block }
link的四種狀態,須要按照下面的先後順序來設置 a:link a:visited a:hover a:active
瀏覽器的缺省字體大小是16px,你能夠先將基準字體大小設爲10px:spa
body {font-size:62.5%;}
後面統一採用em做爲字體單位,2.4em就表示24px。code
h1 {font-size: 2.4 em}
默認狀況下,瀏覽器會用黑圈來充當列表標誌,你能夠用圖片代替
ul li { background-image: url("path-to-your-image"); background-repeat: none; background-position: 0 0.5em; }
textarea { overflow: auto; }
這會讓你的彩色照片變成黑白的圖像
img.desaturate { filter: grayscale(100%); -webkit-filter: grayscale(100%); -moz-filter: grayscale(100%); -ms-filter: grayscale(100%); -o-filter: grayscale(100%); }
通常咱們給元素添加樣式會先給因此的都添加,而後再取消咱們不想要的哪一個元素樣式
/* add border */.nav li { border-right: 1px solid #666;} /* remove border */.nav li:last-child { border-right: none;}
能夠直接使用:not() 僞類實現
.nav li:not(:last-child) { border-right: 1px solid #666;}
css3屬性,當一個元素設置以後將沒法點擊 .disabled { pointer-events: none; }
.blur { color: transparent; text-shadow: 0 0 5px rgba(0,0,0,0.5); }
div {user-select: none; /* Standard syntax */}