国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue組件jsx語法的具體使用

2019-11-19 13:48:31
字體:
來源:轉載
供稿:網友

如果使用render函數來寫比較復雜的vue組件,對于可讀性和可維護性都很不友好,而使用jsx就會讓我們回到更接近于模板的語法。babel轉譯器會將jsx轉譯為render函數渲染。

配置

需要用到babel插件

安裝

npm install/ babel-plugin-syntax-jsx/ babel-plugin-transform-vue-jsx/ babel-helper-vue-jsx-merge-props/ babel-preset-env/ --save-dev

.babelrc配置

在plugins中添加transform-vue-jsx

{ "presets": ["env"], "plugins": ["transform-vue-jsx"]}

基礎示例

轉義前

<div id="foo">{this.text}</div>

轉譯后

h('div', { attrs: {  id: 'foo' }}, [this.text])

Note:h函數為vue實例的$createElement方法,必須存在于jsx的作用域中,在渲染函數中必須以第一個參數傳入,如:

render (h) { // <-- h 函數必須在作用域內 return <div id="foo">bar</div>}

自動注入h函數

從3.4.0開始,在用ES2015語法聲明的方法和getter訪問器中(使用function關鍵字或箭頭函數除外),babel會自動注入hconst h = this.$createElement)函數,所以可以省略(h)參數。

Vue.component('jsx-example', { render () { // h 會自動注入  return <div id="foo">bar</div> }, myMethod: function () { // h 不會注入  return <div id="foo">bar</div> }, someOtherMethod: () => { // h 不會注入  return <div id="foo">bar</div> }})@Componentclass App extends Vue { get computed () { // h 會自動注入  return <div id="foo">bar</div> }}

 Vue JSX 和 React JSX對比

首先, Vue2.0 的vnode 格式與react不同,createElement函數的第二個參數是一個數據對象,接受一個嵌套的對象,每一個嵌套對象都會有對應的模塊處理。

Vue2.0 render語法

render (h) { return h('div', {  // 組件props  props: {   msg: 'hi'  },  // 原生HTML屬性  attrs: {   id: 'foo'  },  // DOM props  domProps: {   innerHTML: 'bar'  },  // 事件是嵌套在`on`下面的,所以將不支持修飾符,如:`v-on:keyup.enter`,只能在代碼中手動判斷keyCode  on: {   click: this.clickHandler  },  // For components only. Allows you to listen to  // native events, rather than events emitted from  // the component using vm.$emit.  nativeOn: {   click: this.nativeClickHandler  },  // class is a special module, same API as `v-bind:class`  class: {   foo: true,   bar: false  },  // style is also same as `v-bind:style`  style: {   color: 'red',   fontSize: '14px'  },  // other special top-level properties  key: 'key',  ref: 'ref',  // assign the `ref` is used on elements/components with v-for  refInFor: true,  slot: 'slot' })}

對應的Vue2.0 JSX語法

render (h) { return (  <div   // normal attributes or component props.   id="foo"   // DOM properties are prefixed with `domProps`   domPropsInnerHTML="bar"   // event listeners are prefixed with `on` or `nativeOn`   onClick={this.clickHandler}   nativeOnClick={this.nativeClickHandler}   // other special top-level properties   class={{ foo: true, bar: false }}   style={{ color: 'red', fontSize: '14px' }}   key="key"   ref="ref"   // assign the `ref` is used on elements/components with v-for   refInFor   slot="slot">  </div> )}

JSX展開運算符

支持JSX展開,插件會智能的合并數據屬性,如:

const data = { class: ['b', 'c']}const vnode = <div class="a" {...data}/>

合并后的數據為:

{ class: ['a', 'b', 'c'] }

Vue 指令

JSX對大多數的Vue內建指令都不支持,唯一的例外是v-show,該指令可以使用v-show={value}的語法。大多數指令都可以用編程方式實現,比如v-if就是一個三元表達式,v-for就是一個array.map()等。

如果是自定義指令,可以使用v-name={value}語法,但是改語法不支持指令的參數arguments和修飾器modifier。有以下兩個解決方法:

將所有內容以一個對象傳入,如:v-name={{ value, modifier: true }}

使用原生的vnode指令數據格式,如:

const directives = [ { name: 'my-dir', value: 123, modifiers: { abc: true } }]return <div {...{ directives }}/>

原文地址(https://github.com/vuejs/babel-plugin-transform-vue-jsx#usage)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 体育| 蒙山县| 萝北县| 阿瓦提县| 焦作市| 江安县| 寻乌县| 涞源县| 福贡县| 同江市| 沙坪坝区| 射阳县| 万安县| 铁力市| 武强县| 赤峰市| 山西省| 弥勒县| 报价| 宾川县| 庆安县| 承德县| 昂仁县| 鹤峰县| 和平区| 南岸区| 福泉市| 体育| 门头沟区| 宁蒗| 沙河市| 三明市| 闽侯县| 诏安县| 涡阳县| 土默特右旗| 米脂县| 长宁区| 冕宁县| 高平市| 西青区|