CSS奇思妙想-圆角三角形的巧妙实现
鍓嶉潰鐨勬枃绔犫€斺€斻€婅€佺敓甯歌皥涔?CSS 瀹炵幇涓夎褰€嬩粙缁嶄簡6绉嶇敤CSS瀹炵幇涓夎褰㈢殑鏂规硶銆備絾鏄紡鎺変簡涓€涓緢閲嶈鐨勫満鏅紝濡備綍鐢ㄧ函CSS瀹炵幇涓€涓渾瑙掔殑涓夎褰㈠憿锛燂紝鍍忚繖鏍凤細鏈枃灏嗕粙缁嶅嚑绉嶅渾瑙掍笁瑙掑舰鐨勫疄鐜般€傛柟娉曚竴銆佸畬鍏ㄥ吋瀹筍VG鏂规硶濡傛灉瑕佺敓鎴愬渾瑙掍笁瑙掑舰锛岀敤鏈€灏戠殑浠g爜鐢熸垚涓夎褰㈡渶濂界殑鏂规硶灏辨槸浣跨敤SVG銆備娇鐢⊿VG鐨勫杈瑰舰鏍囩鐢熸垚涓夎褰紝骞朵娇鐢⊿VG鐨剆troke-linejoin="round"鍦ㄨ繛鎺ュ鐢熸垚鍦嗚銆備唬鐮侀噺寰堝皯锛屾牳蹇冧唬鐮佸涓嬶細.triangle{濉厖锛?0f0;琛岀▼锛?0f0锛泂troke-width:10;}瀹為檯鍥惧舰濡備笅锛氳繖閲屽疄闄呬娇鐢ㄤ簡SVG澶氳竟褰㈢殑stroke-linejoin:round灞炴€у緱鍒扮殑鍦嗚锛屼粈涔堟槸stroke-linejoin锛熺敤浜庢帶鍒朵袱鏉℃弿杈圭嚎娈典箣闂寸殑璺濈锛屽叡鏈変笁涓彲閫夊€硷細miter涓洪粯璁ゅ€硷紝琛ㄧず鍦ㄨ繛鎺ュ浣跨敤鏂瑰舰绗斿埛褰㈡垚灏栬锛況ound琛ㄧず浣跨敤鍦嗚杩炴帴锛岃揪鍒板钩婊戠殑鏁堟灉锛涚劧鍚庢垜浠疄闄呴€氳繃涓€涓甫杈规鐨勫杈瑰舰鐢熸垚涓€涓渾瑙掍笁瑙掑舰锛岃竟妗嗚繛鎺ョ被鍨嬩负stroke-linejoin:round銆傚鏋滄垜浠尯鍒嗚儗鏅鑹插拰杈规棰滆壊锛屽畠瀹為檯涓婃槸杩欐牱鐨勶細.triangle{fill:#0f0;琛岀▼锛?000锛泂troke-width:10;}閫氳繃stroke-width鎺у埗鍦嗚鐨勫ぇ灏忛偅涔堝浣曟帶鍒跺渾瑙掔殑澶у皬鍛紵涔熷緢绠€鍗曪紝閫氳繃鎺у埗stroke-width鐨勫ぇ灏忥紝灏卞彲浠ユ敼鍙樺渾瑙掔殑澶у皬銆傚綋鐒讹紝瑕佷繚鎸佷笁瑙掑舰澶у皬涓€鑷达紝闇€瑕佸湪澧炲姞/鍑忓皯stroke-width鐨勫悓鏃跺噺灏?澧炲姞鍥惧舰鐨勫搴?楂樺害锛氬畬鏁寸殑DEMO鍙互鐐硅繖閲岋細CodePenDemo--UsingSVGtoRealizea鍦嗚涓夎褰㈡柟娉曚簩銆佸浘褰㈡嫾鎺ヤ笉杩囦笂闈㈣浜嗙敤绾疌SS瀹炵幇鍦嗚涓夎褰紝涓嶈繃涓婇潰鐨勭涓€绉嶆柟娉曞叾瀹炴槸鍊熷姪浜哠VG銆傞偅涔堝彧浣跨敤CSS锛屾湁鍔炴硶鍚楋紵褰撶劧锛屽彂鏁f€濈淮锛孋SS鏈夎叮鐨勫湴鏂瑰氨鍦ㄨ繖閲屻€備竴寮犲浘锛屽彲浠ユ湁寰堝宸у鐨勮В鍐虫柟妗堬紒鐪嬩竴涓嬶紝涓€涓渾瑙掍笁瑙掑舰鍏跺疄鍙互鎷嗗垎鎴愬嚑涓儴鍒嗭細鎵€浠ワ紝鍏跺疄鎴戜滑鍙渶瑕佽兘澶熺敾鍑鸿繖鏍蜂竴涓渾瑙掔殑鑿卞舰锛岄€氳繃3娆℃棆杞彔鍔狅紝灏卞彲浠ュ緱鍒板渾瑙掍笁瑙掑舰锛氱敾涓€涓渾瑙掕彵褰㈤偅涔堬紝鎴戜滑鐨勪笅涓€涓洰鏍囧氨鍙樻垚浜嗙敾涓€涓渾瑙掕彵褰€傛湁寰堝鏂规硶銆傛湰鏂囩粰鍑轰簡鍏朵腑涓€绉嶆柟娉曪細棣栧厛锛屽皢姝f柟褰㈠彉鎴愯彵褰紝浣跨敤transform鏈変竴涓浐瀹氱殑鍏紡锛?div>
div{width:10em;楂樺害锛?0em锛泃ransform:rotate(-60deg)skewX(-30deg)scale(1,0.866);}鎶婂叾涓竴涓鍙樻垚涓€涓渾Angle:div{width:10em;楂樺害锛?0em锛涘彉鎹細鏃嬭浆锛?60搴︼級skewX锛?30搴︼級姣斾緥锛?銆?.866锛夛紱+border-top-right-radius:30%;}鍒扮洰鍓嶄负姝紝鎴戜滑寰堥『鍒╀綘寰楀埌涓€涓甫鍦嗚鐨勮彵褰紒鎷兼帴3涓渾瑙掕彵褰㈤潪甯哥畝鍗曪紝鎴戜滑鍙渶瑕佸埄鐢ㄥ厓绱犵殑鍙﹀涓や釜浼厓绱犵敓鎴?涓渾瑙掕彵褰紝涓€鍏辨嫾鎺ュ嚭3涓甫鏈夋棆杞拰浣嶇Щ鐨勫浘褰紒瀹屾暣浠g爜濡備笅锛?div>
div{position:relative;鑳屾櫙鑹诧細姗欒壊锛泒div锛氫箣鍓嶏紝div锛氫箣鍚巤鍐呭锛?'锛涗綅缃細缁濆锛涜儗鏅壊锛氱户鎵匡紱}div,div:before,div:after{瀹藉害锛?0em;楂樺害锛?0em锛沚order-top-right-radius:30%;}div{transform:rotate(-60deg)skewX(-30deg)scale(1,.866);}div:before{transform:rotate(-135deg)skewX(-45deg)scale(1.414,.707)translate(0,-50%);}div:after{transform:rotate(135deg)skewY(-45deg)scale(.707,1.414)translate(50%);}寰楀埌涓€涓渾瑙掍笁瑙掑舰锛佹晥鏋滃涓嬶細瀹屾暣浠g爜鍙互鐐硅繖閲岋細CodePenDemo--甯﹀渾瑙掔殑涓夎褰㈡柟娉曚笁銆佸浘褰㈡嫾鎺ュ疄鐜版笎鍙樿壊鍦嗚涓夎褰㈠畬鎴愪簡鍚楋紵涓嶏紒涓婇潰鐨勮В鍐虫柟妗堣櫧鐒朵笉鏄お澶嶆潅锛屼絾鏈変竴鐐瑰苟涓嶅畬缇庯紝灏辨槸涓嶈兘鏀寔娓愬彉鑹茬殑鍦嗚涓夎褰€傚儚杩欐牱锛氬鏋滈渶瑕佸疄鐜颁竴涓笎鍙樼殑鍦嗚涓夎褰紝杩樻槸鏈夌偣澶嶆潅銆備絾浠嶆湁浜哄鍏惰繘琛屼簡淇ˉ銆備笅闈㈢殑鏂规硶鍙傝€?-濡備綍鍦–SS涓埗浣滀笁瑙掑渾瑙掍笁瑙掑舰銆備篃鏄娇鐢ㄥ涓潡杩涜鎷兼帴锛屼絾鏄繖娆℃垜浠殑鍩虹鍥惧舰浼氬緢澶嶆潅銆傞鍏堟垜浠瀹炵幇杩欐牱涓€涓鍣ㄦ锛屽拰涓婇潰鐨勬柟娉曠被浼硷紝鍙互鐞嗚В涓轰竴涓渾瑙掕彵褰紙鐢诲嚭杈规鏂逛究鐞嗚В锛夛細
div{width:200px;楂樺害锛?00px锛涘彉鎹細鏃嬭浆锛?0搴︼級skewY锛?0搴︼級scaleX锛?.866锛夛紱杈规锛?px瀹炲績#000锛沚order-radius:20%;}鎺ヤ笅鏉ユ垜浠悓鏍蜂娇鐢ㄤ袱涓吉鍏冪礌鏉ュ疄鐜颁袱涓暐鏄炬€紓鐨勫浘褰titching鏄痶ransform鍚勭鐢ㄦ硶鐨勯泦鍚堬細div::before,div::after{content:"";浣嶇疆锛氱粷瀵癸紱瀹藉害锛?00px锛沨eight:200px;}div::before{border-radius:20%20%20%55%;鍙樻崲锛歴caleX(1.155)skewY(-30deg)rotate(-30deg)translateY(-42.3%)skewX(30deg)scaleY(0.866)translateX(-24%)锛涜儗鏅細绾㈣壊锛泒div::after{杈圭晫鍗婂緞锛?0%20%55%20%锛涜儗鏅細钃濊壊锛泃ransform:scaleX(1.155)skewY(-30deg)rotate(-30deg)translateY(-42.3%)skewX(-30deg)scaleY(0.866)translateX(24%);}涓轰簡鏂逛究鐞嗚В锛屽仛浜嗕竴涓畝鍗曠殑鍙樻崲鍔ㄧ敾:鏈川灏辨槸瀹炵幇杩欐牱涓€涓浘褰細鏈€鍚庡湪鐖跺厓绱犱笂鍔犱竴涓猳verflow:hidden骞跺幓鎺夌埗鍏冪礌鐨刡order寰楀埌涓€涓猂oundedtriangle:鐢变簬杩欎袱涓厓绱犻噸鍙犵┖闂寸殑鐗规畩缁撴瀯锛屽湪杩欎竴娆★紝涓轰袱涓吉鍏冪礌娣诲姞鐩稿悓鐨勬笎鍙橀鑹诧紝瀹冧滑灏嗗畬缇庨噸鍙狅細div::before,div::after,{background:linear-gradient(#0f0,#03a9f4);}鏈€鍚庡緱鍒颁竴涓笎鍙樼殑鍦嗚涓夎褰細涓婇潰鍥惧舰鐨勫畬鏁翠唬鐮佸彲浠ョ偣鍑昏繖閲岋細CodePenDemo--涓€涓甫鏈夊渾瑙掑拰娓愬彉鑳屾櫙鐨勪笁瑙掑舰鏈€鍚庯紝鏈枃浠嬬粛鍑犵瀹炵幇鍦嗚涓夎褰㈢殑鏂规硶CSS涓殑閮ㄥ垎鏂规硶铏界劧鏈変簺绻佺悙锛屼絾涔熶綋鐜颁簡CSS鈥滄湁瓒e張鎶樼(浜衡€濈殑涓€闈€傚埌鍏蜂綋搴旂敤鐨勬椂鍊欙紝杩樻槸瑕佽€冭檻瑕佷笉瑕佺敤涓婇潰鐨勬柟娉曘€傛湁鏃讹紝鍓垏鍥剧墖鍙兘浼氭洿濂姐€傛柟妗堝噯澶囧ソ浜嗭紝鏈枃鍒版缁撴潫锛屽笇鏈涘浣犳湁鎵€甯姪:)鎯宠鑾峰彇鏈€鏈夎叮鐨凜SS璧勮锛屽崈涓囦笉瑕侀敊杩囨垜鐨勫叕浼楀彿鈥斺€攊CSS鍓嶇濂囬椈杞朵簨馃槃鏇村绮惧僵CSS鎶€鏈枃绔犳眹鎬诲湪鎴戠殑Github鈥斺€攊CSS锛屾寔缁洿鏂帮紝娆㈣繋鐐逛釜鏄熻闃呮敹钘忋€傛湁浠€涔堥棶棰樻垨鑰呭缓璁彲浠ュ浜ゆ祦銆傚師鍒涙枃绔犳枃绗旀湁闄愶紝鐭ヨ瘑鍖箯銆傚鏋滄枃绔犱腑鏈変换浣曚笉鍑嗙‘鐨勫湴鏂癸紝璇峰憡璇夋垜銆?/p>