当前位置: 首页 > Web前端 > JavaScript

使用CSS轻松实现各种频繁出现的奇形怪状按钮的背景

时间:2023-03-27 12:07:53 JavaScript

缇ら噷鍚屽浼氶棶鐩稿叧闂锛屽浣曚娇鐢–SS瀹炵幇涓€涓唴鍒囪鎸夐挳锛屽浣曞疄鐜颁竴涓甫绠ご鐨勬寜閽紵鏈枃浠ヨ璁$涓粡甯稿嚭鐜扮殑涓€浜涳紝浣跨敤CSS瀹炵幇鐣ユ湁闅惧害鍜屾妧宸х殑鎸夐挳涓哄熀纭€锛屽敖鍙兘鍦拌瑙e浣曚娇鐢–SS瀹炵幇銆傝鎴戜滑鏉ョ湅鐪嬭繖浜涚粡甯稿嚭鐜扮殑鎸夐挳褰㈢姸锛氱煩褰㈠拰鍦嗚鎸夐挳閫氬父鎯呭喌涓嬶紝鎴戜滑閬囧埌鐨勬寜閽棤闈炲氨鏄繖涓ょ鈥斺€旂煩褰㈠拰鍦嗚锛氬畠浠緢绠€鍗曪紝瀹藉害鍜岄珮搴︿互鍙婂渾瑙掑拰鑳屾櫙棰滆壊銆?divclass='btnrect'>rect

