精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

用Jsx寫Vue組件

開發(fā) 前端
下面我們要講的是如何在vue里面寫jsx,知道react的人應(yīng)該都知道jsx,jsx的一個特性就是非常靈活,雖然有的人覺得jsx很丑陋,把邏輯都寫到模版的感覺,但蘿卜青菜各有所愛,適合自己適合團隊的就是最好的。

 

前言

我們平常寫vue的組件時,一般都是用的是模版,這種方式看起來比較簡潔,而且vue作者也推薦使用這個方式,但是這種方式也有一些它的弊端,例如模版調(diào)試麻煩,或者在一些場景下模版描述可能沒那么簡單和方便。

下面我們要講的是如何在vue里面寫jsx,知道react的人應(yīng)該都知道jsx,jsx的一個特性就是非常靈活,雖然有的人覺得jsx很丑陋,把邏輯都寫到模版的感覺,但蘿卜青菜各有所愛,適合自己適合團隊的就是***的。

在使用jsx之前我們需要安裝一個babel插件(babel-plugin-transform-vue-jsx )

安裝方式:

  1. npm install\ 
  2.  
  3.   babel-plugin-syntax-jsx\ 
  4.  
  5.   babel-plugin-transform-vue-jsx\ 
  6.  
  7.   babel-helper-vue-jsx-merge-props\ 
  8.  
  9.   babel-preset-es2015\ 
  10.  
  11.   --save-dev  

