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

Vue全家桶组件化开发

时间:2023-04-02 23:40:31 HTML

浣滆€厊鏉版柉鍏嬫.鎺橀噾|https://juejin.im/user/5a16e1...瀛︿範缁勪欢鍖栧紑鍙戯紝棣栧厛鎺屾彙缁勪欢鍖栧紑鍙戞€濇兂銆佺粍浠舵敞鍐屾柟寮忋€佺粍浠舵暟鎹氦浜掓柟寮忋€佺粍浠舵Ы鐨勪娇鐢ㄣ€佺粍浠舵Ы鐨勪娇鐢╲ue璋冭瘯宸ュ叿锛岀粍浠跺疄鐜颁笟鍔¢€昏緫鍔熻兘鐨勬柟寮忋€傜粍浠跺紑鍙戞€濊矾锛岀粍浠舵敞鍐岋紝缁勪欢璋冭瘯锛岀粍浠堕棿鏁版嵁浜や簰锛岀粍浠舵Ы缁勪欢鍖栬鑼冿紝澶嶇敤鍏ㄥ眬缁勪欢娉ㄥ唽璇硶鏈夊绉嶅彲鑳絍ue.component(缁勪欢鍚?{data:缁勪欢鏁版嵁,template:缁勪欢妯℃澘鍐呭})//瀹氫箟涓€涓悕涓篵utton-counter鐨勬柊缁勪欢Vue.component('button-counter',{data:function(){return{count:0}},template:'鐐瑰嚮{{count}}娆?/button>})缁勪欢浣跨敤

