组件封装思路——以一个简单的加载动画为例
时间:2023-03-28 15:33:36
HTML
鍐呭骞朵笉澶嶆潅锛屽彧鏄负浜嗚鏄庣粍浠跺皝瑁呯殑鎬濊矾銆傛垜浠厛鏉ョ湅涓€涓姩鐢汇€傛垜浠厛鏉ュ垎鏋愪竴涓嬪姩鐢汇€傚姩鐢讳腑鐨勬瘡涓瓧姣嶉兘鏈変竴涓崟鐙殑鑺傛媿銆傝烦璺冨姩鐢绘槸涓€鏍风殑锛屼絾姣忎釜瀛楁瘝鐨勫紑濮嬫椂闂翠笉鍚屻€傚彲浠ョ湅鍑猴紝杩欎釜鍔ㄧ敾涓殑鍔ㄧ敾鏁堟灉鍏跺疄鏄竴涓€傚彧鏄綋涓嶅悓鐨勫厓绱犳寚瀹氳繖涓姩鐢绘椂锛屽欢杩熸椂闂存槸鏈夋帶鍒剁殑銆傜劧鍚庢垜浠彲浠ュ皢鏂囨湰鐨勬瘡涓瓧姣嶆斁鍏ヤ竴涓猻pan鏍囩涓€傜劧鍚庝负姣忎釜浜嬩欢鏍囩鍒嗛厤涓€涓姩鐢绘牱寮忋€傝繖鍙互閫氳繃浣跨敤nth-of-type鏉ュ疄鐜般€?divclass="loadingloading-1">loading...
.loading{杈硅窛锛?00鍍忕礌锛涢珮搴︼細100px锛沴ine-height:100px;}.loading>span{display:inline-block;鏂囨湰杞崲锛氬ぇ鍐欙紱瀛楁瘝闂磋窛锛?px锛沘nimation:loadingWord800msease-inininfinitealternate;}/*10涓瓧姣嶏紝姣忎竴涓殑寤惰繜閮戒笉鐩稿悓*/.loading-1>span:nth-of-type(1){animation-delay:200ms;}.loading-1>span:nth-of-type(2){鍔ㄧ敾寤惰繜锛?00ms锛泒.loading-1>span:nth-of-type(3){鍔ㄧ敾寤惰繜锛?00ms锛泒.loading-1>span:nth-of-type(4){鍔ㄧ敾寤惰繜锛?00ms锛泒.loading-1>span:nth-of-type(5){鍔ㄧ敾寤惰繜锛?00ms锛泒.loading-1>span:nth-of-type(6){鍔ㄧ敾寤惰繜锛?00ms锛泒.loading-1>span:nth-of-type(7){鍔ㄧ敾寤惰繜锛?00ms锛泒.loading-1>span:nth-of-type(8){鍔ㄧ敾寤惰繜锛?00ms锛泒.loading-1>span:nth-of-type(9){鍔ㄧ敾寤惰繜锛?000ms锛泒.loading-1>span:nth-of-type(10){鍔ㄧ敾寤惰繜锛?100ms锛泒@keyframesloadingWord{0%{transform:translateY(0);}50%{杞崲锛歵ranslateY(0);}100%{杞崲锛歵ranslateY(-16px);}}杩欐牱灏卞彲浠ュ揩閫熷疄鐜板姩鐢讳簡銆傜劧鍚庝笂闈㈢殑浠g爜灏嗚捣浣滅敤銆傚鏋滄垜浠渶瑕佸皢杩欎釜鍔犺浇鍔ㄧ敾灏佽鍒颁竴涓粍浠朵腑锛屾柟渚垮悗缁被浼煎満鏅殑浣跨敤锛屾垜浠渶瑕佽€冭檻鐨勪笢瑗垮氨鏇村浜嗭紝涓嶈兘绠€鍗曠殑瀹炵幇杩欑鏁堟灉銆傞鍏堬紝鎴戜滑闇€瑕佸垎鏋愪竴涓嬭繖涓嚱鏁颁腑鍙兘鍙戠敓鍙樺寲鐨勯儴鍒嗭細杩欎釜鍔ㄧ敾浠h〃浜嗕竴涓瓑寰呯殑杩囩▼銆傜瓑寰呯殑杩涚▼鍙兘姝e湪loading銆乴oading锛涗笅杞斤紝涓嬭浇锛泆ploading,uploading,etc.鎵€浠ヨ繖閲岀殑鏂囧瓧闇€瑕佹槸鍙厤缃殑銆傛枃鏈殑鏍峰紡鍙兘闇€瑕佹洿鏀广€傛牳蹇冩槸鏂囧瓧澶у皬鍜岄鑹层€傚姩鐢绘柟寮忋€佸姩鐢婚鐜囥€傚洜涓鸿繖涓粍浠舵湰韬氨鏄烦璺冪瓑寰呭姩鐢伙紝鎵€浠ュ缓璁慨澶嶅姩鐢婚儴鍒嗐€傚惁鍒欙紝缁勪欢杩囦簬鐏垫椿锛屼娇鐢ㄨ捣鏉ヤ細寰堜笉鏂逛究銆備笉濡ㄥ疄鐜颁袱涓粍浠躲€傛枃鏈儴鍒嗗拰鍓嶉潰鐨勪唬鐮佷竴鏍凤紝闇€瑕佸湪CSS涓‖缂栫爜绱㈠紩锛屽苟涓烘瘡涓浐瀹氫綅缃殑瀛愬厓绱犺缃姩鐢诲欢杩熴€傚鏋滄枃鏈暱搴︿笉鍥哄畾锛岄偅涔堣繖绉嶅啓娉曟槸鏈夐棶棰樼殑銆傝繖鏄垜浠鍏堣瑙e喅鐨勩€傝繖鍙互閫氳繃浣跨敤css鍙橀噺鏉ヨВ鍐炽€備唬鐮佸涓?divclass="loadingloading-2">
loading銆?/span>.. .loading{margin:100px;楂樺害锛?00px锛沴ine-height:100px;}.loading>span{display:inline-block;鏂囨湰杞崲锛氬ぇ鍐欙紱瀛楁瘝闂磋窛锛?px锛涘姩鐢伙細loadingWord800msease-in鏃犻檺浜ゆ浛锛沘nimation-delay:calc(var(--index)*100ms+200ms);}杩欐牱姣忎釜span閮芥湁鑷繁鐨?-index銆傜劧鍚庡姩鐢诲欢杩熶細璁$畻--index瀵瑰簲鐨勬椂闂淬€傝鎴戜滑灏嗗瓙鑺傜偣鏇存敼涓篔S浠ヨ鍙栨煇涓枃鏈潵鐢熸垚瀹冦€?divclass="loadingloading-3"id="load">loading...