css - 這種零碎的重復樣式該怎樣寫最優~
問題描述
問題解答
回答1:沒有必要對一個個的零散的重復屬性糾結,而應該把重心放到可重用的模塊上。不然你會越來越無法自拔,題目中開頭那段代碼我覺得就是最好的
回答2:可以利用js
回答3:可以花個10分鐘了解一下sass
回答4:看公共代碼的代碼量 和 功能
假如你有3個元素
.demo1{position: absolute;border: 1px solid #000; } .demo2{position: absolute;border: 2px solid #f55; } .demo3{position: absolute;border: 3px solid #f30; }
它們都有一個公共的postion:absolute;然后你提取出來單獨寫
.demo1,.demo2,.demo3{position: absolute; }
可以看出,這樣毫無意義,就一條代碼,提不提出來都無所謂。。最多增強一點微不足道的可讀性
但是如果是一大串功能性代碼,比如清除浮動,那么肯定要提取出來方便復用,比如SASS的做法:
%clearfix { *zoom: 1; &:before, &:after {display: table;content: ’’; } &:after {clear: both;overflow: hidden; }}
那么隨便你再哪里調用它,比如
.demo1{@extend %clearfix;.....其他代碼}.nav{@extend %clearfix;......其他代碼}sub-nav{@extend %clearfix;......其他代碼}最后都會自動合并為.demo1,.nav,.sub-nav{清除浮動公共代碼}
其實這和JS的function一樣,大量復用的自然做成插件,單獨一句console.log(XXX),雖然也到處寫,難道你還需要給它做成個插件么?直接寫就行了,不用糾結
相關文章:
1. Docker for Mac 創建的dnsmasq容器連不上/不工作的問題2. java - SSH框架中寫分頁時service層中不能注入分頁類3. node.js - 終端 遠程連接服務器,終端關閉后,服務器無法運行4. debian - docker依賴的aufs-tools源碼哪里可以找到???5. java - instance method中 static后的<K>是什么意思?6. docker - 如何修改運行中容器的配置7. javascript - QWebEngineView 如何爬 angular 的動態數據?8. java - 關于File的問題?9. python3.x - python連oanda的模擬交易api獲取json問題第五問10. php - 一個操作請求多個服務如何保證數據的安全?
