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

CSS如何让autoheight完美支持转场动画?

时间:2023-04-05 23:04:50 HTML5

娆㈣繋鍏虫敞鎴戠殑鍏紬鍙凤細鍓嶇渚︽帰閮界煡閬擄紝璁剧疆楂樺害涓篴uto鍏抽敭瀛楁椂锛宼ransition杩囨浮鍔ㄧ敾鏄笉浼氳Е鍙戠殑銆備互涓嬫槸浼唬鐮乨iv{height:0;transition:1s}.wrap:hoverdiv{height:auto}鏁堟灉濡備笅銆傚鏋滀綘鎯冲湪灞曞紑鐨勬椂鍊欐湁涓€涓繃娓″姩鐢伙紝姣斿浣犱竴鑸兘鏄敤JS鍔ㄦ€佽幏鍙栧厓绱犵殑楂樺害锛堣繕鏄湁鐐归夯鐑︼紝闇€瑕乺ender鎵嶈兘鐭ラ亾楂樺害锛夈€傚叾瀹濩SS涔熸湁瑙e喅鏂规锛屽氨鏄敤max-height鏉ラ€傞厤鍔ㄦ€侀珮搴︺€備互涓嬫槸浼唬鐮乨iv{max-height:0;transition:1s}.wrap:hoverdiv{max-height:800px/*杩戜技鍊硷紝闇€瑕佽秴杩囧厓绱犵殑楂樺害*/}鏈夊叴瓒g殑鍙互鍙傝€冭繖绡囨枃绔狅細CSStricksandtricks:dynamicheighttransition鍔ㄧ敾锛屼絾鏄湁涓€涓檺鍒讹紝楂樺害宸秺澶э紝杩囨浮鏁堟灉瓒婂樊锛屽亣璁惧厓绱犵殑鐪熷疄楂樺害鍙湁100px锛屽鏋渕ax-height鏄?00px锛岄偅涔堝彧鏈夊墠1/8浼氬姩鐢伙紝鍍忚繖鏍烽偅涔堬紝鏈夋病鏈夋洿濂界殑鏂规硶鏉ヨВ鍐宠繖涓棶棰樺憿锛熷綋鐒舵湁锛岃繖娆′粙缁嶄竴绉嶅叏鏂扮殑瀹炵幇楂樺害鍔ㄦ€佽繃娓$殑鏂瑰紡锛屼竴璧锋潵鐪嬬湅1.缃戞牸甯冨眬涓殑fr鍗曞厓缃戞牸甯冨眬涓柊澧炰簡涓€涓猣r鍗曞厓锛岀敤浜庡畾涔夌綉鏍艰建閬撳脊鎬фā閲忕殑澶у皬銆傜綉鏍煎竷灞€姣旇緝澶嶆潅锛屼笉鍙兘涓夎█涓よ璇存竻妤氥€傛湁鍏磋叮鐨勫彲浠ュ弬鑰冪綉鏍肩浉鍏崇殑鏁欑▼锛屾瘮濡傚睍绀猴細寮犳柊鏃€佸笀鍐欑殑缃戞牸甯冨眬鏁欑▼澶ч瓟鐜嬬殑鐜颁唬Web甯冨眬銆傝繖閲岀畝鍗曚粙缁嶄竴涓媐r鍗曞厓鐨勪娇鐢紝姣斿鏈夎繖鏍风殑甯冨眬1fr1fr1fr

