精品欧美一区二区三区在线观看 _久久久久国色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ù)棧公眾號

视频在线观看免费影院欧美meiju| 午夜美女福利视频| 亚洲综合福利| 欧美日韩精品一区二区三区| 国产奶头好大揉着好爽视频| 成人午夜精品福利免费| 久久久精品性| 久久精品国产久精国产思思| 中国免费黄色片| 视频精品导航| 午夜日韩在线观看| 一区精品在线| 久久国产精品高清一区二区三区| 精品一区二区三区在线观看| 91超碰caoporn97人人| 五月天免费网站| 特黄特色欧美大片| 欧美群妇大交群中文字幕| 五十路熟女丰满大屁股| 欧美精品hd| 久久久久久久综合日本| 99高清视频有精品视频| 国产精品成人无码| 亚洲精品国产无码| 日本在线观看免费| 91丨九色丨蝌蚪富婆spa| 国产精品亚洲综合天堂夜夜| 久久久久亚洲av成人毛片韩| 综合久久久久| 日韩中文字幕在线| 欧美另类z0zx974| 欧美91在线| 日韩精品专区在线影院观看| 色婷婷成人在线| 在线亚洲人成| 性做久久久久久| 永久免费网站视频在线观看| 成年人视频网站在线| 26uuu亚洲综合色| 国产麻豆一区二区三区在线观看| 91国偷自产中文字幕久久| 久久亚洲欧洲| 57pao成人国产永久免费| 国产成人啪精品午夜在线观看| 亚洲国产成人精品女人| 日韩中文字幕免费看| 这里只有久久精品| 在线成人动漫av| 日韩福利视频在线观看| 国产草草浮力影院| 精品丝袜久久| 精品乱码亚洲一区二区不卡| 成人免费播放视频| 精品国产一级| 日韩欧美电影一区| xxxx视频在线观看| 一区二区亚洲视频| 欧美精品一区在线观看| 中国极品少妇xxxx| 电影一区二区在线观看| 亚洲第一精品福利| 久久久午夜精品福利内容| 波多野结衣在线一区二区 | 老太脱裤子让老头玩xxxxx| 成人毛片av在线| 亚洲黄色小视频| 久久这里只有精品8| 丰满诱人av在线播放| 亚洲一卡二卡三卡四卡无卡久久| xxxx18hd亚洲hd捆绑| 免费成人在线电影| 欧美亚洲综合在线| 亚洲综合123| 成人黄色av网址| 精品一区二区电影| 阿v天堂2014| 欧美精品成人| 午夜精品一区二区三区在线 | 欧美亚洲图片小说| www.久久91| 视频免费一区二区| 日韩av在线免费播放| 色欲狠狠躁天天躁无码中文字幕 | 色妞ww精品视频7777| 欧美精品一区二区在线观看| 亚洲欧美视频在线播放| 日韩精品看片| 久久久久久久久久久av| 亚洲精品中文字幕乱码三区91| 日韩av中文字幕一区二区三区| 国产人妖伪娘一区91| 丰满人妻一区二区| 国产午夜精品一区二区三区视频 | 免费看黄色aaaaaa 片| 欧美人妖在线| 美女精品视频一区| 特黄视频免费看| 极品销魂美女一区二区三区| 精品日本一区二区| 欧美成人三区| 精品国产91久久久久久| 五月天av在线播放| 西瓜成人精品人成网站| 久久精品91久久久久久再现| 男女啊啊啊视频| 精品中文字幕一区二区| 精品一区二区三区国产| 国产黄色小视频在线| 欧美性猛交xxxx乱大交蜜桃| 亚洲成人手机在线观看| 欧美精品一区二区三区精品| 久久久爽爽爽美女图片| 91久久国语露脸精品国产高跟| 99精品在线观看视频| 国产手机视频在线观看| 成人爱爱网址| 亚洲的天堂在线中文字幕| 女人裸体性做爰全过| 国产一区二区三区久久久久久久久 | 黄视频网站在线观看| 欧美精品久久久久久久久老牛影院| 青青草视频播放| 欧美精品综合| 91九色单男在线观看| 国产毛片在线看| 欧美视频免费在线观看| 国产香蕉精品视频| 欧美伊人影院| 成人激情视频在线| 日本免费在线视频| 欧洲色大大久久| 久久精品国产亚洲av麻豆| 韩国久久久久| 成人91视频| a免费在线观看| 欧美日韩和欧美的一区二区| www在线观看免费视频| 国产模特精品视频久久久久| av成人免费观看| 成人在线app| 欧美精品日韩一区| 亚洲视频重口味| 久久99国产精品久久99| 特级西西444www大精品视频| 国产亚洲一区二区手机在线观看| 日韩国产一区三区| 日韩免费视频一区二区视频在线观看| 丁香啪啪综合成人亚洲小说| 美女黄色免费看| 色妞ww精品视频7777| 欧美精品videofree1080p| xxxx国产精品| 亚洲韩国一区二区三区| 国产精品99久久久精品无码| 亚洲国产高清视频| 好吊妞www.84com只有这里才有精品| 密臀av在线| 亚洲成人久久网| 一级免费在线观看| 91视频com| 熟女人妇 成熟妇女系列视频| 免费久久精品| 国产精品露脸自拍| 女女色综合影院| 日韩三级.com| 伊人国产在线观看| 26uuu国产一区二区三区 | 美国av一区二区| 99re99热| eeuss鲁片一区二区三区| 992tv成人免费影院| 欧美美女色图| 欧美日韩一级视频| 青娱乐国产精品| k8久久久一区二区三区| 青青在线视频观看| 成人vr资源| 99精品国产一区二区| 草草视频在线观看| 一本色道久久88综合日韩精品 | 在线观看欧美日韩电影| 在线国产精品播放| 国产色视频在线| 精品人伦一区二区三区蜜桃网站 | 爱情岛论坛亚洲自拍| 99国产一区| 亚洲精品一卡二卡三卡四卡| 视频一区视频二区欧美| 欧洲亚洲在线视频| 国产调教视频在线观看| 亚洲激情免费观看| 在线播放成人av| 亚洲尤物在线视频观看| 亚洲区自拍偷拍| 国产91富婆露脸刺激对白| 日韩中文字幕组| 欧美精品播放| 午夜午夜精品一区二区三区文| 欧美日韩黄网站| 日韩美女视频在线观看| 97caopor国产在线视频| 亚洲欧美日韩在线一区| 精品国产18久久久久久| 日韩欧中文字幕| 免费在线观看av网址| 国产欧美精品区一区二区三区| 三大队在线观看| 免费在线观看成人| 欧美 国产 综合| 欧美高清日韩| 亚洲看片网站| 国产传媒欧美日韩成人精品大片| 99精品国产高清在线观看| 奇米777日韩| 久久免费国产精品1| 国产在线观看av| 国产一区二区免费| 亚洲人午夜射精精品日韩| 777奇米成人网| 免费黄色小视频在线观看| 天天影视涩香欲综合网| 欧美成人精品欧美一| 国产精品日日摸夜夜摸av| 丰满大乳奶做爰ⅹxx视频 | 91在线短视频| 国精品产品一区| 国产精品99导航| 中文一区一区三区高中清不卡免费| 欧美福利小视频| 成年人视频网站在线| 亚洲视频自拍偷拍| 男女污视频在线观看| 精品亚洲aⅴ在线观看| 亚洲女同志亚洲女同女播放| 91精品国产综合久久久久久| 中文字幕在线观看你懂的| 91成人在线精品| 国产午夜性春猛交ⅹxxx| 亚洲福利一二三区| 久久久久久久久97| 亚洲精品一卡二卡| 农村黄色一级片| 亚洲日本乱码在线观看| 国产黄a三级三级| 国产精品你懂的在线| 日本精品在线观看视频| 国产亚洲精品免费| 在线视频第一页| 中文字幕中文字幕一区| 欧美aaa级片| 成人免费一区二区三区在线观看| 国产一区在线观看免费| 国产精品乱子久久久久| 成人性生活毛片| 一区二区三区四区国产精品| 久久免费视频精品| 天天综合网天天综合色 | 在线电影院国产精品| 国产精品主播一区二区| 欧美一二三区精品| 性网爆门事件集合av| 亚洲成成品网站| 视频一区二区三区国产| 亚洲片在线观看| 91网页在线观看| 久久精品国产亚洲| 欧美巨大xxxx做受沙滩| 欧美综合第一页| 国产精品.xx视频.xxtv| 91精品入口蜜桃| 精品亚洲精品| 欧美一区二区三区在线播放| 首页国产精品| 日韩免费在线观看av| 一区二区三区福利| 色悠悠久久综合网| 国产成人欧美日韩在线电影| 国产成人无码一区二区在线观看| 日本一区二区三区在线不卡| 成人性视频免费看| 亚洲成精国产精品女| 999视频在线| 欧美大黄免费观看| 国产在线观看网站| 美日韩在线视频| 91av亚洲| 亚洲综合社区网| 亚洲精品合集| 成人黄色片免费| 性欧美videos另类喷潮| 涩涩网站在线看| 91网站最新网址| 我要看一级黄色录像| 婷婷久久综合九色国产成人| 自拍偷拍第八页| 亚洲а∨天堂久久精品喷水| jizz日韩| 91国偷自产一区二区三区的观看方式| 久久伊人国产| 九九99久久| 一二三区不卡| 国产一区视频免费观看| 国产成人综合亚洲网站| 调教驯服丰满美艳麻麻在线视频| 亚洲狠狠爱一区二区三区| 亚洲一区二区色| 亚洲美女精品成人在线视频| 污网站在线免费看| 国产精品亚洲激情| 亚洲aa在线| 国产91视频一区| 毛片不卡一区二区| 中文字幕国产专区| 亚洲国产精品久久人人爱| 911美女片黄在线观看游戏| 亚洲精品一区在线观看香蕉| 韩国日本一区| 亚洲va久久久噜噜噜| 欧美码中文字幕在线| 亚洲熟妇av一区二区三区漫画| 国产麻豆视频一区| 成年人免费视频播放| 色网综合在线观看| 天堂av网在线| 97国产在线视频| ccyy激情综合| 国产黄色激情视频| 国产美女一区二区三区| 中文字幕资源站| 欧美午夜精品一区| 黄色av免费在线观看| 人人爽久久涩噜噜噜网站| 激情视频极品美女日韩| 欧美黄网在线观看| 国产剧情一区二区| 国产精品老熟女一区二区| 3d动漫精品啪啪1区2区免费| 欧美日韩在线看片| 91精品久久久久久久久久久| 色乱码一区二区三区网站| 日韩一级理论片| 中文字幕国产精品一区二区| 日韩黄色片网站| 尤物九九久久国产精品的分类| 成人午夜视屏| 日本一区二区三区四区在线观看| 欧美综合国产| 国产成人精品无码免费看夜聊软件| 欧美色视频日本版| 可以在线观看的av| 国产精品福利观看| 欧美日韩在线网站| 国产精品自拍视频在线| 国产精品黄色在线观看| 91成人在线免费| 欧美伦理91i| av不卡一区二区| 国产午夜大地久久| 久久亚洲影视婷婷| 波多野结衣网站| www.久久久久| 久久久久毛片免费观看| 亚洲精品久久久久久久蜜桃臀| av网站一区二区三区| 国产尤物在线视频| 国产亚洲一级高清| 亚州精品国产| 久久久久久久久久久久久国产| 国产成人亚洲精品青草天美| 日韩精品国产一区二区| 亚洲欧美自拍一区| 亚洲伦理久久| www.在线观看av| 久久精品亚洲精品国产欧美kt∨| 亚洲精品一区二区二区| 精品国内产的精品视频在线观看| 国产成人综合久久| 亚洲综合色站| 中文在线观看免费视频| 91黄色免费网站| 黄色免费在线观看| 国产欧美丝袜| 日本欧美韩国一区三区| av成人免费网站| 日韩高清有码在线| 99精品在线免费观看| aa视频在线播放| 国产精品乱码妇女bbbb| 黄色av中文字幕| 国产精品高潮在线| 狠狠综合久久| 国产精成人品免费观看| 欧美一区午夜精品| 都市激情亚洲一区| 日本xxxxx18| 国产视频一区二区在线| 成人av手机在线| 国产欧美精品日韩| 亚洲综合丁香| 综合五月激情网|