然后再.babelrc里面添加:

  1.  
  2. "presets": ["es2015"], 
  3.  
  4. "plugins": ["transform-vue-jsx"
  5.  
  6.  

接著我們就可以愉快地在vue里面編寫jsx了。

Test.vue

  1. <script> 
  2.  
  3. export default { 
  4.  
  5.     props: ['onClick''isShow'], 
  6.  
  7.     data() { 
  8.  
  9.         return { 
  10.  
  11.             test: 123 
  12.  
  13.         }; 
  14.  
  15.     }, 
  16.  
  17.     render() { 
  18.  
  19.         return ( 
  20.  
  21.             <div class="test" onClick={ this.onClick }> 
  22.  
  23.                 { this.test } 
  24.  
  25.                 { this.isShow + '' } 
  26.  
  27.             </div> 
  28.  
  29.         ); 
  30.  
  31.     } 
  32.  
  33.  
  34. </script>  

可以看到我們把jsx寫在了render方法里面,render方法是vue2.0才支持的,用來提供對虛擬DOM的支持,也就是說只有vue2.0才支持jsx語法轉(zhuǎn)換。

這里要注意的一點是vue里面編寫jsx和在react里面的jsx語法還是有一點不一樣的。

一下是一段覆蓋大部分語法的vue jsx代碼:

  1. render (h) { 
  2.  
  3.   return ( 
  4.  
  5.     <div 
  6.  
  7.       // normal attributes or component props. 
  8.  
  9.       id="foo" 
  10.  
  11.       // DOM properties are prefixed with `domProps` 
  12.  
  13.       domPropsInnerHTML="bar" 
  14.  
  15.       // event listeners are prefixed with `onor `nativeOn` 
  16.  
  17.       onClick={this.clickHandler} 
  18.  
  19.       nativeOnClick={this.nativeClickHandler} 
  20.  
  21.       // other special top-level properties 
  22.  
  23.       class={{ foo: true, bar: false }} 
  24.  
  25.       style={{ color: 'red', fontSize: '14px' }} 
  26.  
  27.       key="key" 
  28.  
  29.       ref="ref" 
  30.  
  31.       // assign the `ref` is used on elements/components with v-for 
  32.  
  33.       refInFor 
  34.  
  35.       slot="slot"
  36.  
  37.     </div> 
  38.  
  39.   ) 
  40.  
  41.  

可以看到DOM屬性要加domProps前綴,但這里lass和style卻不需要,因為這兩個是特殊的模塊,而且react的class用的是className,vue卻用的class。事件監(jiān)聽是以“on”或者“nativeOn”為開始。

實際上vue2.0的模版***都會被編譯為render方法,所以模版聲明的組件和jsx聲明的組件***都是一樣的。

上面的jsx***會被編譯成下面這樣:

  1. render (h) { 
  2.  
  3.   return h('div', { 
  4.  
  5.     // Component props 
  6.  
  7.     props: { 
  8.  
  9.       msg: 'hi' 
  10.  
  11.     }, 
  12.  
  13.     // normal HTML attributes 
  14.  
  15.     attrs: { 
  16.  
  17.       id: 'foo' 
  18.  
  19.     }, 
  20.  
  21.     // DOM props 
  22.  
  23.     domProps: { 
  24.  
  25.       innerHTML: 'bar' 
  26.  
  27.     }, 
  28.  
  29.     // Event handlers are nested under "on", though 
  30.  
  31.     // modifiers such as in v-on:keyup.enter are not 
  32.  
  33.     // supported. You'll have to manually check the 
  34.  
  35.     // keyCode in the handler instead
  36.  
  37.     on: { 
  38.  
  39.       click: this.clickHandler 
  40.  
  41.     }, 
  42.  
  43.     // For components only. Allows you to listen to 
  44.  
  45.     // native events, rather than events emitted from 
  46.  
  47.     // the component using vm.$emit. 
  48.  
  49.     nativeOn: { 
  50.  
  51.       click: this.nativeClickHandler 
  52.  
  53.     }, 
  54.  
  55.     // class is a special module, same API as `v-bind:class` 
  56.  
  57.     class: { 
  58.  
  59.       foo: true
  60.  
  61.       bar: false 
  62.  
  63.     }, 
  64.  
  65.     // style is also same as `v-bind:style` 
  66.  
  67.     style: { 
  68.  
  69.       color: 'red'
  70.  
  71.       fontSize: '14px' 
  72.  
  73.     }, 
  74.  
  75.     // other special top-level properties 
  76.  
  77.     key'key'
  78.  
  79.     ref: 'ref'
  80.  
  81.     // assign the `ref` is used on elements/components with v-for 
  82.  
  83.     refInFor: true
  84.  
  85.     slot: 'slot' 
  86.  
  87.   }) 
  88.  
  89.  

這也意味著兩種形式的組件是可以相互引用的。

有時候我們難免會在模版里引入jsx編寫的vue組件或者在jsx編寫的vue組件里引入模版組件,這里還是有些需要注意的事項:

1.在模版里面引入jsx的組件,可以通過components引用,另外props的編寫從駝峰式改為連接符:

  1. <template> 
  2.  
  3.   <div class="wrapper"
  4.  
  5.     <Test :on-click="clickHandler" :is-show="show"></Test> 
  6.  
  7.   </div> 
  8.  
  9. </template> 
  10.  
  11. <script> 
  12.  
  13. import Test from './Test.vue'
  14.  
  15. export default { 
  16.  
  17.   name'hello'
  18.  
  19.   components: { 
  20.  
  21.     Test 
  22.  
  23.   }, 
  24.  
  25.   data() { 
  26.  
  27.     return { 
  28.  
  29.       msg: 'Welcome to Your Vue.js App'
  30.  
  31.       show: true 
  32.  
  33.     }; 
  34.  
  35.   }, 
  36.  
  37.   methods: { 
  38.  
  39.     clickHandler(){ 
  40.  
  41.       this.show = !this.show; 
  42.  
  43.     } 
  44.  
  45.   } 
  46.  
  47. }; 
  48.  
  49. </script>  

2.在jsx里面引入vue模版組件,這里沒有什么要注意的,除了連接符式的屬性要轉(zhuǎn)換成駝峰式,還有一個需要注意的是指令,如果用了jsx,那么內(nèi)置的指令都不會生效(除了v-show),好在內(nèi)置指令大部分都可以用jsx描述。那么自定義指令要怎么用呢?

自定義指令可以使用“v-name={value}”語法,如果要支持指令參數(shù)和modifier可以用“v-name={{ value, modifier: true }}”語法:

  1. <script> 
  2.  
  3. import Vue from 'vue'
  4.  
  5. Vue.directive('my-bold', { 
  6.  
  7.   inserted: function (el) { 
  8.  
  9.     el.style.fontWeight = 900; 
  10.  
  11.   } 
  12.  
  13. }) 
  14.  
  15. export default { 
  16.  
  17.     props: ['onClick''isShow'], 
  18.  
  19.     data() { 
  20.  
  21.         return { 
  22.  
  23.             test: 123 
  24.  
  25.         }; 
  26.  
  27.     }, 
  28.  
  29.     methods: { 
  30.  
  31.         afterLeave() { 
  32.  
  33.             console.log('afterLeave'
  34.  
  35.         } 
  36.  
  37.     }, 
  38.  
  39.     render() { 
  40.  
  41.         const directives = [ 
  42.  
  43.             { name'my-bold', value: 666, modifiers: { abc: true } } 
  44.  
  45.         ]; 
  46.  
  47.         return ( 
  48.  
  49.             <transition onAfterLeave={this.afterLeave} name="fade"
  50.  
  51.                 <div class="test" onClick={this.onClick} v-show={ this.isShow } v-my-bold> 
  52.  
  53.                     {this.test} 
  54.  
  55.                     {this.isShow + ''
  56.  
  57.                 </div> 
  58.  
  59.             </transition> 
  60.  
  61.         ); 
  62.  
  63.     } 
  64.  
  65.  
  66. </script> 
  67.  
  68. <style> 
  69.  
  70. .fade-enter-active, .fade-leave-active { 
  71.  
  72.   transition: opacity .5s 
  73.  
  74.  
  75. .fade-enter, .fade-leave-to { 
  76.  
  77.   opacity: 0 
  78.  
  79.  
  80. </style>  

我們還可以用原生vnode的數(shù)據(jù)格式使用自定義指令:

  1. const directives = [ 
  2.  
  3. name'my-dir', value: 123, modifiers: { abc: true } } 
  4.  
  5.  
  6. return <div {...{ directives }}/>  

擴展

如果有人覺得在vue組件里面要寫data,props,computed和methods不夠優(yōu)雅,可以參考下這個插件vue-class-component,它能讓你使用ES6的class和ES7的裝飾器編寫vue組件。

相關(guān)鏈接

babel-plugin-transform-vue-jsx(https://github.com/vuejs/babel-plugin-transform-vue-jsxhttps://github.com/vuejs/babel-plugin-transform-vue-jsx) 

責任編輯:龐桂玉 來源: 前端大全
相關(guān)推薦

2024-02-02 08:33:00

Vue模板性能

2022-11-01 11:55:27

ReactVue3

2024-01-11 10:22:20

AI代碼生成工具前端

2020-02-10 10:23:03

VueJSX前端

2023-03-30 11:50:34

2023-04-18 09:17:40

父子組件Vue

2021-07-19 10:32:17

Vue倒計時組件前端

2025-10-28 01:55:00

2022-02-08 15:55:00

Vue組件庫Vue Demi

2024-09-05 08:50:11

2023-08-07 08:52:53

Vue組件Props 命名

2022-12-19 08:17:36

ReactReconciler

2023-07-25 14:24:33

元素JSX解析器

2017-08-07 16:39:03

JSX動態(tài)數(shù)據(jù)

2024-01-09 08:34:56

Vue3.js組件通信

2024-04-16 12:05:27

Vue3前端

2019-05-05 11:02:07

vscodevue前端

2024-07-10 10:38:58

Vue組件函數(shù)

2018-04-16 14:39:10

Vue輪播切換

2022-08-09 11:46:58

Vue遞歸組件
點贊
收藏

51CTO技術(shù)棧公眾號

免费av网站在线播放| wwwav国产| 成人在线视频观看| 成人欧美一区二区三区黑人麻豆| 电影午夜精品一区二区三区| 中文字幕在线播| 91精品国产乱码久久久久久久| 亚洲成**性毛茸茸| 天天爱天天操天天干| 亚洲www色| 国产免费成人在线视频| 成人免费看片网址| 亚洲天堂狠狠干| 一本不卡影院| 美日韩精品视频免费看| 在线免费观看视频| caoporn成人免费视频在线| 91官网在线免费观看| 国产天堂视频在线观看| 日本中文字幕视频在线| 久久午夜羞羞影院免费观看| 91亚洲国产成人久久精品网站 | 三级视频网站在线| 国产精品综合一区二区| 国产精品亚洲一区二区三区| 久久久久久久黄色片| 欧美一区视频| 日韩中文字幕国产| 无码人妻aⅴ一区二区三区69岛| 黄色欧美网站| 日韩欧美国产系列| 亚洲天堂国产视频| 天然素人一区二区视频| 狠狠综合久久av一区二区小说| 做爰高潮hd色即是空| seseavlu视频在线| 国产亚洲自拍一区| 牛人盗摄一区二区三区视频| 婷婷五月综合久久中文字幕| 极品少妇xxxx精品少妇偷拍| 国产精品视频自在线| 岛国av中文字幕| 国产日韩欧美在线播放不卡| 午夜精品久久久久久久99黑人| 亚洲av无码一区二区三区在线| 久久精品国产99久久| 中文字幕少妇一区二区三区| 日本高清黄色片| 日韩一区二区三区免费播放| 在线视频欧美性高潮| 国产精品理论在线| 色综合天天爱| 久久久av一区| 国产性xxxx| 国产精品二区影院| 国模吧一区二区| 免费看日韩毛片| 国产精品婷婷| 国产精品成人va在线观看| 日韩欧美在线观看免费| 日韩 欧美一区二区三区| 国产精品国产自产拍高清av水多| 午夜一级黄色片| 奇米四色…亚洲| 成人亲热视频网站| 精品欧美在线观看| av色综合久久天堂av综合| 狠狠久久综合婷婷不卡| 日韩精品视频无播放器在线看 | 日韩的一区二区| 人妻精品久久久久中文字幕| 激情综合网站| 久久资源免费视频| 久久久久久久伊人| 久久九九免费| 成人乱色短篇合集| 国产小视频免费观看| www日韩大片| 午夜精品区一区二区三| 在线免费观看的av| 精品久久久久久中文字幕一区奶水| 成人在线看视频| 国产91欧美| 亚洲成av人片在线观看香蕉| 久久精品国产亚洲AV熟女| 日韩精品午夜| 欧美激情区在线播放| 免费黄色网址在线| 久草精品在线观看| 精品国产一区二区三| 在线观看av黄网站永久| 亚洲午夜免费电影| 国产真人无码作爱视频免费| 玖玖精品一区| 亚洲跨种族黑人xxx| 91av手机在线| 亚洲欧洲一区| 国产日韩精品视频| 手机看片一区二区| 最新成人av在线| 免费看又黄又无码的网站| 亚洲精品成a人ⅴ香蕉片| 亚洲成人黄色在线| 亚洲av无一区二区三区| 一本色道久久综合亚洲精品不| 国产精品成人免费电影| 国产综合视频在线| 国产精品三级av| 精品视频免费在线播放| 国产精品一区二区美女视频免费看| 日韩av网站大全| 激情综合网五月天| 秋霞av亚洲一区二区三| 精品国产乱码久久久久久88av| 国产写真视频在线观看| 色综合视频在线观看| 好吊操视频这里只有精品| 成人国产精品一级毛片视频| 国内精品久久久久久中文字幕| 一本色道久久综合亚洲| 久久女同精品一区二区| 免费看毛片的网址| 国产精品1区在线| 在线精品高清中文字幕| 久久夜色精品亚洲| 国产a视频精品免费观看| 亚洲精美视频| 亚洲爱爱视频| 亚洲精选一区二区| 日本一区二区不卡在线| 国产精品888| 熟女视频一区二区三区| 国产精品久久久久久吹潮| 亚洲欧美国产精品专区久久 | 亚洲麻豆视频| 成人永久免费| 性爱视频在线播放| 91麻豆精品国产91久久久久久久久 | 99视频在线视频| 亚洲日本三级| 欧美一级电影在线| 女人天堂在线| 色综合久久久久综合| 蜜桃精品成人影片| 午夜亚洲精品| 欧美在线一二三区| 欧美日韩国产v| 国产一区二区三区18| 天天干,天天干| 国产香蕉久久精品综合网| 91猫先生在线| 免费欧美视频| 国产va免费精品高清在线观看| 日本v片在线免费观看| 色视频一区二区| av男人的天堂av| 日本中文一区二区三区| 亚洲人久久久| 精品国产第一国产综合精品| 色综合天天狠天天透天天伊人| 亚洲精品国产一区二| 午夜精品久久久久| 最近中文字幕无免费| 鲁大师影院一区二区三区| 欧美一区二区三区电影在线观看| 日本精品在线一区| 久久久av免费| 人妻va精品va欧美va| 欧美视频中文在线看| 国产传媒国产传媒| 韩国精品在线观看| 久青草视频在线播放| 日韩高清电影免费| 国产精品国产三级国产aⅴ9色| 免费在线观看av网站| 日韩精品一区二区三区视频| 日韩男人的天堂| 久久久久99精品国产片| 午夜剧场在线免费观看| 午夜精品电影| 欧美精品亚洲精品| 91精品国产一区二区在线观看| 操日韩av在线电影| 日韩精品视频无播放器在线看| 精品婷婷伊人一区三区三| 深夜福利影院在线观看| 久久综合九色综合97_久久久| 污污网站免费观看| 99精品国产在热久久婷婷| 亚洲精品成人自拍| 久久午夜影院| 成人国产精品av| 少妇视频一区| 久久综合电影一区| 久久久pmvav| 日韩一区二区三区高清免费看看| 国产精品第9页| 亚洲同性gay激情无套| 成年人网站免费看| 国产一区二区在线观看视频| 国内自拍在线观看| 91精品天堂福利在线观看| 免费在线一区二区| 亚洲性视频在线| 国产欧美韩国高清| 色尼玛亚洲综合影院| 九九热这里只有在线精品视| 国产精品秘入口| 欧美精品一区男女天堂| 91激情在线观看| 一本大道久久a久久综合婷婷 | 日韩欧美国产网站| 一区视频免费观看| 国产精品视频一二三| 国产精品无码一区二区三| 国产精品一区二区三区网站| 国产自偷自偷免费一区 | 日本一区二区三区四区视频| 日韩伦理av| 日韩视频中文字幕| 国产露出视频在线观看| 亚洲精品久久久一区二区三区| 国产肥老妇视频| 欧美日韩成人综合天天影院| 国产性生活视频| 欧美日韩国产中文精品字幕自在自线| 欧美精品久久久久性色| 亚洲女与黑人做爰| 三级黄色录像视频| 中文字幕一区二区三中文字幕| 成人国产精品久久久网站| 99久久久国产精品| 色婷婷精品久久二区二区密| 盗摄精品av一区二区三区| 操人视频免费看| 国产一区三区三区| 婷婷激情5月天| 久久国产麻豆精品| 五月婷婷六月合| 男男视频亚洲欧美| 在线免费av播放| 免费成人在线网站| 欧美三级午夜理伦三级富婆| 琪琪一区二区三区| 欧美日韩一区二区三区69堂| 美腿丝袜亚洲三区| 欧美国产日韩另类 | 男人天堂资源网| 国产精品情趣视频| 日韩欧美视频免费观看| 综合色天天鬼久久鬼色| 永久av免费网站| 一区二区三区免费观看| 九九热只有精品| 亚洲成av人片在www色猫咪| 欧美午夜免费电影| 久久精品在线观看视频| 中文字幕一区二区三区四区| 69xxx免费| 亚洲色图.com| 精品少妇一二三区| 日韩欧美在线看| 伊人网视频在线| 欧美一级欧美一级在线播放| 欧美 日韩 国产 在线| 日韩精品有码在线观看| 国产午夜精品一区理论片| 国产一区二区三区丝袜| av在线app| 亚洲97在线观看| 99蜜月精品久久91| 亚洲影院污污.| 少妇高潮一区二区三区| 天堂一区二区三区| 欧美成人一品| 久久精品免费一区二区| 理论电影国产精品| 少妇伦子伦精品无吗| 久久一区二区三区四区| 日韩精品久久久久久久的张开腿让| 亚洲精品欧美二区三区中文字幕| 久久久久久久久99| 色婷婷综合久久久久中文 | 免费黄网站欧美| 韩国三级与黑人| 久久色在线视频| 国产欧美小视频| 中文字幕一区二区三区不卡| 在线观看 中文字幕| 欧美日韩国产bt| 熟妇人妻中文av无码| 色婷婷**av毛片一区| 丁香花在线高清完整版视频| 国产精品444| 爱高潮www亚洲精品| 婷婷四房综合激情五月| 亚洲天堂男人| 中文字幕中文在线| 91麻豆国产精品久久| 曰本女人与公拘交酡| 日本高清视频一区二区| 亚洲精品久久久蜜桃动漫 | 日韩一区二区电影网| 国产高清美女一级毛片久久| 欧美二区乱c黑人| 成人午夜一级| 免费国产在线精品一区二区三区| 911久久香蕉国产线看观看| 国产精品-区区久久久狼| 国产精品88av| 91狠狠综合久久久| 在线视频综合导航| 午夜影院在线视频| 欧美激情精品久久久久久免费印度| 成人国产精品入口免费视频| 精品久久久久亚洲| 狠久久av成人天堂| 亚洲高清av一区二区三区| 丁香5月婷婷久久| 影音先锋欧美精品| 狠狠操一区二区三区| 51国偷自产一区二区三区的来源| 日韩精品首页| 日本成人中文字幕在线| 91免费看视频| 精品成人久久久| 337p日本欧洲亚洲大胆精品| 日本中文字幕中出在线| 成人网在线观看| 999久久久精品国产| 亚洲狼人综合干| 国产午夜精品理论片a级大结局| 国产视频91在线| 亚洲精品久久久久久久久| 欧美6一10sex性hd| 国产69精品久久久久9999apgf| 自拍欧美日韩| 亚洲一区二区图片| 亚洲综合偷拍欧美一区色| 国产成人精品一区二区无码呦| 久久天天躁狠狠躁夜夜av| 伊人国产精品| 日本丰满大乳奶| 国产黄色成人av| 免费一级a毛片夜夜看| 欧美tk丨vk视频| 黄页网站大全在线免费观看| 成人在线免费观看一区| 黄色成人在线网站| 亚洲欧美高清在线| 精品高清美女精品国产区| 天堂中文网在线| 奇米一区二区三区四区久久| 国产videos久久| 中文字幕av专区| 亚洲精品国产一区二区精华液| 精品国产伦一区二区三区| 久久久久久九九九| 香蕉人人精品| 亚洲第一中文av| 亚洲特级片在线| 亚洲美女福利视频| 91精品国产乱码久久久久久久久 | 日本免费在线一区| 性做爰过程免费播放| 国产91露脸合集magnet| 亚洲精品www久久久久久| 亚洲欧美日韩久久久久久| jizz亚洲女人高潮大叫| 久久av秘一区二区三区| 成人黄色综合网站| 精品不卡一区二区| 久久久国产一区二区| 97人人澡人人爽91综合色| 一女被多男玩喷潮视频| 国产精品美女久久久久aⅴ| www.看毛片| 日本久久亚洲电影| 羞羞答答成人影院www| 国产伦精品一区二区免费| 日本丰满少妇一区二区三区| 蜜桃视频网站在线| 99久久99久久| 久久蜜桃资源一区二区老牛| 无码黑人精品一区二区| 亚洲精品久久久一区二区三区 | 精品国产成人在线影院 | 亚洲va久久久噜噜噜| 亚洲深夜av| 69堂成人精品视频免费| 欧洲中文在线| 日本精品二区| 大白屁股一区二区视频| 一级特黄免费视频| 欧美国产精品va在线观看| 精品国产一区二区三区久久久樱花 | 天堂中文av在线资源库| 老汉色影院首页| 国产午夜精品一区二区三区嫩草 | 亚洲欧美日韩精品久久奇米色影视|