鍏抽敭鏍峰紡濡備笅銆傜綉鏍納鏄剧ず锛氱綉鏍硷紱grid-template-columns:repeat(3,1fr);}鍙互寰楀埌杩欐牱鐨勬晥鏋溿€傝繖閲岀殑repeat(3,1fr)鍏跺疄鏄?fr1fr1fr鐨勭缉鍐欙紝琛ㄧず3绛夊垎鍓╀綑绌洪棿銆備篃鍙互璁剧疆鍦ㄥ瀭鐩存柟鍚戙€俫rid{grid-template-rows:repeat(3,1fr);}鏁堟灉濡備笅锛屼篃鍙互鏀瑰彉鍚勮嚜鐨勫垎閰嶆瘮渚嬨€俫rid{grid-template-rows:1fr2fr1fr;}鏁堟灉濡備笅鐜板湪鐪嬩釜鐗逛緥锛屼篃鍙互璁剧疆鍒嗛厤姣斾緥涓?fr.grid{grid-template-rows:0fr2fr1fr;}鏄笉鏄湁鐐瑰鎬紝鏁堟灉濡備笅锛?fr鎬庝箞鍜?fr姣斾緥涓€鏍凤紵鍏跺疄杩欐槸鐢辩綉鏍肩殑鏈€灏忓昂瀵歌鍒欏喅瀹氱殑銆傛鏃舵渶灏忛珮搴︿负min-content锛岀敱鍐呴儴鏂囧瓧鍐冲畾銆傚鏋滄病鏈夋枃瀛楋紝0fr鑷劧涓嶄細鍗犵敤绌洪棿銆備笅闈㈡槸鍘绘帀鏂囧瓧鍚庣殑鏁堟灉銆傛兂淇濈暀鏂囧瓧涓嶅崰绌洪棿鎬庝箞鍔烇紵鍙互鐩存帴鎵嬪姩璁剧疆鏈€灏忓昂瀵竤pan{min-height:0}杩欐牱0fr灏变笉浼氬崰鐢ㄧ┖闂翠簡銆傛偍杩樺彲浠ヤ娇鐢ㄦ孩鍑烘潵瀹屽叏闅愯棌瀛愬唴瀹广€俫rid{overflow:hidden;}span{min-height:0}鏁堟灉搴旇鏄繖鏍锋瘮杈冨ソ鐞嗚В锛岄偅璺熷姩鐢绘湁浠€涔堝叧绯诲憿锛熺劧鍚庡線涓嬬湅2.鍙兘鏈夊悓瀛︿細鐤戞儜grid涓殑杩囨浮鍔ㄧ敾锛屼綍蹇呯籂缁撹繖涓?fr鍛紵鎻ず涓€涓嬶紝濡傛灉閲嶇疆1fr锛屽瓙鍐呭浼氶噸鏂板嚭鐜般€俫rid{grid-template-rows:1fr2fr1fr;}涓嬮潰鏄噸鐐癸紝grid涓殑fr鍗曞厓涔熸敮鎸佽繃娓″姩鐢伙紙0fr=>1fr).grid{缃戞牸妯℃澘琛?1fr2fr1fr;transition:.3s}鏁堟灉濡備笅鐢变簬鍐呴儴鏂囨湰寮€鍚簡楂樺害锛屽嵆楂樺害涓嶇‘瀹氾紝浠?fr鍒?fr鐨勮繃娓$浉褰撲簬瀹炵幇浜嗕笉鍚岄珮搴﹀浐瀹氱殑杩囨浮鍔ㄧ敾鍙互杩涗竴姝ョ簿绠€涓鸿揪鍒拌繖鏍风殑鏁堟灉銆傝繖鏄珮搴︿笉鍥哄畾鐨勫姩鐢诲師鍨嬨€傛枃瀛楀啀澶氫竴鐐逛篃鑳藉畬缇庢敮鎾戝畬鏁寸殑demo銆傚彲浠ユ煡鐪嬩互涓嬩换鎰忛摼鎺SS鑷姩楂樺害杩囨浮锛坈odepen.io锛塁SS鑷姩楂樺害杩囨浮锛坮unjs.work锛?.鑷€傚簲楂樺害鍔ㄧ敾鐨勪袱涓緥瀛愪笅闈㈡牴鎹互涓婂師鐞嗗疄鐜颁袱涓緥瀛愩€傚厛鐪嬫枃绔犲紑澶寸殑渚嬪瓙锛孒TML缁撴瀯鏄繖鏍风殑鎶婇紶鏍囨斁鍦ㄤ笂闈㈣瘯璇?/button>

娆㈣繋鍏虫敞鍓嶇绁炴帰锛岃繖閲屾湁涓€浜涗綘鍙兘涓嶇煡閬撶殑鏈夎叮鐨凥TML銆丆SS銆丣S鎶€宸у拰绐嶉棬锛屾瘮濡傝繖绡囨枃绔狅紝濡備綍璁゛utoheight鏀寔transition鍔ㄧ敾鐗囷紵涓€璧锋潵鐪嬬湅

绠€鍗曠殑淇敼锛屽簲璇ユ槸姣旇緝瀹规槗鐨勶紝閫氳繃涓婇潰鐨勬妧宸у氨鍙互鎼炲畾杩欎釜鏁堟灉鐒跺悗闅愯棌涓嬫媺鍐呭锛屽叧閿牱寮忓涓嬨€俫rid{display:grid;缃戞牸妯℃澘琛岋細0fr锛涜繃娓★細.3s锛沷verflow:hidden;}.grid>div{min-height:0;}鐒跺悗閫氳繃hover瑙﹀彂鏄剧ず锛屽嵆鏀瑰彉grid-template-rows.wrap:hover.grid{grid-template-rows:1fr;}涓繖鏍峰氨瀹炵幇浜嗗彉楂樼殑杩囨浮鍔ㄧ敾銆傚浜庡畬鏁寸殑婕旂ず锛屾偍鍙互鏌ョ湅浠ヤ笅浠讳綍閾炬帴CSSautoheightdrop(codepen.io)CSSautoheightdrop(runjs.work)ifonly瀹冩槸涓€涓诞鍔ㄧ獥鍙c€傚洜涓烘槸缁濆瀹氫綅锛屾墍浠ヤ笉浼氬奖鍝嶅叾浠栧竷灞€銆傚叾瀹炲彲浠ョ敤transformscale鏉ョ缉鏀俱€傝鎴戜滑鐪嬪彟涓€涓洿瀹為檯鐨勪緥瀛愩€傛櫘閫氳彍鍗曠殑灞曞紑鍜屾姌鍙狅紝鍙互鐪嬪埌锛屽湪灞曞紑鐨勫悓鏃讹紝涓嬮潰鐨勫厓绱犱篃琚尋鍘嬩簡锛岃繖鏍锋晥鏋滄洿鑷劧锛屾槸transform鏃犳硶瀹炵幇鐨勩€傝繖閲岀殑鍒囨崲鏄€氳繃:checked瀹炵幇鐨勩€傚叧閿唬鐮佸涓?inputhiddentype="checkbox"id="s1"checked/>Workbench
  • 椤圭洰鍒楄〃
  • 鏁版嵁閰嶇疆鍣?/li>
