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

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

vue 組件基礎知識總結

瀏覽:41日期: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久久,三上悠亚国产精品一区二区三区
亚洲欧美日韩在线观看a三区 | 日韩av中文字幕一区二区| 在线综合欧美| 亚洲精品国产偷自在线观看| 国产一区日韩一区| 欧美成人国产| 中文字幕高清在线播放| 中文字幕在线免费观看视频| 极品av在线| 99久久99视频只有精品| 欧美日韩国产传媒| 蜜桃久久av| 日韩中文av| 噜噜噜躁狠狠躁狠狠精品视频| 天堂av在线| 久久免费精品| 欧美成人a交片免费看| 7777精品| 激情视频一区二区三区| 九九久久电影| 爽好久久久欧美精品| 免费精品国产| 蜜桃视频一区二区三区| 日本一不卡视频| 国产欧美一区二区三区米奇 | 日韩天堂av| 蜜桃一区二区三区在线| 国产美女久久| 精品一区二区三区免费看| 日韩伦理一区| 欧美在线资源| 日韩影片在线观看| 欧美黄色一区二区| 精品99在线| 亚洲无线一线二线三线区别av| 激情久久久久久久| 日本午夜精品| а√在线中文在线新版| 欧美日韩国产探花| 9久re热视频在线精品| 欧美日韩水蜜桃| 97久久精品| 欧美日韩国产高清电影| 国产乱子精品一区二区在线观看| 国产不卡人人| 日本在线成人| 亚洲欧洲专区| 日韩av一区二区三区| 亚洲日韩视频| 久久精品福利| 精品免费视频| 亚洲美洲欧洲综合国产一区| 啪啪亚洲精品| 天堂日韩电影| 7777精品| 欧美一区二区三区高清视频| 免费一区二区视频| 国产在线日韩精品| 日韩中文字幕亚洲一区二区va在线| 日韩一区免费| 伊人久久av| 日韩精品一区二区三区中文| 三上亚洲一区二区| 蜜臀av在线播放一区二区三区| 欧美国产一级| 美女黄网久久| 国产色综合网| 日韩精品网站| 7m精品国产导航在线| 国产伊人精品| 你懂的亚洲视频| 亚洲一区中文| 久久99青青| 日韩一区二区三区精品| 日韩精品欧美| 国产精品17p| 老牛影视一区二区三区| yellow在线观看网址| 久久精品超碰| 麻豆亚洲精品| 精品99在线| 欧美一级网站| 欧美综合二区| 久久天堂精品| 精品国产三区在线| 日本va欧美va欧美va精品| 91成人网在线观看| 国产精品毛片一区二区在线看| 日韩高清一区| 视频一区二区三区中文字幕| 欧美特黄一级大片| 日本免费久久| 狠狠久久伊人| 国产精品亚洲综合久久| 蜜臀久久99精品久久久久宅男| 国产精品精品| 国产精品探花在线观看| 亚洲精品在线a| 日韩亚洲在线| 亲子伦视频一区二区三区| 精品一区二区三区中文字幕| 91欧美极品| 亚洲人www| 亚洲欧美视频一区二区三区| 久久精品国产99久久| 久久男人av资源站| 国产精品毛片久久| 久久这里只有| 老色鬼精品视频在线观看播放| 国产调教精品| 亚洲精品在线二区| 蜜臀av亚洲一区中文字幕| 9国产精品视频| 亚洲免费播放| 99成人在线| 国产偷自视频区视频一区二区| 激情婷婷综合| 在线综合视频| 日韩精品一级二级| 丝袜脚交一区二区| 亚洲综合不卡| 亚洲欧美日韩国产| 国产视频亚洲| 一区二区三区午夜视频| 亚洲精品系列| 亚洲欧美日韩视频二区| 在线日韩成人| 亚洲精品美女| 国产探花一区| 国产精品久久久久77777丨| 国产精品久久久久久久久免费高清| 国产精品亚洲一区二区在线观看| 国产高清亚洲| 麻豆mv在线观看| 日韩精品水蜜桃| 亚洲欧美一区在线| 国产精品社区| 亚洲三级视频| 7m精品国产导航在线| 国产精品v亚洲精品v日韩精品| 亚洲香蕉视频| 欧美中文高清| 欧美aa在线视频| 成人片免费看| 国产高清一区| 蜜臀久久99精品久久久久久9 | 国产欧美综合一区二区三区| 久久av超碰| 亚洲伊人av| 9国产精品视频| 欧美在线黄色| а√天堂8资源中文在线| 亚洲第一精品影视| 亚洲国产专区校园欧美| 蜜臀av亚洲一区中文字幕| 日韩精品国产精品| 你懂的亚洲视频| 亚洲色图网站| 亚洲啊v在线| 日韩精品免费一区二区三区| 亚洲精品一区二区妖精| 免费观看在线综合| 国产精品久久免费视频| 日韩一区二区三区免费播放| 99国产精品视频免费观看一公开| 日韩一区中文| 成人国产精品一区二区免费麻豆| 久久精选视频| 好吊视频一区二区三区四区| 日韩高清欧美激情| 日韩伦理一区| 午夜久久av| 国产美女高潮在线观看| 免费观看日韩电影| 日韩综合在线| 亚洲资源网站| 成人国产精品久久| 蜜臀av性久久久久蜜臀aⅴ流畅| 麻豆视频一区| 在线一区欧美| 精品久久中文| 亚洲图片久久| 伊人久久国产| 免费高清在线一区| 精品国产99| 中文字幕中文字幕精品| 色爱综合网欧美| 亚洲精品欧洲| 免费污视频在线一区| **爰片久久毛片| 欧美特黄视频| 精品国产乱码久久久久久樱花| 欧美精品一区二区久久| 国产精品久久久久77777丨| 99成人在线| 波多野结衣久久精品| 日本伊人午夜精品| 国产精品nxnn| 热久久久久久久| 久久www成人_看片免费不卡|