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

Element2TimelineTimeline组件源码分析

时间:2023-03-28 12:01:15 HTML

绠€浠婽imeline缁勪欢Timeline甯哥敤鏉ュ瀭鐩存樉绀烘椂闂存祦淇℃伅銆傚綋闇€瑕佸強鏃舵帓鍒椾竴绯诲垪淇℃伅鏃讹紝浣跨敤鏃堕棿杞磋繘琛岃瑙夛紙姝e悜鎴栧弽鍚戯級绯诲垪銆傛湰鏂囧皢鍒嗘瀽鍏舵簮鐮佸疄鐜帮紝鑰愬績闃呰锛岀浉淇′細瀵逛綘鏈夋墍甯姪銆傪煍楃粍浠舵枃妗f椂闂磋酱馃敆gitee婧愮爜鏇村缁勪欢鍒嗘瀽瑙侌煈夝煋欵lement2婧愮爜鍒嗘瀽缁勪欢姒傝銆傜粍浠舵簮鐮乼imeline鍑芥暟鎻愪緵浜嗕袱涓粍浠讹細el-timeline鍜宔l-timeline-item銆傚悇涓粍浠剁殑prop澹版槑锛屼互鍙婂悇涓睘鎬х殑鍔熻兘璇存槑鍦ㄥ畼鏂规枃妗imeline#attributes涓湁璇︾粏璇存槑銆傛牴缁勪欢main.vue鏍圭粍浠舵槸涓€涓姛鑳界粍浠讹紝瀹冨鏃犲簭鍒楄〃

    鍏冪礌浣跨敤娓叉煋鍑芥暟/JSX璇硶銆傛彁渚涘尶鍚嶆彃妲芥潵鏄剧ず鑺傜偣鍐呭銆?/packages\timeline\src\main.vue灞炴€everse鐢ㄤ簬鑺傜偣鎺掑簭鏂瑰悜銆備娇鐢╰his.$slots灏嗕紶鍏ユЫ鐨勫厓绱犵被鍨嬩綔涓簐node鑺傜偣鏁扮粍杩涜璁块棶锛岀劧鍚庝娇鐢ㄦ柟娉時everse()灏嗘暟缁勪腑鍏冪礌鐨勪綅缃弽杞€傝鎻掓Ы=this.$slots.default||[];if(reverse){slots=slots.reverse();}杩欑鎺掑簭鏄厓绱犺妭鐐圭殑浣嶇疆椤哄簭锛岃€屼笉鏄妭鐐瑰唴鐨勬椂闂存埑鎺掑簭銆備唬鐮佷腑鏈夊緢澶氭浠g爜锛屽叿浣撳姛鑳藉惈涔変笉鏄庯紙鎰熻鍔熻兘寮€鍙戜腑閫斿仠浜嗭級銆傚睘鎬everse鍊间负true锛岃妭鐐瑰弽杞椂鐢熸垚绫诲悕is-reverse锛屼絾鏍峰紡琛ㄤ腑娌℃湁瀹氫箟璇ョ被銆俢onstclasses={'is-reverse':reverse};//packages\theme-chalk\src\timeline.scss@includeb(timeline){margin:0;瀛椾綋澶у皬锛?--瀛椾綋澶у皬鍩虹锛涘垪琛ㄦ牱寮忥細鏃狅紱//闅愯棌鏈€鍚庝竴涓妭鐐硅酱&.el-timeline-item:last-child{&.el-timeline-item__tail{display:none;}}}渚濊禆娉ㄥ叆浠g爜鍗充娇琚敞閲婃帀涔熶笉浼氬奖鍝嶇粍浠剁殑鍔熻兘銆?/packages\timeline\src\main.vueprovide(){return{timeline:this};},//packages\timeline\src\item.vueinject:['timeline'],鑺傜偣缁勪欢item.vue鑺傜偣缁勪欢妯℃澘鐢ㄤ簬鍛堢幇琛ㄧず鍒楄〃涓」鐩殑
  • 鍏冪礌銆傝鍏冪礌鑺傜偣涓嬬殑鍐呭鍖呭惈涓変釜閮ㄥ垎锛氬瀭鐩磋酱銆傝妭鐐?鍥炬爣銆傚唴瀹癸紙甯︽椂闂存埑锛夈€?template>//鍥炬爣
