日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue 組件基礎知識總結

瀏覽:39日期:2022-10-08 14:17:29
組件基礎1 組件的復用

組件是可復用的Vue實例。

<!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><button-counter></button-counter><button-counter></button-counter><button-counter></button-counter></div> <script>// 定義一個名為 button-counter 的新組件Vue.component(’button-counter’, {data: function () {return {count: 0}},template: ’<button v-on:click='count++'>點擊了 {{ count }} 次.</button>’});new Vue({ el: ’#app’ }); </script> </body></html>

注意當點擊按鈕時,每個組件都會各自獨立維護它的count。這里自定義組件的data屬性必須是一個函數,每個實例維護一份被返回對象的獨立的拷貝。

<!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><button-counter></button-counter><button-counter></button-counter><button-counter></button-counter></div> <script>var buttonCounterData = {count: 0}// 定義一個名為 button-counter 的新組件Vue.component(’button-counter’, {data: function () {return buttonCounterData},template: ’<button v-on:click='count++'>點擊了 {{ count }} 次.</button>’});new Vue({ el: ’#app’ }); </script> </body></html>2 通過 Prop 向子組件傳遞數據

<!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><blog-post></blog-post><blog-post></blog-post><blog-post></blog-post></div> <script>Vue.component(’blog-post’, {props: [’title’],template: ’<h3>{{ title }}</h3>’})new Vue({ el: ’#app’ }); </script> </body></html>

這里<blog-post>組件就是通過自定義屬性title來傳遞數據。我們可以使用v-bind來動態傳遞prop。

<!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><blog-post v-for='post in posts' v-bind:key='post.id' v-bind:title='post.title'></blog-post></div> <script>Vue.component(’blog-post’, {props: [’title’],template: ’<h3>{{ title }}</h3>’})new Vue({el: ’#app’,data: {posts: [{ id: 1, title: ’My journey with Vue’ },{ id: 2, title: ’Blogging with Vue’ },{ id: 3, title: ’Why Vue is so fun’ }]}}); </script> </body></html>3 單個根元素

每個組件必須只有一個根元素。

<!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><blog-post v-for='post in posts' v-bind:key='post.id' v-bind:post='post'></blog-post></div> <script>Vue.component(’blog-post’, {props: [’post’],template: `<div class='blog-post'><h3>{{ post.title }}</h3><div v-html='post.content'></div></div>`})new Vue({el: ’#app’,data: {posts: [{ id: 1, title: ’My journey with Vue’, content: ’my journey...’ },{ id: 2, title: ’Blogging with Vue’, content: ’my blog...’ },{ id: 3, title: ’Why Vue is so fun’, content: ’Vue is so fun...’ }]}}); </script> </body></html>

注意到v-bind:post='post'綁定的post是一個對象,這樣可以避免了需要通過很多prop傳遞數據的麻煩。

4 監聽子組件事件

<!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><div :style='{fontSize: postFontSize + ’em’}'><blog-post v-for='post in posts' v-bind:key='post.id' v-bind:post='post'v-on:enlarge-text='postFontSize += 0.1' /></div></div> <script>Vue.component(’blog-post’, {props: [’post’],template: `<div class='blog-post'><h3>{{ post.title }}</h3><button v-on:click='$emit(’enlarge-text’)'>放大字體</button><div v-html='post.content'></div></div>`})new Vue({el: ’#app’,data: {postFontSize: 1,posts: [{ id: 1, title: ’My journey with Vue’, content: ’my journey...’ },{ id: 2, title: ’Blogging with Vue’, content: ’my blog...’ },{ id: 3, title: ’Why Vue is so fun’, content: ’Vue is so fun...’ }]}}); </script> </body></html>

子組件通過$emit方法并傳入事件名稱來觸發一個事件。父組件可以接收該事件。

我們可以使用事件拋出一個值。

<!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><div :style='{fontSize: postFontSize + ’em’}'><blog-post v-for='post in posts' v-bind:key='post.id' v-bind:post='post'v-on:enlarge-text='postFontSize += $event' /></div></div> <script>Vue.component(’blog-post’, {props: [’post’],template: `<div class='blog-post'><h3>{{ post.title }}</h3><button v-on:click='$emit(’enlarge-text’, 0.2)'>放大字體</button><div v-html='post.content'></div></div>`})new Vue({el: ’#app’,data: {postFontSize: 1,posts: [{ id: 1, title: ’My journey with Vue’, content: ’my journey...’ },{ id: 2, title: ’Blogging with Vue’, content: ’my blog...’ },{ id: 3, title: ’Why Vue is so fun’, content: ’Vue is so fun...’ }]}}); </script> </body></html>

在父組件中,我們可以通過$event訪問到被拋出的這個值。我們可以在組件上使用v-model。

<!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><!-- <input v-model='searchText'> --><input v-bind:value='searchText' v-on:input='searchText = $event.target.value'><p>{{ searchText }}</p></div> <script>new Vue({el: ’#app’,data: {searchText: ’’}}); </script> </body></html><!DOCTYPE html><html> <head> <meta charset='utf-8'> <style> </style> <script src='https://cdn.staticfile.org/vue/2.4.2/vue.min.js'></script> </head> <body><div id='app'><custom-input v-model='searchText'></custom-input><custom-input v-bind:value='searchText' v-on:input='searchText = $event'></custom-input><p>{{ searchText }}</p></div> <script>Vue.component(’custom-input’, {props: [’value’],template: `<input v-bind:value='value' v-on:input='$emit(’input’, $event.target.value)' >`})new Vue({el: ’#app’,data: {searchText: ’’}}); </script> </body></html>

最后,注意解析 DOM 模板時的注意事項。

以上就是vue 組件基礎知識總結的詳細內容,更多關于vue 組件的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
激情欧美一区二区三区| 国产精品大片免费观看| 国产高潮在线| 欧美日本不卡| 青草久久视频| 亚洲天堂日韩在线| 日韩毛片网站| 国产精品一级| 国内精品麻豆美女在线播放视频| 国产成人精品一区二区免费看京| 亚洲最新无码中文字幕久久 | 日韩精品永久网址| 亚洲涩涩在线| 欧美福利一区| 蜜臀av在线播放一区二区三区 | 国产精品第一国产精品| 老司机精品视频网| 国产乱码午夜在线视频| 99精品在线观看| 亚洲午夜黄色| 亚洲精品乱码| 欧美国产日本| 久久精品91| 丝袜a∨在线一区二区三区不卡| 欧美一区不卡| 捆绑调教日本一区二区三区| 伊人久久大香线蕉av超碰演员| 亚洲欧美网站在线观看| 欧美性www| 欧美男人天堂| 日韩中文字幕1| 久久a爱视频| 99久久精品费精品国产| 蜜桃视频免费观看一区| 欧美中文一区| 亚洲播播91| 亚洲区第一页| 捆绑调教日本一区二区三区| 久久国产88| 精品国产一区二区三区性色av| 亚洲午夜电影| 国产精品传媒麻豆hd| 1000部精品久久久久久久久| 日韩欧美四区| 欧美日韩视频网站| 四虎精品一区二区免费| 精品三级av| 欧美日韩国产一区精品一区| 国产精品久久久一区二区| 国产高清一区| 国产精品久久| 日韩视频在线一区二区三区 | 在线亚洲观看| 国产毛片精品| 免费国产自久久久久三四区久久| 日韩欧美在线精品| 久久国产日韩| 国产欧美88| 亚洲激情社区| 欧美黑人做爰爽爽爽| 国产精品美女| 国产成人免费精品| 在线精品亚洲| 91精品亚洲| 国产精品扒开腿做爽爽爽软件| 欧美二区视频| 国产精品久久乐| 蜜桃视频一区二区| 日韩中文在线电影| 欧美日韩午夜电影网| aa国产精品| 视频在线不卡免费观看| 亚洲2区在线| 欧美亚洲激情| 精品国产亚洲日本| 日韩动漫一区| 水蜜桃久久夜色精品一区的特点 | 日韩一区二区三区精品| 日韩av在线免费观看不卡| 欧美日韩激情| 精品亚洲自拍| 日韩精品高清不卡| 亚洲免费在线| 99精品综合| 久久久久久久久成人| 亚洲精品亚洲人成在线观看| 久久精品影视| a天堂资源在线| 精品亚洲免a| 国产精品麻豆成人av电影艾秋| 综合视频一区| 老司机精品久久| 五月天综合网站| 91视频一区| 久久中文欧美| 国产精品第十页| 日本特黄久久久高潮| 美美哒免费高清在线观看视频一区二区| 香蕉视频亚洲一级| 久久男人av资源站| 国产一区二区三区黄网站| 国产精品亚洲综合久久| 欧美在线观看天堂一区二区三区| 亚洲精一区二区三区| 亚洲欧美日韩综合国产aⅴ| 91精品观看| 欧美午夜不卡影院在线观看完整版免费| 久久九九99| 日韩欧美1区| 国产欧洲在线| 国产精品yjizz视频网| 在线看片国产福利你懂的| 99视频+国产日韩欧美| 99热精品在线| 日韩亚洲国产欧美| 国产农村妇女精品一二区| 9国产精品视频| 伊人精品在线| 久久性天堂网| 日韩中文字幕在线一区| 日韩福利在线观看| 国产九九精品| 麻豆国产精品777777在线| 欧美激情综合| 国产精品99一区二区三| 97国产精品| 天堂资源在线亚洲| 在线一区电影| 视频一区视频二区中文字幕| 亚洲精品伊人| 国产探花一区二区| 久久精品国产免费| sm久久捆绑调教精品一区| 欧美日韩水蜜桃| 国产午夜精品一区二区三区欧美| 视频一区欧美日韩| 日本午夜精品一区二区三区电影| 国产精品xxx在线观看| 国产+成+人+亚洲欧洲在线| 色老板在线视频一区二区| 五月天久久网站| 免费人成在线不卡| 国产免费av一区二区三区| 欧美好骚综合网| 欧美日韩国产一区精品一区| 日韩精品一二三区| 欧美日韩一区自拍| 色一区二区三区| 国产在线欧美| 亚洲精品九九| 欧美精品aa| 四虎4545www国产精品 | 亚洲成人精品| 中文视频一区| 欧美国产中文高清| 99精品国产一区二区三区| 亚洲精品观看| 国产成人精品一区二区三区视频| 激情婷婷亚洲| 欧美三区不卡| 色老板在线视频一区二区| 日韩在线一区二区| 久久久久亚洲精品中文字幕| 91精品国产乱码久久久久久久 | 69堂精品视频在线播放| 国产福利91精品一区二区| 黄色av日韩| 国产精品国码视频| 欧美成人综合| 国产欧美日韩精品一区二区免费| 日韩免费在线| 日韩欧美中文字幕在线视频| 色婷婷色综合| 三级在线观看一区二区| 老司机精品视频在线播放| 亚洲精品一区二区在线看| 国产亚洲一区二区三区不卡| 日韩另类视频| 欧美日韩夜夜| 久久在线视频免费观看| 青草久久视频| 欧美 日韩 国产一区二区在线视频| 91精品国产经典在线观看| 久久视频国产| 国产精品久久久久av蜜臀| 99在线|亚洲一区二区| 精品国产一区二区三区2021| 亚洲激情av| 国产一区二区三区视频在线| 视频一区视频二区在线观看| 福利一区二区| 日韩欧美在线精品| 今天的高清视频免费播放成人| 国产精品一区二区精品视频观看 | 亚洲精品中文字幕乱码| 国产精品久久久久毛片大屁完整版| 成人av二区| 高清av一区| 欧美日韩一区二区国产| 国产亚洲午夜|