ul{min-height:0;}.sub{display:grid;grid-template-rows:0fr;transition:0.3s;overflow:hidden;}:checked~.sub{grid-template-rows:1fr;}瀹屾暣鐨刣emo鍙互鍦ㄤ互涓嬩换涓€閾炬帴鏌ョ湅CSS鑷姩楂樺害鑿滃崟锛坈odepen.io)CSSautoheightmenu(runjs.work)4.娉ㄦ剰浜嬮」鍜屼竴浜涢檺鍒朵互涓嬫槸涓€浜涙敞鎰忎簨椤硅繖閲岀殑鍔ㄧ敾鏉ヨ嚜浜巊rid-template-rows鐨勫彉鍖栵紝涔熷氨鏄?fr鍙樻垚1fr娉ㄦ剰锛屾敞鎰忥紝娉ㄦ剰锛岃繖閲岀殑0fr蹇呴』鏄?fr锛屼笉鑳芥槸0涔熶笉鏄?px锛屽繀椤绘槸fr鍗曚綅涓嬮潰鏄敼鎴?0px鐨勬晥鏋?鍔ㄧ敾Lost)鑰屼笖0fr涓嶆敮鎸乧alc璁$畻锛岀洿鎺ヨ涓烘槸闈炴硶鐨勩€傝繖鎰忓懗鐫€锛屼緥濡傦紝鎮ㄥ笇鏈涢粯璁ゅ叿鏈夊浐瀹氶珮搴︼紙涓嶆槸0锛夛紝鐒跺悗鎵╁睍鍒拌嚜閫傚簲楂樺害銆傝繖涓柟娉曚笉鑳藉疄鐜拌浆鍦哄姩鐢伙紝鏈夌偣閬楁喚馃槬5.鏈€鍚庢€荤粨涓€涓嬶紝鏈€鍚庡洖椤句竴涓嬪疄鐜扮殑鍏抽敭杩囩▼銆傜綉鏍納鏄剧ず锛氱綉鏍硷紱缃戞牸妯℃澘琛岋細0fr锛涜繃娓★細.3s锛沷verflow:hidden;}.grid>div{min-height:0;}.wrap:hover.grid{grid-template-rows:1fr;}涓昏鏄埄鐢ㄧ綉鏍煎脊鎬у竷灞€鐨勭壒鎬э紝鍙互瀹炵幇杩囨浮鍔ㄧ敾銆備笅闈㈡€荤粨浜嗕竴浜涘疄鐜拌鐐广€傚綋height璁剧疆涓篴uto鍏抽敭瀛楁椂锛屼笉浼氳Е鍙憈ransitiontransition鍔ㄧ敾缃戞牸甯冨眬涓殑fr鍗曚綅鍙互鐢ㄦ潵瀹氫箟缃戞牸杞ㄩ亾澶у皬鐨勫脊鎬х郴鏁般€傜綉鏍煎竷灞€鐨勫昂瀵歌绠楄鍒欑敱鏈€灏忛珮搴﹀喅瀹氥€傞粯璁や负min-content锛岀敱鍐呴儴鏂囨湰鍐冲畾锛屽彲浠ユ墜鍔ㄧ‘瀹氥€傝缃甿in-height瀹炵幇0frgrid甯冨眬锛屽悓鏃朵篃鏀寔杩囨浮鍔ㄧ敾锛?fr=>1fr锛夛紝杩欐牱灏卞彲浠ュ疄鐜板彲鍙橀珮搴︾殑杩囨浮鍔ㄧ敾銆傝璁╄繃娓″姩鐢荤敓鏁堬紝蹇呴』浠r涓哄崟浣嶏紝涓嶈兘鎺ュ彈鍏朵粬鍗曚綅锛屼篃涓嶈兘閫氳繃calc鏂规硶璁$畻锛屽彧鑳藉疄鐜颁粠鍒濆楂樺害0鍒拌嚜閫傚簲楂樺害鐨勮繃娓°€傛湁鐐归仐鎲俱€傛渶鍚庯紝濡傛灉鎮ㄨ寰楄繕涓嶉敊锛屽鎮ㄦ湁甯姪锛岃鐐硅禐銆佹敹钘忋€佽浆鍙戔潳鉂も潳娆㈣繋鍏虫敞鎴戠殑鍏紬鍙凤細鍓嶇澶т睛鎺?/p>