circle
.btn{margin:8pxauto;浼哥缉鏀剁缉锛?锛涘搴︼細160px锛涢珮搴︼細64px锛泒.rect{鑳屾櫙锛?f6ed8d;}.circle{杈规鍗婂緞锛?4px;background:#7de3c8;}姊舰鍜屽钩琛屽洓杈瑰舰鎺ヤ笅鏉ユ牴鎹煩褰㈢殑鍙樺舰锛岀粡甯镐細鍑虹幇姊舰鍜屽钩琛屽洓杈瑰舰鎸夐挳銆傚疄鐜板畠浠富瑕佸彲浠ヤ娇鐢╰ransform锛屼絾鏄渶瑕佹敞鎰忕殑鏄娇鐢╰ransform涔嬪悗锛宭abel涓殑鏂囧瓧涔熶細鍙樺舰锛屾墍浠ユ垜浠€氬父浣跨敤鍏冪礌鐨勪吉鍏冪礌鏉ュ疄鐜板舰鐘讹紝杩欐牱浼氫笉褰卞搷鎸夐挳涓殑鏂囨湰銆傚崟璇嶃€傚彧闇€瀵瑰钩琛屽洓杈瑰舰浣跨敤transform:skewX()銆傛敞鎰忎笂闈紝浣跨敤鍏冪礌鐨勪吉鍏冪礌瀹炵幇骞宠鍥涜竟褰紝浠ュ厤褰卞搷鍐呴儴鏂囧瓧銆?divclass='btnparallelogram'>骞宠鍥涜竟褰?/div>.parallelogram{position:relative;瀹藉害锛?60px锛涢珮搴︼細64px锛?::涔嬪墠{鍐呭锛氣€溾€濓紱浣嶇疆锛氱粷瀵癸紱椤堕儴锛?锛涘乏锛?锛涘簳閮細0锛涘彸锛?锛涜儗鏅細#03f463锛涘彉鎹細skewX锛?5deg锛夛紱}}濡傛灉涓嶆兂鐢ㄤ吉鍏冪礌锛岄櫎浜唗ransform:skewX()锛屽骞宠鍥涜竟褰娇鐢ㄦ笎鍙樹篃鏄彲浠ョ殑銆傚ぇ姒傛槸杩欐牱锛歿background:linear-gradient(45deg,transparent22%,#04e6fb22%,#9006fb78%,transparent0);}姊舰姊舰姣斿钩琛屽洓杈瑰舰澶嶆潅涓€鐐癸紝鏇村鐨勬槸鐢ㄩ€忚锛屽叾瀹烇紝瀹冧娇鐢ㄦ煇绉?D鍙樻崲杩涜銆傚師鐞嗘槸缁昘杞存棆杞殑鐭╁舰锛屽儚杩欐牱锛氫娇鐢ㄩ€忚鍜屽彉鎹細rotateX()锛屽綋鐒朵篃鍙互鍐欐垚锛?divclass='btntrapezoid'>Trapezoid
銆傚钩琛屽洓杈瑰舰{浣嶇疆锛氱浉瀵癸紱瀹藉害锛?60px锛涢珮搴︼細64px锛涳紗::涔嬪悗{鍐呭锛氣€溾€?浣嶇疆锛氱粷瀵癸紱椤堕儴锛?锛涘彸锛?锛涘簳閮細0锛涘乏锛?锛涘彉鎹細閫忚锛?0px锛塺otateX锛?0deg锛夛紱鍙樻崲鍘熺偣锛氬簳閮紱鑳屾櫙锛?ff9800锛泒}鍒囪鈥斺€旂函鑹茶儗鏅拰娓愬彉鑹茶儗鏅帴涓嬫潵灏辨槸鍒囪鍥惧舰浜嗐€傛渶甯歌鐨勬柟娉曟槸浣跨敤娓愬彉linear-gradient鏉ュ疄鐜般€傝鎴戜滑鐪嬬湅杩欐牱鐨勫浘褰?div>
.notching{background:linear-gradient(135deg,transparent10px,#ff14930);background-repeat:no-repeat;}缁撴灉濡備笅锛屽熀浜庢锛屾垜浠彧闇€瑕佷娇鐢ㄥ閲嶆笎鍙橈紝瀹炵幇4涓繖鏍风殑鍥惧舰锛屽苟浣跨敤background-position瀹氫綅鍥涗釜瑙掞細notching.notching{鑳屾櫙锛氱嚎鎬ф笎鍙橈紙135deg锛岄€忔槑10px锛?ff14930锛夊乏涓婏紝绾挎€ф笎鍙橈紙-135deg锛岄€忔槑10px锛?ff14930锛夊彸涓婏紝绾挎€ф笎鍙橈紙-45deg,transparent10px,#ff14930)鍙充笅瑙?linear-gradient(45deg,transparent10px,#ff14930)bottomleft;鑳屾櫙澶у皬锛?0%50%锛沚ackground-repeat:no-repeat;}usingclip-path褰撶劧锛岃繖绉嶆妧鏈湁涓€涓棶棰樸€傚綋瑕佹眰鑳屾櫙鑹蹭负娓愬彉鑹叉椂锛岃繖绉嶆柟娉曟瘮杈冪鎷欍€傚垢杩愮殑鏄紝鎴戜滑鏈夊彟涓€绉嶆柟娉曞彲浠ュ湪clip-path鐨勫府鍔╀笅鍓垏鍑轰竴涓猚ut銆傝搴﹀浘褰紝杩欐牱锛岃儗鏅壊鍙互鏄换鎰忚嚜瀹氫箟棰滆壊锛屾棤璁烘槸娓愬彉鑹茶繕鏄函鑹诧細notching.clip-notching{background:linear-姊害锛?5deg锛?f9d9e7锛?ff1493锛夛紱鍓緫璺緞锛氬杈瑰舰(15px0,calc(100%-15px)0,100%15px,100%calc(100%-15px),calc(100%-15px)100%,15px100%,0calc(100%-15px),015px);}涓€涓笎鍙樿儗鏅殑绠€鍗曞疄鐜帮紝鐒跺悗鏍稿績灏辨槸锛屽湪娓愬彉鐭╁舰鍥惧舰鐨勫熀纭€涓婏紝浣跨敤clip-path:polygon()瑁佸壀鍑烘兂瑕佺殑褰㈢姸锛堜竴涓?-sidedshape)锛氬綋鐒朵笂闈㈢殑浠g爜寰堝鏄撴兂鍒颁笅闈㈢殑6杈瑰舰锛屼娇鐢╣radients鍜宑lip-paths鍙互寰堝鏄撶殑寰楀埌锛歛rrowbutton鍚庨潰璺熺潃涓€涓猘rrowbutton锛屼粩缁嗚瀵熶笂闈㈢殑鍒囪鎸夐挳锛屽綋涓や晶鍒囨帀瓒冲鐨勮鏃讹紝鍙樻垚绠ご褰㈢姸銆傛垜浠彲浠ヤ娇鐢ㄤ袱涓笎鍙樻潵瀹炵幇鍗曚釜绠ご鎸夐挳锛?divclass="arrow">arrow&.arrow{background:linear-gradient(-135deg,transparent22px,#04e6fb22px,#65ff9a100%)鍙充笂锛岀嚎鎬ф笎鍙橈紙-45deg锛岄€忔槑22px锛?04e6fb22px锛?65ff9a100%锛夊彸涓嬶紱鑳屾櫙澶у皬锛?00%50%锛沚ackground-repeat:no-repeat;}涓€涓澶村嚭鏉ヤ簡锛氭槸涓婁笅娓愬彉鍧楃粍鍚堝緱鍒扮殑锛屾崲涓鑹茬珛椹氨鏄庣櫧浜嗭細濡傛灉鏄繖鏍风殑绠ご褰㈢姸鍛紵鍚屾牱锛屼篃鏄袱涓笎鍙樼殑鍙犲姞锛屾笎鍙樼殑棰滆壊閫忔槑-->棰滆壊A-->棰滆壊B-->閫忔槑銆傚綋鐒惰繖閲屼篃鍙互浣跨敤clip-path锛氳繖閲屾槸clip-path鐨勮В鍐虫柟娉曪細{background:linear-gradient(45deg,#04e6fb,#65ff9a);clip-path:polygon(00,30px50%,0100%,calc(100%-30px)100%,100%50%,calc(100%-30px)0);}涓嬫柟鎸夐挳鐨勫舰鐘秈nscribedroundedcorners缁忓父鍑虹幇鍦╟oupons涓紝鏈€甯歌鐨勮В鍐虫柟妗堬紝涔熶娇鐢ㄤ簡Gradients锛屽綋鐒讹紝鍜屽垏瑙掍笉鍚岀殑鏄紝杩欓噷浣跨敤鐨勬槸寰勫悜娓愬彉銆傞鍏堢湅杩欎箞涓€涓畝鍗曠殑渚嬪瓙锛?div>div{background-image:radial-gradient(circleat100%100%,transparent0,transparent12px,#2179f512px);}鍙互寰楀埌杩欐牱涓€涓浘褰?鎵€浠ワ紝鍙鎺у埗background-size锛屽湪4涓瀹炵幇4涓繖鏍风殑鍥惧舰锛?divclass="inset-circle">inset-circle&.inset-circle{background-size:70%70%;鑳屾櫙鍥惧儚锛氬緞鍚戞笎鍙橈紙鍦嗗舰100%100%锛岄€忔槑0锛岄€忔槑12px锛?2179f513px锛夛紝寰勫悜娓愬彉锛堝渾褰?0锛岄€忔槑0锛岄€忔槑12px锛?2179f513px锛夛紝寰勫悜娓愬彉锛堝渾褰?00%0锛岄€忔槑0锛岄€忔槑12px锛?2179f513px锛夛紝寰勫悜娓愬彉锛堝渾褰?100%锛岄€忔槑0锛岄€忔槑12px锛?2179f513px锛夛紱鑳屾櫙閲嶅锛氫笉閲嶅锛涜儗鏅綅缃細鍙充笅瑙抩m,lefttop,righttop,leftbottom;}鍊熷姪mask瀹炵幇娓愬彉鍐呮帴鍦嗚鎸夐挳濡傛灉鑳屾櫙鑹查渶瑕佹笎鍙樻€庝箞鍔烇紵鍋囪鎴戜滑鏈変竴涓煩褰㈢殑鑳屾櫙鍥炬锛屾垜浠彧闇€瑕佺敤mask瀹炵幇涓€灞俶asking锛屽埄鐢╩ask鐨勭壒鎬ф妸4涓閮介伄浣弇ask鐨勪唬鐮佸拰涓婇潰璇寸殑鍦嗚鍒囧壊浠g爜寰堝儚銆傜畝鍗曚慨鏀瑰悗锛屽氨鍙互寰楀埌涓€涓笎鍙樼殑鍐呭祵鍦嗚鎸夐挳锛?179f5锛?e91e63锛夛紱钂欑増锛氬緞鍚戞笎鍙橈紙鍦嗗舰100%100%锛岄€忔槑0锛岄€忔槑12px锛?2179f513px锛夛紝寰勫悜娓愬彉锛堝渾褰?0锛岄€忔槑0锛岄€忔槑12px锛?2179f513px锛夛紝寰勫悜娓愬彉锛堝渾褰t100%0,transparent0,transparent12px,#2179f513px),radial-gradient(circleat0100%,transparent0,transparent#12px,2179f513px);鎺╃爜閲嶅锛氫笉閲嶅锛沵ask-position锛氬彸涓嬶紝宸︿笂锛屽彸涓婏紝宸︿笅锛沵ask-size:70%70%;}杩欐牱锛屾垜浠緱鍒颁簡杩欐牱涓€涓浘褰細褰撶劧锛岃鐪嬫噦涓婇潰鐨勪唬鐮侊紝棣栧厛瑕佹悶娓呮CSSmask灞炴€х殑鍘熺悊銆傚鏋滀綘瀵瑰畠杩樻湁鐐逛笉鐔熸倝锛屽彲浠ョ湅鎴戠殑鏂囩珷锛氱簿褰╃殑CSSMASK涓嬮潰鐨勫渾瑙掍笉瑙勫垯鐭╁舰杩欎釜鎸夐挳鐨勫舰鐘朵篃鏄渶杩戣闂埌鐨勯偅涓€傛垜浠厛鐪嬬湅瀹冪殑褰㈢姸锛氬畠鐨勫悕瀛椾笉濂藉懡鍚嶃€備竴杈规槸甯﹀渾瑙掔殑瑙勫垯鐩磋锛屽彟涓€杈规槸甯﹀渾瑙掔殑鏂滆竟銆傚疄闄呬笂锛屽畠鏄敱鍦嗚鐭╁舰+鍦嗚骞宠鍥涜竟褰㈢粍鎴愮殑锛氭墍浠ワ紝鍊熷姪涓や釜浼厓绱狅紝寰堝鏄撳疄鐜帮細Skew.skew{position:relative;瀹藉害锛?20px锛涳紗::涔嬪悗{鍐呭锛氣€溾€?浣嶇疆锛氱粷瀵癸紱椤堕儴锛?锛涘乏锛?锛涘彸锛?锛涘簳閮細0锛涜竟鐣屽崐寰勶細10px锛涜儗鏅細姗欒壊锛涘彉鎹細skewX锛?5deg锛夛紱}&::before{鍐呭锛氣€溾€濓紱浣嶇疆锛氱粷瀵癸紱椤堕儴锛?锛涘彸锛?13px锛涘搴︼細100px锛涢珮搴︼細64px锛涜竟鐣屽崐寰勶細10px锛涜儗鏅細姗欒壊锛涗笂闈紝鎵€浠ュ叾涓竴涓娇鐢ㄦ笎鍙樿壊锛屽彟涓€涓娇鐢ㄧ函鑹诧紝棰滆壊鍙互瀹岀編鐨勮鎺ュ湪涓€璧凤紝杩欐牱娓愬彉鑹茬殑鍥惧舰灏卞疄鐜颁簡锛氬鍦嗚鎸夐挳涓嬩竴涓寜閽舰鐘跺父瑙佸湪Tab椤典笂锛岀被浼间簬Chrome鐨勫垎椤碉細鎴戜滑鏉ユ媶瑙d竴涓嬭繖涓寜閽殑褰㈢姸锛岃繖閲屽叾瀹炴槸3鍧楃殑鍙犲姞锛氬紕娓呮涓よ竟鐨勫渾寮т笁瑙掑浣曞疄鐜板氨鍙互浜嗐€傝繖閲屾垜浠繕鏄娇鐢ㄤ簡娓愬彉鈥斺€斿緞鍚戞笎鍙橈紝鍏跺疄灏辨槸杩欐牱鐨勶紝濡備笅鍥撅紝鎴戜滑鍙渶瑕佸皢榛戣壊閮ㄥ垎鎹㈡垚閫忔槑鍗冲彲锛屼娇鐢ㄤ袱涓吉鍏冪礌锛氫唬鐮佸涓嬶細outside-circle.outside-circle{浣嶇疆锛氱浉瀵癸紱鑳屾櫙锛?e91e63锛涜竟妗嗗崐寰勶細10px10px00锛?::涔嬪墠{鍐呭锛氣€溾€濓紱浣嶇疆锛氱粷瀵癸紱瀹藉害锛?0px锛涢珮搴︼細20px锛涘乏锛?20px锛涘簳閮細0锛涜儗鏅細#000锛涜儗鏅細寰勫悜娓愬彉锛堝渾鍦堝湪00锛岄€忔槑20px锛?e91e6321px锛夛紱}&::after{鍐呭锛氣€溾€濓紱浣嶇疆锛氱粷瀵癸紱瀹藉害锛?0px锛涢珮搴︼細20px锛涘彸锛?20px锛涘簳閮細0锛涜儗鏅細#000锛涜儗鏅細寰勫悜娓愬彉锛堝渾褰?00%0锛岄€忔槑20px锛?e91e6321px锛夛紱鑾峰彇锛氫笂闈㈡墍鏈夊浘褰㈢殑瀹屾暣浠g爜锛屽彲浠ョ湅杩欓噷锛欳odePenDemo--CSSVariousButtonShapes|瀹冧滑閮芥槸閫氳繃鎷兼帴銆佽挋鐪笺€侀伄钄界瓑鏂瑰紡瀹炵幇鐨勩€傚叾涓細gradient锛堢嚎鎬ф笎鍙榣inear-gradient銆乺adialgradientradial-gradient銆乵ultiplegradient锛塵askclipping-pathdeformationtransform璧风潃閲嶈鐨勪綔鐢紝鐔熺粌浣跨敤瀹冧滑锛屾垜浠彲浠ュ緢鏂逛究鐨勪娇鐢ㄨ繖浜涘浘褰紝鍩轰簬瀹冧滑鐨勫彉褰篃鍙互鍐烽潤搴斿銆備互涓婂浘褰紝缁撳悎filter:drop-shadow()锛屽熀鏈彲浠ュ疄鐜颁笉瑙勫垯闃村奖銆傛澶栵紝姣旇緝澶嶆潅鐨勫浘褰㈠涓嬶細鎶婂浘褰㈠壀涓嬫潵銆侰SS铏界劧濂斤紝浣嗗湪瀹為檯浣跨敤涓渶瑕佽€冭檻鎶曞叆浜у嚭姣斻€傛渶鍚庯紝杩欑瘒鏂囩珷鐨勭洰鐨勬洿澶氱殑鏄竴涓畝鍗曠殑鎵嬪唽銆傚湪瀹炶返涓紝鍙兘鏈夋洿濂界殑鏂规硶鍙互杈惧埌涓婅堪鏁堟灉銆傛湰鏂囦笉涓€涓€鍒椾妇銆傛杩庤ˉ鍏呭拰鎸囨銆傚ソ浜嗭紝鏈枃鍒版缁撴潫锛屽笇鏈涜繖绡囨枃绔犲浣犳湁鎵€甯姪:)鎯宠鑾峰彇鏈€鏈夎叮鐨凜SS璧勮锛屽崈涓囦笉瑕侀敊杩囨垜鐨勫叕浼楀彿鈥斺€攊CSS鍓嶇濂囬椈杞朵簨馃槃鏇村绮惧僵CSS鎶€鏈枃绔犳眹鎬诲湪鎴戠殑Github鈥斺€攊CSS锛屾寔缁洿鏂帮紝娆㈣繋鐐逛釜鏄熻闃呮敹钘忋€傛湁浠€涔堥棶棰樻垨鑰呭缓璁彲浠ュ浜ゆ祦銆傚師鍒涙枃绔犳枃绗旀湁闄愶紝鐭ヨ瘑鍖箯銆傚鏋滄枃绔犱腑鏈変换浣曚笉鍑嗙‘鐨勫湴鏂癸紝璇峰憡璇夋垜銆?/p>