鍓嶇瀛︿範-10涓猟emo绀轰緥瀛︿細CSS3 radial-gradient寰勫悜娓愬彉

匿名 (未验证) 提交于 2019-12-02 16:45:31

涓€銆佽娉曠粏鑺傝涓嶄綇鎬庝箞鍔烇紵
瀹為檯寮€鍙戠殑鏃跺€欙紝褰撹浣跨敤radial-gradient寰勫悜娓愬彉鐨勬椂鍊欙紝鑴戜腑浼氭湁澶ф鐨勮娉曪紝浣嗘槸缁嗚妭鍗磋涓嶄綇锛屼簬鏄兂蹇嵎鎵句釜妗堜緥鐪嬬湅鍏蜂綋鎬庝箞鐢紝鐒跺悗鐩存帴濂椾竴涓嬨€傞€氬父涓€鐣悳绱紝浼氬彂鐜拌櫧鐒舵槸涓畝鍗曢渶姹傦紝浣嗘槸姝eソ婊¤冻杩欎釜闇€姹傜殑椤甸潰鍗翠笉濂芥壘锛屼贡绯熺碂鐨勩€侟/p>

涓嬫閬囧埌杩欑鍦烘櫙锛岀洿鎺ユ潵鏈珯鎼溾€滃緞鍚戞笎鍙樷€濓紝鎴栬€呯洿鎺ユ悳绱⑩€滄笎鍙樷€濓紝灏辨湁涓撻棬灞曠ずradial-gradient寰勫悜娓愬彉鍩烘湰璇硶浣跨敤妗堜緥鐨勬枃绔犮€傛枃绔犲叡灞曠ず浜?0渚嬪父瑙佷娇鐢ㄦ渚嬶紝鐩镐俊涓€瀹氬彲浠ヨ鐩栦綘鐨勪娇鐢ㄥ満鏅殑銆侟/p>

棣栧厛锛屽亣璁炬垜浠娇鐢ㄥ悓涓€娈礖TML浣滀负绀烘剰锛欬/p>

浜屻€佺ず渚?锛氭渶鍩虹鏈€绠€鍗曚娇鐢?/p>

CSS濡備笅锛欬/p>

.radial-gradient {     width: 400px; height: 200px;     background: radial-gradient(yellow, red); }

鏈€缁堟晥鏋滃涓嬪浘锛欬/p>

鍙锛屽浜庡緞鍚戞笎鍙橈紝鍦ㄤ笉鎸囧畾娓愬彉绫诲瀷浠ュ強浣嶇疆鐨勬儏鍐典笅锛屽叾娓愬彉璺濈鍜屼綅缃槸鐢卞鍣ㄧ殑灏哄鍐冲畾鐨勩€侟/p>

渚嬪鏈緥涔嬩腑锛屽鍣ㄧ殑瀹介珮姣旀槸2:1锛屾渶缁堟笎鍙樺憟鐜板嚭鏉ョ殑褰㈢姸涔熸槸涓€涓?:1鐨勬き鍦嗗舰锛屽苟涓旀笎鍙橀鑹茶嚜鍔ㄧ粓姝笌瀹瑰櫒鐨勮竟缂樸€侟/p>

鍘熺悊绀烘剰濡備笅锛欬/p>

涓夈€佺ず渚?锛氱畝鍗曠殑鍦嗗舰娓愬彉
CSS浠g爜濡備笅锛欬/p>

.radial-gradient {     width: 400px; height: 200px;     background: radial-gradient(circle, yellow, red); }

鍏舵笎鍙樿寖鍥达紙娓愬彉缁撴潫绾匡級绀烘剰濡備笅鍥撅紝浼氬彂鐜版棦涓嶆槸鎸夌収瀹藉害鏉ョ殑锛屼篃涓嶆槸鎸夌収楂樺害鏉ョ殑锛屾槸鎸夌収鏈€杩滆竟瑙掕窛绂讳綔涓烘笎鍙樼粨鏉熺嚎鐨勶細

鍏舵笎鍙樿寖鍥达紙娓愬彉缁撴潫绾匡級绀烘剰濡備笅鍥撅紝浼氬彂鐜版棦涓嶆槸鎸夌収瀹藉害鏉ョ殑锛屼篃涓嶆槸鎸夌収楂樺害鏉ョ殑锛屾槸鎸夌収鏈€杩滆竟瑙掕窛绂讳綔涓烘笎鍙樼粨鏉熺嚎鐨勶細