//鍐呭
娓叉煋鏁堟灉濡備笅锛氬湪涓婁竴鑺備腑锛屾牴缁勪欢瀹氫箟浜嗙敤浜庤缃粨鏉熻妭鐐瑰厓绱犵殑杞翠笉鏄剧ず鐨勬牱寮忋€?el-timeline.el-timeline-item:last-child.el-timeline-item__tail{display:none;}杞寸被鍚峞l-timeline-item__tail鐨刣iv鍏冪礌浣跨敤缁濆甯冨眬锛宭eft鍦ㄨ妭鐐瑰厓绱爈eft閲岄潰:4px,骞堕€氳繃瀹氫箟border-leftheight鏍峰紡灞炴€у疄鐜扮旱杞存晥鏋溿€?el-timeline-item__tail{浣嶇疆锛氱粷瀵癸紱宸︼細4px锛涢珮搴︼細100%锛沚order-left:2pxsolid#e4e7ed;}鑺傜偣timeline鑺傜偣榛樿涓哄渾褰㈠疄蹇冪偣锛岄鑹蹭负#e4e7ed銆傚睘鎬ype鐢ㄤ簬璁剧疆鑺傜偣绫诲瀷鐨勪富棰橈紝鐢熸垚涓嶅悓鐨勯鑹叉牱寮忕被el-timeline-item__node--[primary/success/warning/danger/info]銆傚睘鎬ize鐢ㄤ簬璁剧疆棰勮鐨勮妭鐐瑰ぇ灏忥紙鍖呮嫭offset锛夛紝鐢熸垚el-timeline-item__node--[normal/large]銆傚睘鎬olor鍦ㄥ厓绱犵殑鍐呰仈鏍峰紡backgroundColor:color涓娇鐢紝璁剧疆鑺傜偣棰滆壊銆傝缃睘鎬у浘鏍囧€硷紝浼犲叆鍥炬爣绫诲悕鍗冲彲鐩存帴浣跨敤鍥炬爣銆備负鑷畾涔夎妭鐐规彁渚涘懡鍚嶇偣妲姐€?!--瀹炲績鐐?鍥炬爣-->
{{timestamp}}{{timestamp}}鏍峰紡瀹炵幇缁勪欢鏍峰紡婧愮爜packages\theme-chalk\src\timeline.scss锛宲ackages\theme-chalk\src\timeline-item.scss浣跨敤娣峰悎鎸囦护宓屽鐢熸垚缁勪欢鏍峰紡銆?/packages\theme-chalk\src\timeline.scss//鐢熸垚.el-timeline@includeb(timeline){//...//.el-timeline.el-timeline-item:last-child.el-timeline-item__tail&.el-timeline-item:last-child{&.el-timeline-item__tail{//...}}}//packages\theme-chalk\src\timeline-item.scss//鐢熸垚.el-timeline-item@includeb(timeline-item){//...//鐢熸垚.el-timeline-item__wrapper@includee(wrapper){//...}//鐢熸垚.el-timeline-item__tail@includee(tail){//...}//鐢熸垚.el-timeline-item__icon@includee(icon){//...}//鐢熸垚.el-timeline-item__node@includee(node){//...//鐢熸垚.el-timeline-item__node--normal@includem(normal){//...}//鐢熸垚.el-timeline-item__node--large@includem(large){//...}//鐢熸垚.el-timeline-item__node--[primary/success/warning/danger/info]@includem(primary){//...}//success/warning/danger/淇℃伅....}//鐢熸垚.el-timeline-item__dot@includee(dot){//...}//鐢熸垚.el-timeline-item__content@includee(content){//...}//鐢熸垚.el-timeline-item__timestamp@includee(timestamp){//...//鐢熸垚.el-timeline-item__timestamp.is-top@includewhen(top){//...}//鐢熸垚.el-timeline-item__timestamp.is-bottom@includewhen(bottom){//...}}}鍏虫敞涓撴爮濡傛灉鏈枃瀵规偍鏈夊府鍔╋紝璇峰叧娉ㄢ灂銆佺偣璧烉煈嶃€佹敹钘忊瓙锛佹偍鐨勮鍙槸瀵规垜鏈€澶х殑鏀寔锛?/p>