当前位置: 首页 > Web前端 > vue.js

你知道Vue有多少种创建组件的方式吗?

时间:2023-03-31 21:59:37 vue.js

.dialog-page{position:fixed;椤堕儴锛?锛涚寮€鍚細0锛涘搴︼細100vw锛涢珮搴︼細100vh锛涜儗鏅壊锛歳gba(0,0,0,0.6);z-鎸囨暟锛?9999锛?dialog-box{浣嶇疆锛氱粷瀵癸紱椤堕儴锛?0%锛涘乏锛?0%锛涜浆鎹細translateX(-50%)锛涗繚璇侀噾锛氳嚜鍔紱瀹藉害锛?00px锛涢珮搴︼細400px锛涘~鍏呴《閮細20px锛涜儗鏅壊锛?fff锛涜竟鐣屽崐寰勶細10px锛涙闃村奖锛?06px0#fff锛?title{鏂囨湰瀵归綈锛氬眳涓紱瀛椾綋澶у皬锛?2px锛涢鑹诧細#333锛泒.close{浣嶇疆锛氱粷瀵癸紱鍙筹細20px锛涢《閮細20px锛涙父鏍囷細鎸囬拡锛泒.confirm-btn{瀹藉害锛?0%锛涗綅缃細缁濆锛涘乏锛?0%锛涘簳閮細50px锛泒}}.fade-enter-active,.fade-leave-active{transition:opacity.2s;}.fade-enter,.fade-leave-to/*.fade-leave-activebelowversion2.1.8*/{opacity:0;}鍓嶈█鐜板湪鍓嶇寮€鍙戜及璁¢兘鏄敤Vue銆傜粍浠朵篃鏄疺ue鐨勬牳蹇冨唴瀹癸紝涔熸槸鎴戜滑鍦ㄦ棩甯稿紑鍙戜腑鎺ヨЕ鏈€澶氱殑涓滆タ銆傞偅涔堜粈涔堟槸缁勪欢鍛紵涓€涓粍浠跺彲浠ュ皬鍒颁竴涓寜閽€佷竴涓浘鏍囷紝涔熷彲浠ュぇ鍒颁竴涓〉闈紝鐢氳嚦鏄竴涓郴缁熴€傛渶杩戞帴鎵嬩簡涓€涓猇ue椤圭洰锛屽彲浠ヨ鏄敹鑾烽涓帮紝鍖呮嫭鏈枃鎻愬埌鐨勨€滅粍浠垛€濓紝鎵€浠ユ兂鍐欎笅鏉ュ垎浜竴涓嬨€傛湰鏂囦笉璁茬粍浠剁殑鍩虹鐭ヨ瘑锛屽彧璁插嚑绉嶅垱寤虹粍浠讹紙娉ㄥ唽锛夌殑鏂规硶銆傚叏灞€娉ㄥ唽Vue.component('my-component-name',{//...options...})鎴戜滑鍙互閫氳繃杩欑鏂瑰紡鍒涘缓鍏ㄥ眬缁勪欢锛屽湪瀹炰緥鍖朧ue涔嬪墠浣跨敤Vue.component鍒涘缓缁勪欢锛岃繖鏍锋垜浠氨鍙互鍦ㄥ疄渚嬪寲Vue鐨勪换浣曠粍浠讹紙鏂癡ue锛変腑浣跨敤瀹冦€傚叿浣撴柟娉?銆佹敞鍐岀粍浠禫ue.component('component-a',{/*...*/})Vue.component('component-b',{/*...*/})Vue.component('component-c',{/*...*/})newVue({el:'#app'})2.浣跨敤缁勪欢

杩欐牱鎴戜滑灏辨垚鍔熺殑鍒涘缓浜嗘敞鍐屽拰浣跨敤鐨勭粍浠讹紝骞朵笖鍦ㄥ垱寤虹殑鍐呴儴涔熷彲浠ヤ簰鐩镐娇鐢ㄤ簡鎴愬垎銆傞儴鍒嗘敞鍐屾垜浠彲浠ュ垱寤烘櫘閫氬璞″舰寮忕殑缁勪欢锛屽叾涓彲浠ュ寘鍚垜浠父鐢ㄧ殑鏁版嵁銆佹柟娉曚互鍙婂叾浠栧睘鎬у拰鏂规硶锛屾瘮濡備笅闈㈢殑varComponentA={/*...*/}varComponentB={/*鈥︹€?/}varComponentC={/*...*/}娉ㄥ唽鏈湴缁勪欢銆傛垜浠渶瑕佷娇鐢ㄧ粍浠舵潵娉ㄥ唽鎴戜滑瑕佷娇鐢ㄧ粍浠剁殑鍦版柟锛堝ぇ澶氭暟鎯呭喌涓嬩篃鏄粍浠讹級銆傚叿浣撲唬鐮佸涓媙ewVue({el:'#app',components:{'component-a':ComponentA,'component-b':ComponentB}})鍗曟枃浠剁粍浠跺湪鎴戜滑浣跨敤webpack鐨勬椂鍊欏彲鑳界敤鐨勬瘮杈冨鏋勫缓鎴戜滑鐨勯」鐩紙渚嬪锛歷ue-cli锛夛紝缂栧啓鐨勫崟鏂囦欢缁勪欢姣旇緝澶氾紝闇€瑕佸湪缁勪欢涓娇鐢ㄥ彟澶栦竴涓粍浠讹紝濡備笅鎴戦殢渚垮啓锛屾垜浠湪vue-cli3.0鐨勫熀纭€涓婂啓銆傞鍏堬紝鎴戜滑鎸夌収涓婇潰鐨勬柟寮忓垱寤轰竴涓粍浠?//components/Dialog/Dialog.vue.dialog-page{position:fixed;椤堕儴锛?锛涚寮€鍚細0锛涘搴︼細100vw锛涢珮搴︼細100vh锛涜儗鏅壊锛歳gba(0,0,0,0.6);z-鎸囨暟锛?9999锛?dialog-box{浣嶇疆锛氱粷瀵癸紱椤堕儴锛?0%锛涘乏锛?0%锛涜浆鎹細translateX(-50%)锛涗繚璇侀噾锛氳嚜鍔紱瀹藉害锛?00px锛涢珮搴︼細400px锛涘~鍏呴《閮細20px锛涜儗鏅壊锛?fff锛涜竟鐣屽崐寰勶細10px锛涙闃村奖锛?06px0#fff锛?title{鏂囨湰瀵归綈锛氬眳涓紱瀛椾綋澶у皬锛?2px锛涢鑹诧細#333锛泒.close{浣嶇疆锛氱粷瀵癸紱鍙筹細20px锛涢《閮細20px锛涙父鏍囷細鎸囬拡锛泒.confirm-btn{瀹藉害锛?0%锛涗綅缃細缁濆锛涘乏锛?0%锛涘簳閮細50px锛泒}}.fade-enter-active,.fade-leave-active{transition:opacity.2s;}.fade-enter,.fade-leave-to/*.fade-leave-activebelowversion2.1.8*/{opacity:0;}鐒跺悗鍦ˋpp.vue涓娇鐢?/App.vue濡傛灉姝ゆ椂杩愯椤圭洰锛岄〉闈細鏄繖鏍风殑锛堢‘璁ゆ寜閽垜鐢ㄧ殑鏄痚lementUI)鍏堝鍏ョ粍浠讹紝鐒跺悗浣跨敤components娉ㄥ唽缁勪欢锛屾渶鍚庝娇鐢ㄦā鏉夸腑鐨勭粍浠讹紝杩欐牱鎴戜滑灏遍『鍒╁畬鎴愪簡涓€涓粍浠剁殑鍒涘缓鍜屼娇鐢紝杩欎釜鏂规硶鏄垜鐩墠鐢ㄧ殑鏈€澶氱殑涓€绉嶏紝褰撶劧涔熷彲浠ユ弧瓒冲ぇ閮ㄥ垎鐨勯渶姹傦紝浣嗘槸鏈変簺鎯呭喌涓嬶紝杩欑涓滆タ鏄笉澶熺殑锛屾瘮濡備竴浜涘脊鍑烘鎴栬€呯敤浜庨€氱煡鐨勪氦浜掔粍浠讹紝骞虫椂鏄笉浼氭樉绀虹殑锛屽彧浼氭樉绀哄綋鏌愪簺鍔ㄤ綔琚Е鍙戞椂锛屽鏋滄垜浠粛鐒朵娇鐢ㄨ繖涓柟娉曠殑璇濓紝杩欑鎯呭喌涓嬶紝蹇呴』鍏堝紩鍏ョ粍浠讹紝鐒跺悗娉ㄥ唽锛屾渶鍚庡湪椤甸潰涓娇鐢紝鍚屾椂鎴戜滑杩橀渶瑕佹帶鍒剁粍浠舵槸鍚︽樉绀猴紝鏄惁娣诲姞寰堝鏃犵敤鐨勫彉閲忓拰浠g爜锛岄偅鎴戜滑鑳戒笉鑳界敤涓€涓洿绠€鍗曟柟渚跨殑鏂规硶鏉ュ垱寤虹粍浠跺憿锛熺瓟妗堟槸鑲畾鐨勶紝璇风户缁槄璇汇€傛柟娉曡皟鐢ㄥ垱寤虹敤杩噀lementUI銆乮view绛夌涓夋柟缁勪欢搴撶殑鍚屽鍙兘鐭ラ亾锛屼粬浠彁渚涗簡寰堝鍏ㄥ眬鐨凙PI鏉ユ柟渚跨粍浠剁殑鍒涘缓锛屾瘮濡傚脊鍑烘绛夛紝浠栦滑鏄€庝箞鍋氬埌鐨勶紝涓€璧锋潵鐪嬬湅鐪嬩笅闈€傛垜浠户缁啓涓婇潰鐨勫脊鍑烘缁勪欢銆傞鍏堬紝绋嶅井鏀瑰姩涓€涓嬪垰鍒氬啓濂界殑缁勪欢锛屽湪鍏朵腑娣诲姞涓€浜涗簨浠讹紙鍏抽棴鍜岀‘璁わ級///components/Dialog/Dialog.vue<鏍峰紡lang="scss"scoped>/*鍚屼笂锛屽お闀垮啓涓嶄笅*/...鏂板缓涓€涓枃浠?//components/Dialog/index.jsimportVuefrom'vue';importDialogfrom"@/components/Dialog/Dialog";letvm;constnoop=()=>{};functioncreateVNode(resolve=noop,reject=noop,props){returnnewVue({mixins:[{mounted(){鏂囨。.body.appendChild(this.$el);},beforeDestroy(){document.body.removeChild(this.$el);},}],beforeDestroy(){vm=null;},鏂规硶锛歿confirm(){resolve('鐐瑰嚮纭');this.$destroy();},close(){reject('鐐瑰嚮鍏抽棴');this.$destroy();}},render(createElement){returncreateElement(Dialog,{on:{confirm:this.confirm,close:this.close},閬撳叿锛岄鏍硷細{棰滆壊锛?绾㈣壊'}锛寎锛夛紱}})}functionshow(props){returnnewPromise((resolve,reject)=>{//濡傛灉鏈塿m瀹炰緥锛屽厛閿€姣佸畠if(vm){vm.$destroy();}vm=createVNode(resolve,reject,props);vm.$mount();})}exportdefaultshow;鍥炶繃澶存潵鐪嬶紝鎴戜滑瀵煎嚭浜嗕竴涓猻how鏂规硶锛屽畠杩斿洖涓€涓狿romise锛屼篃灏辨槸璇存垜浠皟鐢ㄨ繖涓柟娉曠殑鏃跺€欙紝鍙互浣跨敤.then璇硶鍦ㄤ互鍚庣殑鏌愪釜鏃堕棿鐐硅繘琛屼竴浜涙搷浣滐紙鍏抽棴寮规锛屾垨鑰呯偣鍑荤‘璁わ級銆傜劧鍚庢垜浠垱寤轰竴涓獀m瀹炰緥骞惰皟鐢?mount锛岃繖鐪嬭捣鏉ュ苟涓嶇啛鎮夛紝鏄殑锛屽湪main.js鏂囦欢涓?/main.js...newVue({...render:h=>h(App),}).$mount('#app');瀹冨皢ne鈥嬧€媤vue鐢熸垚鐨勮櫄鎷烡OM杞崲鎴愮湡瀹炵殑DOM鎸傝浇鍒?app涓娿€傞偅涔堟垜浠笂闈㈢殑$mount娌℃湁浼犲弬锛屼細鎸傝浇鍒板摢閲屽憿锛熷叾瀹炴垜浠渶瑕佹墜鍔ㄦ寕杞藉畠锛屾墍浠ョ粰瀹冧竴涓紶閫侀棬鍚с€傜劧鍚庢垜浠皥璁烘垜浠殑缁勪欢銆傝繖閲屾垜浠湅鍒板彟涓€涓猚reateVNode鏂规硶銆備笉鐢ㄨ锛岃繖鏄敤鏉ュ垱寤虹粍浠剁殑鏂规硶銆傚彲浠ョ湅鍒板畠杩斿洖浜嗕竴涓猇ue瀹炰緥鍖栧璞★紙铏氭嫙DOM锛夛紝newVue鐨勫弬鏁伴噷闈㈡贩鏉備簡涓€浜涚敓鍛藉懆鏈熷嚱鏁板拰涓や釜鏂规硶锛屽叾涓粍浠舵覆鏌撳悗鎵嬪姩灏嗗綋鍓嶆瀯閫犵殑DOM鎻掑叆鍒癰ody涓凡瀹屾垚锛屽苟鍦ㄧ粍浠惰閿€姣佷箣鍓嶅垹闄ゃ€傛渶閲嶈鐨勬槸涓嬮潰鐨剅ender鍑芥暟锛岄噷闈㈠唴瀹瑰緢澶氾紝灏变笉灞曞紑浜嗭紙鎴戣嚜宸变篃涓嶆槸寰堜簡瑙o紝鎵€浠ユ病娉曡В閲婐煠旓級锛屽鏋滀綘鎯充簡瑙f洿澶氾紝鍙互鐐逛紶閫侀棬锛屽彲浠ョ畝鍗曠悊瑙d负render鍙互鐢熸垚涓€涓猇Node锛屼篃灏辨槸铏氭嫙鑺傜偣銆傚畠鐨勭涓€涓弬鏁版槸鎴戜滑鍒氭墠鍐欑殑缁勪欢锛岀浜屼釜鍙傛暟鏄竴涓璞★紝鍙互瀹氫箟涓€浜涘弬鏁帮紝姣斿瑕佷紶閫掔粰缁勪欢鐨勫弬鏁帮紝鏍峰紡锛岃鐩戝惉鐨勪簨浠剁瓑銆傝繖鏍锋垜浠湪newVue鐨勬椂鍊欙紝涓嶅啀浣跨敤template鏂规硶锛岃€屾槸浣跨敤render鍑芥暟鐢熸垚鎴戜滑鎯宠鐨勭粍浠讹紝鎵嬪姩鎸傝浇鍒癉OM涓紙涓嶆槸鍦?app涓紝鏄苟鍒楀叧绯伙紝閮藉湪韬綋锛夈€傛帴涓嬫潵鎴戜滑鍙互鍦ㄩ渶瑕佺殑鍦版柟璋冪敤锛屾瘮濡侫pp.vue//App.vue褰撴寜閽鐐瑰嚮鏃讹紝鎴戜滑璋冪敤瀵煎叆鐨凞ialog鏂规硶骞朵紶閫掓爣棰樺弬鏁帮紝鐜板湪鎴戜滑鍙互鐪嬪埌鏁堟灉浜嗐€傜幇鍦ㄦ垜浠凡缁忓畬鎴愪簡缁勪欢鐨勫垱寤哄拰璋冪敤锛岀偣鍑诲叧闂‘璁ょ殑鏃跺€欏彲浠ョ湅鐪嬫帶鍒跺彴锛屾槸鍚﹀崟鐙墦鍗板嚭鏉ャ€傝繖灏辨槸鎴戜滑鍦ˋpp.vue涓皟鐢―ialog鏂规硶鐨勬椂鍊欙紝鍦╰hen涓墦鍗板苟catch锛岃繑鍥炲埌涓婇潰/components/Dialog/index.js鏂囦欢涓殑show鏂规硶锛屾垜浠繑鍥炰竴涓猵romise锛屾垜浠€氳繃resolve鍜宺eject鍙傛暟浼犲叆createVNode鏂规硶锛屽垎鍒笉瑕佸湪methods涓皟鐢╟onfirm鍜宑lose瀵瑰簲鐨勪袱涓柟娉曪紝鎵€浠onfirm鍜宑lose鏄浣曡Е鍙戠殑鍙互鍦?components/Dialog/Dialog.vue鏂囦欢涓湅鍒般€傚綋鎴戜滑鐐瑰嚮鐨勬椂鍊欙紝鎴戜滑浣跨敤$emit鏉ヨЕ鍙戝搴旂殑浜嬩欢锛岄偅涔堜簨浠舵槸浠庡摢閲屾帴鏀跺埌鐨勫憿锛熷洖鍒?components/Dialog/index.js鏂囦欢涓殑render鍑芥暟锛屾垜浠湪createElement鏂规硶鐨勭浜屼釜鍙傛暟涓湁涓€涓猳n瀵硅薄锛屾槸涓嶆槸鎰熻寰堢溂鐔燂紝娌¢敊锛屽氨鏄敤鏉ョ洃鍚簨浠剁殑锛屾垜浠笂闈㈠氨鐢ㄥ埌浜?emit瑙﹀彂鐨勪簨浠朵篃鍦ㄨ繖閲岀洃鎺с€傝繖鏍锋垜浠湪鐐瑰嚮confirm鎴栬€卌lose涔嬪悗锛屾墽琛宺esolve鎴栬€卹eject鏂规硶锛岀劧鍚庢垜浠氨鍙互鍦╰hen鍜宑atch涓繘琛岀浉搴旂殑鎿嶄綔浜嗐€傛敞鍐屽叏灞€鎻掍欢缁间笂鎵€杩帮紝鎴戜滑鍙互寰堟柟渚垮湴浠PI鐨勫舰寮忓垱寤虹粍浠讹紝浣嗗彲鑳芥湁浜轰細瑙夊緱涓嶅鏂逛究銆傛瘡娆¢兘瑕佸鍏ュ啀璋冪敤锛屾湁娌℃湁鏇存柟渚跨殑鏂规硶鍛紵涓€瀹氭湁锛岀幇鍦ㄦ垜浠瘯璇曠湅銆傚叾瀹炲緢绠€鍗曪紝绋嶅井鏀逛竴涓嬩唬鐮佸氨鍙互浜嗐€?//component/Dialog/index.js...-exportdefaultshow;+exportdefault{+install(vue){+vue.prototype.$Dialog=show;+}+}//main.js+importDialogfrom'@/components/Dialog/index'+Vue.use(Dialog);鐪嬪埌Vue.use鍙堟湁绉嶄技鏇剧浉璇嗙殑鎰熻锛屾垜浠钩鏃剁敤鐨勪笉灏辨槸鎻掍欢鍚楋紒娌¢敊锛岀涓夋柟鎻掍欢鍙互閫氳繃Vue.use鐨勫舰寮忔敞鍐岋紝鍥犱负浠栦滑鍦ㄦ彃浠朵腑閮藉鍑轰簡涓€涓猧nstall鏂规硶銆傚鏋滀綘涓嶇煡閬擄紝璇风湅杩欓噷Vue.use銆傝繖鏍锋垜浠氨鍙互鍦ㄩ渶瑕佺殑鍦版柟璋冪敤this.$Dialog浜嗭紝涓嶉渶瑕佸厛瀵煎叆锛屽洜涓烘柟娉曞凡缁廻ook鍒癡ue鍘熷瀷涓婁簡銆傜珛鍗冲皾璇?/App.vue鏁堟灉鍜屼箣鍓嶄竴鏍凤紝娌℃湁璐村浘銆傚ソ浜嗭紝鍒版涓烘锛屾槸涓嶆槸瑙夊緱鍜孍lementUI鎻愪緵鐨勪竴浜涙柟娉曟湁鐐圭浉浼煎憿锛熸槸鐨勶紝浠栦滑瀹為檯涓婁篃杩欐牱鍋氥€傜粨璇湰鏂囦富瑕佷粙缁嶅嚑绉嶅垱寤虹粍浠剁殑鏂规硶銆備娇鐢ㄥ摢涓€绉嶅彇鍐充簬鍏蜂綋鐨勪笟鍔″満鏅€備織璇濊锛屾病鏈夋渶濂界殑鎶€鏈柟妗堬紝鍙湁鏈€鍚堥€傜殑銆備絾姣曠珶锛屽鎺屾彙涓€鐐规€绘槸濂界殑銆備笅闈㈢殑鍐呭娑夊強鍒癡ue涓瘮杈冮毦鐨勫唴瀹癸紝濡俽ender銆乧reateElement銆?mount绛夛紝鍏跺疄杩欎簺涓滆タ鏇存帴杩戝簳灞傘€傞€氳繃瀛︿範杩欎簺锛屾垜浠彲浠ユ洿娣卞叆鍦扮悊瑙ue锛岃€屼笉鏄粎浠呭仠鐣欏湪鈥滀細鐢ㄢ€濈殑闃舵銆傚ソ浜嗭紝鍏堣鍒拌繖閲屽惂锛屽鏋滃枩娆㈡垨鑰呰寰楁湁鐢紝鍙互鐐硅禐+鏀惰棌锛屾湁閿欒娆㈣繋鎸囧嚭锛侊紒锛佹垜鍒氬垰鎵撳寘浜嗕竴涓猇ue鍥剧墖棰勮鎻掍欢锛坴ue-preview-imgs锛夛紝杩欎篃鏄垜鎵撳寘鐨勭涓€涓彃浠躲€傝繕瀛樺湪寰堝涓嶈冻銆傛杩庝氦娴侊紝鍠滄灏辩粰涓猻tar鍚э紒鍦板潃锛歨ttps://github.com/hzpeng57/v...