瑕佽瘉鏄庝笂闈㈢粨璁烘瘮杈冪畝鍗曪紝鎴戜滑鍙互璁$畻涓嬪瑙掔嚎涓€鍗婇暱搴︼紝涓猴細Math.sqrt(200200 + 400400) 鈮 223.6锛屼簬鏄紝鎴戜滑璁剧疆锛欬/p>

.radial-gradient {     width: 400px; height: 200px;     background: radial-gradient(223.6px circle, yellow, red); }

浼氬彂鐜帮紝鏈€缁堟晥鏋滃拰涓婇潰鐨勬晥鏋滄埅鍥惧嚑涔庡氨鏄竴妯′竴鏍风殑銆傝€?00px鐨勫崐寰勶細

.radial-gradient {     width: 400px; height: 200px;     background: radial-gradient(200px circle, yellow, red); }

鍙栬壊灏变細鍙戠幇杈圭紭棰滆壊宸紓杈冨ぇ锛岃鏄庨粯璁や笉鏄寜鐓ф渶鐭竟鏉ユ覆鏌撶殑銆侟/p>

鍥涖€佺ず渚?锛氭寚瀹氭笎鍙樿捣濮嬬偣浣嶇疆
璧峰鐐逛綅缃彲浠ラ€氳繃at鏉ユ寚瀹氾紝渚嬪锛欬/p>

.radial-gradient {     width: 400px; height: 200px;     background: radial-gradient(circle at 50px 50px, yellow, red); }

鏁堟灉濡備笅鍥炬墍绀猴細

濡傛灉甯屾湜娓愬彉鏄拰瀹瑰櫒淇濇寔涓€鑷存瘮渚嬬殑妞渾锛屽垯circle鍙互缂虹渷锛屼篃灏辨槸鐩存帴radial-gradient(at 50px 50px, yellow, red)涔熸槸鍙互鐨勩€侟/p>

50px 50px鎴戜滑涔熷彲浠ヤ娇鐢ㄧ櫨鍒嗘瘮鍊间唬鏇匡紝渚嬪锛欬/p>

.radial-gradient {     width: 400px; height: 200px;     background: radial-gradient(circle at 12.5% 25%, yellow, red); }

鏁堟灉鏄竴妯′竴鏍风殑銆侟/p>

浜斻€佺ず渚?锛氭寚瀹氭笎鍙樼粓姝㈢偣浣嶇疆
radial-gradient寰勫悜娓愬彉鏀寔4涓叧閿瓧鍙互鎸囧畾娓愬彉缁堟鐐逛綅缃紝瑙佷笅琛細

鏍规嵁涓婇潰鐨勭ず鎰忔晥鏋滃彲浠ョ湅鍑洪粯璁ゅ€兼槸farthest-corner銆侟/p>

鐜板湪锛屾垜浠CSS杩涜璋冩暣锛屽涓嬶細

.radial-gradient {     width: 400px; height: 200px;     background: radial-gradient(closest-side circle at 50px 50px, yellow, red); }

涔熷氨鏄渾褰㈡笎鍙樼粓姝簬鏈€鐭竟锛岀粨鏋滄晥鏋滃涓嬪浘锛欬/p>

鍏€佺ず渚?锛氭寚瀹氭笎鍙橀鑹叉柇鐐更br />濡傛灉鎸囧畾澶氫釜棰滆壊锛屼絾鏈寚瀹氬叿浣撴柇鐐圭殑浣嶇疆锛屽垯杩欎簺棰滆壊浼氬潎鍖€鍒嗛厤0%~100%鐨勬笎鍙樺尯鍩燂紝渚嬪锛屼笅闈?鑹叉笎鍙橈細

.radial-gradient {     width: 200px; height: 200px;     border: 1px solid silver;     background: radial-gradient(closest-side circle, yellow, orange, red, white); }

缁撴灉濡備笅鍥炬墍绀猴細

浣嗕粠鑲夌溂瑙嗚鎴戜滑鏄湅涓嶅嚭鏄笉鏄潎鍖€鍒嗛厤娓愬彉鍖哄煙锛屼絾鏄垜浠彲浠ラ€氳繃鍏朵粬鏂瑰紡楠岃瘉鎴戜滑鐨勮鐐癸紝濡備笅鎸囧畾棰滆壊鏂偣浣嶇疆鐨凜SS锛欬/p>