Vue.component('button-counter',{data:function(){return{count:0}},template:'鐐瑰嚮{{count}}'鏂规硶锛歿handle:function(){this.count+=2;}}})varvm=newVue({el:'#app',data:{}});娉ㄥ唽缁勪欢鏃讹紝data蹇呴』鏄嚱鏁帮紝缁勪欢妯℃澘鐨勫唴瀹瑰繀椤绘槸鍗曟牴鍏冪礌妯℃澘锛歚
鐐瑰嚮{{count}}娆?/button>
`銆佺粍浠跺懡鍚嶆柟寮?/鐭í绾挎柟寮廣ue.component('my-component',{/*...*/})//椹煎嘲鏂瑰紡Vue.component('鎴戠殑缁勪欢',{/*...*/}}閮ㄥ垎缁勪欢娉ㄥ唽varComponentA={/*...*/}varComponentB={/*...*/}varComponentC={/*...*/}newVue({el:'#app',components:{'component-a':ComponentA,'component-b':ComponentB,'component-c':ComponentC,}})vue璋冭瘯宸ュ叿鐨勪娇鐢ㄧ‘淇濅綘浣跨敤鐨勬槸Node6+鍜孨PM3+鍏嬮殕杩欎釜reponpm瀹夎锛堝鏋滀綘浣跨敤yarn浣滀负鍖呯鐞嗗櫒锛屽垯瀹夎yarn锛塶pmrunbulid鎵撳紑Chrome鎵╁睍椤甸潰妫€鏌モ€滃紑鍙戣€呮ā寮忊€濈偣鍑烩€滃姞杞借В鍘嬬殑鎵╁睍鈥濓紝鐒跺悗閫夋嫨shells/chrome.HackingClone杩欎釜reponpminstallnpmrundev鍦╨ocalhost:8100浼氬緱鍒颁竴涓甫娴嬭瘯app鐨勬櫘閫歴hell銆傚畨瑁呰皟璇曞伐鍏风涓€姝ュ厠闅嗕粨搴擄紝绗簩姝ュ畨瑁呬緷璧栧寘锛岀涓夋鏋勫缓锛岀鍥涙锛屾墦寮€Chrome鎵╁睍椤甸潰锛岀浜旀锛岄€夋嫨寮€鍙戣€呮ā寮忥紝绗叚姝ワ紝鍔犺浇瑙e帇鍚庣殑鎵╁睍锛岄€夋嫨shells/chrome缁勪欢闂存暟鎹氦浜掔埗缁勪欢浼犲€肩粰瀛愮粍浠剁粍浠堕€氳繃props鎺ユ敹浼犲€糣ue.component('dada-item',{props:['title'],//鐢ㄤ簬鎺ユ敹鐢眛heparentcomponenttemplate:'
{{title}}
'})鐖剁粍浠堕€氳繃灞炴€?dada-itemtitle="Datafromtheparentcomponent">//闈欐€?dada-item:title="title">//鍔ㄦ€佸睘鎬х粦瀹氫唬鐮佺ず渚嬶細//鐖剁粍浠朵紶鍊肩粰瀛愮粍浠禫ue.component('dada-item',{//瀛愮粍浠舵帴鏀剁埗缁勪欢//title灞炴€rops:['title'],data:function(){return{msg:'瀛愮粍浠剁殑鏁版嵁'}},template:'
{{msg+"..."+title}}
'});varvm=newVue({el:'#app',data:{pmsg:'鐖剁粍浠朵腑鐨勫唴瀹?,ptitle:'dynamic',}});props灞炴€у悕绉扮殑瑙勫垯鏄湪props褰㈠紡涓娇鐢ㄩ┘宄板紡澶у皬鍐欙紝鎮ㄩ渶瑕佸湪妯℃澘涓娇鐢ㄧ牬鎶樺彿銆傚瓧绗︿覆褰㈠紡鐨勬ā鏉挎病鏈夎繖鏍风殑闄愬埗銆俈ue.component('dada-item',{//JavaScript涓殑hump-styleprops:['daTitle'],template:'
{{title}}
'})//杩欐槸涓€涓畝鐭殑html涓殑姘村钩绾?dada-itemda-title="dada">
{{pmsg}}
//鐖剁粍浠朵紶鍊肩粰瀛愮粍浠?灞炴€у悕Vue.component('third-com',{props:['testTitle'],template:'
{{testTitle}}
'});Vue.component('menu-item',{props:['menuTitle'],template:'
{{menuTitle}}
'});props灞炴€у€肩被鍨媠tring绫诲瀷string鍊肩被鍨媙umberboolean绫诲瀷booleanarray绫诲瀷arrayobjectobject//string褰㈠紡pstr">
//鏁板瓧浼犲€?dada-item:pstr='pstr':pN='11'>//鐖剁粍浠朵紶鍊肩粰瀛愮粍浠?props灞炴€у悕typeVue.component('dada-item',{props:['pstr','pN'],template:`
{{pstr}}
{{pN}}
`});varvm=newVue({el:'#app',data:{pmsg:'鐖剁粍浠?pstr:'dada'}});瀛愮粍浠朵紶鍊肩粰鐖剁粍浠?dada-item:parr="parr">//瀛愮粍浠朵紶鍊肩粰鐖剁粍浠禫ue.component('dada-item',{props:['parr'],妯℃澘锛歚
鐐瑰嚮
`});varvm=newVue({el:'#app',data:{pmsg:'鐖剁粍浠?,parr:['da1','da2','da3']}}];瀛愮粍浠朵紶鍊肩粰鐖剁粍浠剁粍浠讹紝瀛愮粍浠堕€氳繃鑷畾涔変簨浠跺悜鐖剁粍浠朵紶閫掍俊鎭?buttonv-on:click='$emit("eventname",value)'>dada鐖剁粍浠剁洃鍚瓙缁勪欢浜嬩欢闈炵埗瀛愮粍浠朵紶鍊煎厔寮熺粍浠堕棿浜や簰varevent=newVue()浜嬩欢涓績鐩戝惉浜嬩欢鍜屼簨浠堕攢姣佷簨浠?$on('鑷畾涔変簨浠跺悕绉?,eventfunction)鐩戝惉浜嬩欢锛岀涓€涓弬鏁颁负鑷畾涔夌洃鍚簨浠剁殑鍚嶇О锛岀浜屼釜涓轰簨浠跺嚱鏁癳vent.$off('鑷繁瀹氫箟浜嬩欢鐨勫悕绉?)//destroy浜嬩欢瑙﹀彂浜嬩欢event.$emit('鑷畾涔変簨浠跺悕绉?,id)mounted:function(){//鐩戝惉浜嬩欢eventhub.$on('da1',(val)=>{this.num+=val;});}mounted:function(){//鐩戝惉浜嬩欢eventhub.$on('da2',(val)=>{this.num+=val;});}Componentslot鐖剁粍浠朵紶鏁版嵁缁欏瓙缁勪欢锛岀埗缁勪欢浼犳暟鎹粰瀛愮粍浠?/鐖剁粍浠?dada-item>dada杩欓噷鐨刣ada娌℃湁slot鏄棤娉曟樉绀虹殑//瀛愮粍浠秙lot鐨勪綅缃?slot>slot浣嶄簬瀛愮粍浠剁殑妯℃澘涓?/slot鐨勪綅缃甐ue.component('dada-box',{template:`
da
//鏄剧ず浣嶇疆
`})//鏄剧ず鍐呭锛宻lotdadahello閲嶇偣锛屽懡鍚嶆Ы鐢ㄦ硶锛屽懡鍚嶆Ы
鎻掓Ы鍐呭Header

璁╁紑锛岃揪杈炬潵浜?/p>Bottom

鏍囬1

<p>Header2

//鏀剧疆鏇村鍐呭鑼冨洿妲?dada-list:list="list">Vue.component('dada-list',{props:['list'],template:`
{{item.name}}
`});varvm=newVue({el:'#app',data:{list:[{id:1,name:'dada'},{...}]}鎻掓Ы瀹氫箟锛屽瓙缁勪欢
    {{item.name}}
//鎻掓Ы鍐呭{{slotPrOps.info.name}}Shopping姹借溅鍔熻兘鐨勬楠わ紝瀹炵幇鏁翠綋甯冨眬鍜屾牱寮忥紝鍒掑垎鍔熻兘缁勪欢锛屽皢鎵€鏈夊瓙缁勪欢缁勫悎鎴愪竴涓暣浣撶粨鏋勶紝涓€涓€瀹炵幇姣忎釜缁勪欢鐨勫姛鑳斤紝鏍囬缁勪欢锛屽垪琛ㄧ粍浠讹紝缁撶畻缁勪欢鏈€鍚庢杩庡姞鎴戝井淇★紙xiaoda0423)鎷変綘杩涙妧鏈兢锛岄暱鏈熶氦娴佸涔?..娆㈣繋鍏虫敞鈥滆揪杈惧墠绔€濓紝璁ょ湡瀛︿範鍓嶇锛屽仛涓€涓笓涓氱殑鎶€鏈汉...鍦ㄥ崥瀹㈠钩鍙颁笂锛屾湭鏉ョ殑璺繕寰堥暱锛屽笇鏈涘ぇ瀹剁湅鎴戜互鍚庣殑鏂囩珷澶氬鏀寔锛屽澶氭壒璇勬寚姝o紝鎴戜滑涓€璧疯繘姝ワ紝涓€璧疯蛋杩欐潯璺€傞潪甯告劅璋㈡偍闃呰杩欑瘒鏂囩珷銆傚鏋滆繖绡囨枃绔犲啓鐨勫ソ锛屽鏋滀綘瑙夊緱鈥滆揪杈锯€濇湁浠€涔堬紝濡傛灉浣犺寰楁垜鍙互鍧氭寔瀛︿範锛屽鏋滀綘瑙夊緱杩欎釜浜哄彲浠ヤ氦鍒版湅鍙嬶紝璇风偣璧烉煈嶈鍏虫敞鉂わ笍璇峰垎浜煈ョ湡鐨勬槸瀵规垜鍜屾殩鐢锋湁鐢紒锛侊紒鉂わ笍鍒繕浜嗙暀涓嬪涔犵殑瓒宠抗銆愮偣璧?鏀惰棌+璇勮銆慉uthorInfo:銆愪綔鑰呫€戯細Jeskson銆愬師鍒涘叕浼楀彿銆戯細杈捐揪鍓嶇灏忛厭棣嗐€傘€愮鍒┿€戯細鍏紬鍙峰洖澶嶁€滀俊鎭€濓紝閫佽嚜瀛﹁祫鏂欏ぇ绀煎寘锛堣繘缇ゅ垎浜紝鎯宠浠€涔堝氨璇达紝鐪嬫垜鏈夋病鏈夛級锛併€愯浆杞借鏄庛€戯細杞浇璇锋敞鏄庡嚭澶勶紝璋㈣阿鍚堜綔锛亊澶у墠绔紑鍙戯紝瀹氫綅鍓嶇寮€鍙戞妧鏈爤鍗氬锛孭HP鑳屾櫙鐭ヨ瘑鐐癸紝web鍏ㄦ爤鎶€鏈鍩燂紝鏁版嵁缁撴瀯涓庣畻娉曪紝缃戠粶鍘熺悊绛変互閫氫織鏄撴噦鐨勬柟寮忓憟鐜扮粰灏忎紮浼存柟寮忋€傛劅璋㈡偍鐨勬敮鎸侊紝鎰熻阿鎮ㄧ殑鍘氱埍锛侊紒锛佸鏈处鍙峰唴瀹规湁闂锛堜緥濡傦細娑夊強鐗堟潈鎴栧叾浠栭棶棰橈級锛岃鍙婃椂鑱旂郴鎴戜滑杩涜鏁存敼锛屾垜浠細灏藉揩澶勭悊銆傝鍠滄瀹冿紒鍥犱负鎮ㄧ殑璁ゅ彲/榧撳姳鏄垜鍐欎綔鏈€澶х殑鍔ㄥ姏锛佹杩庢潵鍒拌揪杈剧殑CSDN锛佽繖鏄竴涓湁鍝佽川鏈夋€佸害鐨勫崥瀹?/p>