.radial-gradient2 {     width: 200px; height: 200px;     border: 1px solid gray;     background: radial-gradient(closest-side circle, yellow, orange 33.33%, red 66.666%, white); }

鐢变簬娓愬彉棰滆壊榛樿绗竴涓鑹蹭綅缃槸0%锛屾渶鍚庝竴涓鑹蹭綅缃槸100%锛屽洜姝や笂闈ellow鍜寃hite鐨勬柇鐐逛綅缃彲浠ョ己鐪併€侟/p>

鐒跺悗鍙戠幇鏁堟灉鍜屼笂闈㈢殑鏄竴鑷寸殑锛欬/p>

鎸変笅绗竴涓湀鍦堟笎鍙橈紝浼氳鍚庨潰鐨勫湀鍦堢灛闂磋鐩栧湪涓婇潰銆傚鏋滀袱涓笎鍙橀鑹叉湁宸紓锛屾鏃惰倝鐪煎彲浠ユ劅瑙夊埌鏄庢樉鍙樺寲锛涗絾鏄疄闄呮搷浣滀笅鏉ワ紝灏卞ソ鍍忓悗闈㈡笎鍙樼獊鐒舵秷澶变竴鑸紝杩欏氨璇存槑涓婁笅涓や釜娓愬彉瀹為檯涓婃晥鏋滄槸涓€鑷寸殑銆侟/p>

涓冦€佺ず渚?锛氭き鍦嗙被鍨嬬殑寰勫悜娓愬彉
瀵逛簬鍦嗗舰鐣岄潰锛屾垜浠彧闇€瑕佹寚瀹氫竴涓崐寰勫氨鍙互浜嗭紝浣嗘槸瀵逛簬妞渾绫诲瀷鐨勫緞鍚戞笎鍙橈紝鎴戜滑闇€瑕佸悓鏃舵寚瀹氭í杞村拰绾佃酱鐨勯暱搴︼紝渚嬪锛欬/p>

.radial-gradient {     width: 200px; height: 200px;     background: radial-gradient(50px 100px ellipse, transparent 40px, yellow 41px, red); }

50px 100px ellipse涓涓€涓暟鍊?0px琛ㄧず妯酱鍗婂緞锛?00px琛ㄧず绾佃酱鍗婂緞锛屼簬鏄繖娈佃鍙ヨ〃绀虹粯鍒朵竴涓暱搴?00px楂樺害200px鐨勬き鍦嗐€侟/p>

鏁堟灉濡備笅鍥撅細

闇€瑕佹敞鎰忕殑鏄紝鍦ㄤ笂闈㈢ず鎰廋SS浠g爜涓紝閫忔槑鍒懊椕椕楀垎鐣岄偅閲屾湁涓€涓?px鐨勫亸宸繃娓★紝涔熷氨鏄痶ransparent 40px, yellow 41px涓瓂ellow鏄?1px锛岃€屼笉鏄缃殑40px锛屽師鍥犲湪浜庡湪Chrome涓嬶紝濡傛灉棰滆壊鐩存帴0鍋忓樊杩囨浮锛屼細鏈夋瘮杈冧弗閲嶇殑閿娇锛岀被浼间笅鍥捐繖鏍凤紙鑳屾櫙鑹茶涓?333锛夛細

閫氳繃鏈?鍍忕礌鎴栬€呭崐鍍忕礌鐨勮繃娓$紦鍐插彲浠ユ湁鏁堥伩鍏嶉敮榻跨殑鍑虹幇銆侟/p>

鍏€佺ず渚?锛氬彲绱姞鐨勫緞鍚戞笎鍙樿儗鏅浘
鎴戜滑鍙互鎶婂涓緞鍚戞笎鍙樼疮鍔犲湪涓€璧峰疄鐜版煇浜涙晥鏋滐紝渚嬪涓嬮潰CSS锛欬/p>

.radial-gradient {     width: 200px; height: 200px;     background: radial-gradient(50px 100px ellipse, transparent 40px, yellow 41px, red 49px, transparent 50px),                 radial-gradient(30px circle, red, red 29px, transparent 30px); }

瀹炵幇浜嗏€滈偑鐜嬬湡鐪尖€濇晥鏋滐細

涔濄€佺ず渚?锛氭笎鍙樿儗鏅殑灏哄鎺у埗
閰嶅悎background-size鐨勫昂瀵告帶鍒跺拰鑳屾櫙閲嶅鐗规€э紝鎴戜滑鍙互瀹炵幇娓愬彉寮忕殑澶嶆潅绾圭悊鏁堟灉锛欬/p>

.radial-gradient {     width: 200px; height: 200px;     background: radial-gradient(5px 10px ellipse, transparent 4px, yellow 5px, red 6px, transparent 7px),                 radial-gradient(3px circle, red, red 3px, transparent 4px);     background-size: 25px; } 

浜庢槸灏卞彲浠ョ湅鍒颁竴澶ф尝鍐欒疆鐪硷細

閫氬父鎴戜滑浣跨敤寰勫悜娓愬彉鏋勫缓涓€浜涚畝鍗曞疄鐢ㄥ浘褰㈢殑鏃跺€欙紝background-size寰€寰€鏄叧閿睘鎬э紝渚嬪锛屾垜浠瀹炵幇涓按娉㈡晥鏋滐紝鍙互杩欐牱锛欬/p>

.radial-gradient {     width: 200px; height: 100px;     background: red;     position: relative; } .radial-gradient:after {     content: '';     position: absolute;     height: 10px;     left:0 ; right: 0;     bottom: -10px;     background: radial-gradient(20px 15px ellipse at top, red 10px, transparent 11px);     background-size: 20px 10px; }

鐒跺悗灏辨湁涓嬪浘鎵€绀虹殑鏁堟灉锛欬br />

鍗併€佺ず渚?锛氬彲閲嶅鐨勫緞鍚戞笎鍙楛br />濡傛灉鎯宠瀹炵幇鍙噸澶嶇殑寰勫悜娓愬彉锛屼害鍙互浣跨敤鍘熺敓鐨剅epeating-radial-gradient()鏂规硶锛岀壒鍒€傚悎瀹炵幇浠庝腑蹇冩墿鏁g殑鍏夋尝鏁堟灉銆侟/p>

鐒惰€岋紝鐩告瘮閲嶅绾挎€ф笎鍙榬epeating-linear-gradient()鏂规硶锛宺epeating-radial-gradient()鐨勫疄闄呭簲鐢ㄥ満鏅疄闄呬笂寰堟湁闄愩€傚洜涓猴紝瀹為檯寮€鍙戠殑鏃跺€欙紝鎴戜滑寰堝皯鐢ㄥ埌浠庝腑蹇冩墿鏁g殑鍏夋尝鏁堟灉銆侟/p>

闄や簡涓€浜涙湰韬氨鏄尝绾圭被鍨嬫晥鏋滐紝濡傛按娉紝澹版尝鎴栬€呭敱鐗囩汗鐞嗭細

濡備笅CSS

.radial-gradient {     position: relative;     width: 262px; height: 262px;     border-radius: 50%;     background: linear-gradient(30deg, transparent 40%, rgba(42, 41, 40, .85) 40%) no-repeat 100% 0, linear-gradient(60deg, rgba(42, 41, 40, .85) 60%, transparent 60%) no-repeat 0 100%, repeating-radial-gradient(#2a2928, #2a2928 4px, #ada9a0 5px, #2a2928 6px);     background-size: 50% 100%, 100% 50%, 100% 100%; } .radial-gradient:after {     position: absolute;     top: 50%; left: 50%;     margin: -35px;     border: solid 1px #d9a388;     width: 68px; height: 68px;     border-radius: 50%;     box-shadow: 0 0 0 4px #da5b33, inset 0 0 0 27px #da5b33;     background: #b5ac9a;     content: ''; }

鍗佷竴銆佺ず渚?0锛氫綔涓篵order-image鐨勫緞鍚戞笎鍙楛br />寰勫悜娓愬彉涓嶄粎鍙互浣滀负background鐨勮儗鏅浘锛岃繕鍙互浣滀负border-image鐨勮竟妗嗗浘浣跨敤銆侟/p>

渚嬪锛欬/p>

.radial-gradient {     width: 100px; height: 100px;     border: 50px solid;     border-image: radial-gradient(circle, transparent 50px, yellow 51px, red) 50 stretch; } 

澶╃劧闀傜┖鏁堟灉锛屽彧鍙儨border-image鏄棤娉曞拰border-radius鍚屾椂鐢熸晥鐨勶紝鍚﹀垯锛宐order-image鍙氨瑕佺墰鐐稿ぉ浜嗐€侟/p>

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!