亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

在vue中使用jsx語法的使用方法

 更新時間:2019年09月30日 11:55:06   作者:SuperMan一路向北  
這篇文章主要介紹了在vue中使用jsx語法的使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

什么是JSX?

JSX就是Javascript和XML結合的一種格式。React發(fā)明了JSX,利用HTML語法來創(chuàng)建虛擬DOM。當遇到<,JSX就當HTML解析,遇到{就當JavaScript解析.

我為什么要在vue中用JSX?

想折騰一下唄,開玩笑.最開始是因為近期在學習react,在里面體驗了一把jsx語法,發(fā)現(xiàn)也并沒有別人說的很難受的感覺啊,于是就想嘗試在vue中也試下,廢話不多說,先來用代碼來看下兩者的區(qū)別吧.

ps:vue中大部分場景是不需要用render函數(shù)的,還是用模板更簡潔直觀.

使用template

// item.vue
<template>
 <div>
  <h1 v-if="id===1">
   <slot></slot>
  </h1>
  <h2 v-if="id===2">
   <slot></slot>
  </h2>
  <h3 v-if="id===3">
   <slot></slot>
  </h3>
  <h4 v-if="id===4">
   <slot></slot>
  </h4>
 </div>
</template>

<script>
  export default {
    name: "item",
    props:{
     id:{
      type:Number,
      default:1
     }
    }
  }
</script>

item組件中就是接收父組件傳過來的id值來顯示不同的h標簽,v-if可以說用到了"極致",而且寫了很多個冗余的slot

使用render函數(shù)和jsx

// item.vue
<script>
  export default {
    name: "item",
    props:{
     id:{
      type:Number,
      default:1
     }
    },
   render(){
     const hText=`
            <h${this.id}>${this.$slots.default[0].text}</h${this.id}>
           `
    return <div domPropsInnerHTML={hText}></div>
   }
  }
</script>

再加上父組件來控制props的值。父組件不做對比還用傳統(tǒng)的template格式,

// list.vue
<template>
 <div>
  <h-title :id="id">Hello World</h-title>
  <button @click="next">下一個</button>
 </div>
</template>

<script>
 import Title from './item'

 export default {
  name: "list",
  data() {
   return {
    id:1
   }
  },
  components: {
   "h-title":Title
  },
  methods:{
   next(){
    ++this.id
   }
  }
 }
</script>

運行后頁面就渲染出了h1 or h2 or h3標簽,同時slot也只有一個,點擊切換props的值,也會顯示不同的h標簽。第二種寫法雖然不是很直接,但是省去了很多冗余代碼,頁面一下清爽了很多。

沒了v-if,v-for,v-model怎么辦?

不要著急,這些指令只是黑魔法,用js很容易實現(xiàn)。

v-if

 render(){
    return (
     <div>
      {this.show?'你帥':'你丑'}
     </div>
    )
   }

寫三元表達式只能寫簡單的,那么復雜的還得用if/else

  render(){
    let ifText
    if(this.show){
      ifText=<p>你帥</p>
    }else{
      ifText=<p>你丑</p>
    }
    return (
     <div>
      {ifText}
     </div>
    )
   }

v-for

   data(){
    return{
     show:false,
     list:[1,2,3,4]
    }
   },
   render(){
    return (
     <div>
      {this.list.map((v)=>{
       return <p>{v}</p>
      })}
     </div>
    )
   }

在jsx中{}中間是沒辦法寫if/for語句的只能寫表達式,所以就用map來當循環(huán),用三元表達式來當判斷了

v-model

最近在幫公司面試招人發(fā)現(xiàn)v-model很多人都不知道語法糖是什么?然后有些人說我可以用原生js實現(xiàn),但是他們竟然不知道在vue中怎么實現(xiàn),好吧,兩個點:傳值和監(jiān)聽事件改變值。

  <script>
  export default {
    name: "item",
   data(){
    return{
     show:false,
     list:[1,2,3,4],
     text:'',
    }
   },
   methods:{
    input(e){
     this.text=e.target.value
    }
   },
   render(){
    return (
     <div>
      <input type="text" value={this.text} onInput={this.input}/>
      <p>{this.text}</p>
     </div>
    )
   }
  }
</script>

怎么用自定義組件?

很簡單,只需要導入進來,不用再在components屬性聲明了,直接寫在jsx中比如

<script>
 import HelloWolrd from './HelloWorld'
  export default {
   name: "item",
   render(){
    return (
      <HelloWolrd/>
    )
   }
  }
</script>

事件,class,style,ref等等怎么綁定?

來看下面的寫法

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>
 )
}

上面有個地方需要注意,當給自定義組件綁定事件時用nativeOnClick,而模板格式是用
@click.native,另外當用到給函數(shù)式組件綁定事件時就有點小坑了下面說。

JSX中的函數(shù)式組件

函數(shù)式組件無狀態(tài),無this實例,下面是vue文檔中提到的一段話:

因為函數(shù)式組件只是一個函數(shù),所以渲染開銷也低很多。然而,對持久化實例的缺乏也意味著函數(shù)式組件不會出現(xiàn)在 Vue devtools 的組件樹里。

我個人理解因為沒了狀態(tài)(data),少了很多響應式的處理,還有生命周期等過程會提高速度和減少內存占用吧?
函數(shù)式組件也可以在模板格式中用只需要這樣

<template functional>

</template>

那jsx中的函數(shù)式組件呢?也很簡單只需增加配置functional: true就可以了

那函數(shù)式組件沒有了this 實例怎么綁定事件怎么獲取props呢?

組件需要的一切都是通過上下文傳遞,包括:

  • props : 提供所有 prop 的對象
  • children: VNode 子節(jié)點的數(shù)組
  • slots: 返回所有插槽的對象的函數(shù)
  • data:傳遞給組件的數(shù)據對象,并將這個組件作為第二個參數(shù)傳入 createElement

上面我只列舉了部分屬性,這些是非函數(shù)式組件的東西,對于函數(shù)式組件
vue 增加了context對象,需要作為render(h,context) 第二個參數(shù)傳入,this.$slots.default更新為context.children props原本是直接掛在this上的,現(xiàn)在變?yōu)閏ontext.props掛在了context.props上。this.data變?yōu)榱薱ontext.data

需要注意的是對于函數(shù)式組件,沒有被定義為prop的特性不會自動添加到組件的根元素上,意思就是需要我們手動添加到組件根元素了,看個例子吧

//父組件
 ...省略無關代碼
 render(){
   return (
    <Item data={this.data} class="large"/>
   )
  }
//Item.vue組件
export default {
  functional:true,
   name: "item",
   render(h,context){
    return (
     <div class="red" >
      {context.props.data}
     </div>
    )
   }
  }

上面代碼期待的是.large類名傳入到了Item的根元素上,但是其實沒有。我們需要增加點東西

// Item.vue
export default {
  functional:true,
   name: "item",
   render(h,context){
    return (
     <div class="red" {...context.data}>
      {context.props.data}
     </div>
    )
   }
  }

注意到,通過展開運算符把所有的屬性添加到了根元素上,這個context.data就是你在父組件給子組件增加的屬性,他會跟你在子元素根元素的屬性智能合并,現(xiàn)在.large類名就傳進來了。這個很有用,當你在父組件給子組件綁定事件時就需要這個了。下面說一個關于綁定事件的小坑

向 createElement 通過傳入 context.data 作為第二個參數(shù),我們就把 my-functional-button 上面所有的特性和事件監(jiān)聽器都傳遞下去了。事實上這是非常透明的,那些事件甚至并不要求 .native 修飾符

上面是vue官網的一段話,然而我看了一遍就忽略了一句很重要的話,就是最后一句,他說不需要.native修飾符了?好先看代碼

// 父組件
 methods:{
   show(){
    alert('你好')
   }
  },
  render(){
   return (
    <Item data={this.data} onNativeClick={this.show} class="large"/>
   )
  }

上面代碼乍一看沒毛病,自定義組件用onNativeClick嘛,結果就是不會彈窗。唉,最后讀了幾遍剛才vue文檔中的解釋,才發(fā)現(xiàn)原來函數(shù)式組件不需要.native修飾符,對于template格式肯定一下就反應過來了,但是jsx的話,好吧,把上面的onNativeClick重新改為onClick就好了。

現(xiàn)有項目哪些功能可以用jsx代替呢?

這個其實跟最開始我例舉的例子很像。我在項目中用它來干掉了滿屏的v-if/v-else

由于我的業(yè)務是pad上的,需求是一套試卷有幾十道題目,要求一屏只顯示一道題目,點擊下一題顯示下一個題,思路也比較簡單:

  1. 用一個num變量表示當前正在展示的題目索引
  2. 每次點擊下一題按鈕時num++
  3. 用v-if來判斷 num===1,num===2這樣來決定展示哪個。

這一寫,模板里面好多啊,由于我們的題目每道題的模板可能都不一樣,所以沒辦法循環(huán),只能手寫全部。之前考慮過用動態(tài)組件來切換,但是放棄了,因為沒有if直觀啊。

下面看怎么用jsx優(yōu)化一下

//父組件
 export default {
  name: "list",
  data() {
   return {
    data:'我是函數(shù)式組件',
    id:1,
     tests:{
     1:<div><span>第一道題</span></div>,
     2:<div><section>第二道題</section></div>,
     3:<div><p>第三道題</p></div>
    }
   }
  },
  methods:{
   next(){
    ++this.id
   }
  },
  render(){
   return (
    <div>
     <Item data={this.tests[this.id]} class="large"/>
     <button onClick={this.next}>下一題</button>
    </div>
   )
  }
 }

上面每道題目的結構都不一致

 //子組件,只接受數(shù)據展示,用函數(shù)式組件
<script>
 export default {
 functional:true,
  name: "item",
  render(h,context){
   return (
    <div class="red" {...context.data}>
     {context.props.data}
    </div>
   )
  }
 }
</script>

上面沒有用任何if/else判斷就完成了功能,這里用jsx我覺得比較合適,不知道各位大佬有什么其他思路?

最后

總結一下吧,我們平時開發(fā)還是多用temlate因為直觀簡潔,各種指令用著很方便,等你覺得用template寫出的代碼看著很冗余,或者想自己控制渲染邏輯比如循環(huán),判斷等等時可以考慮用JSX。另外推薦大家多用函數(shù)式組件提高性能。

第一次寫文章,希望各位花時間看了的大佬覺得哪個說的不太嚴謹還需多多包涵,提出意見我都接受。

參考資料

vue 渲染函數(shù)&jsx
babel-plugin-transform-vue-jsx

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

相關文章

  • vue+element-ui:使用el-dialog時彈框不出現(xiàn)的解決

    vue+element-ui:使用el-dialog時彈框不出現(xiàn)的解決

    這篇文章主要介紹了vue+element-ui:使用el-dialog時彈框不出現(xiàn)的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue+Vuex實現(xiàn)自動登錄的知識點詳解

    Vue+Vuex實現(xiàn)自動登錄的知識點詳解

    在本篇文章里小編給大家整理的是關于Vue+Vuex實現(xiàn)自動登錄的知識點詳解,需要的朋友們可以學習下。
    2020-03-03
  • 使用vue2.6實現(xiàn)抖音【時間輪盤】屏保效果附源碼

    使用vue2.6實現(xiàn)抖音【時間輪盤】屏保效果附源碼

    前段時間看抖音,有人用時間輪盤作為動態(tài)的桌面壁紙,一時間成為全網最火的電腦屏保,后來小米等運用市場也出現(xiàn)了【時間輪盤】,有點像五行八卦,感覺很好玩,于是突發(fā)奇想,自己寫一個網頁版小DEMO玩玩,需要的朋友可以參考下
    2019-04-04
  • Vue實現(xiàn)購物車詳情頁面的方法

    Vue實現(xiàn)購物車詳情頁面的方法

    這篇文章主要介紹了Vue實戰(zhàn)之購物車詳情頁面的實現(xiàn),本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • vue3中ts語法使用element plus分頁組件警告錯誤問題

    vue3中ts語法使用element plus分頁組件警告錯誤問題

    這篇文章主要介紹了vue3中ts語法使用element plus分頁組件警告錯誤問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • 詳解Vue如何支持JSX語法

    詳解Vue如何支持JSX語法

    這篇文章主要介紹了詳解Vue如何支持JSX語法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • vant如何修改placeholder樣式

    vant如何修改placeholder樣式

    這篇文章主要介紹了vant如何修改placeholder樣式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue3之 Vue CLI多環(huán)境配置

    Vue3之 Vue CLI多環(huán)境配置

    這篇文章主要介紹了Vue3之 Vue CLI多環(huán)境配置,通俗點說就是使用配置文件來管理多環(huán)境,實現(xiàn)環(huán)境的切換,西阿棉詳細內容,需要的朋友可以參考一下
    2021-11-11
  • ant-design-vue中的select選擇器,對輸入值的進行篩選操作

    ant-design-vue中的select選擇器,對輸入值的進行篩選操作

    這篇文章主要介紹了ant-design-vue中的select選擇器,對輸入值的進行篩選操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • vue2實現(xiàn)directive自定義指令的封裝與全局注冊流程

    vue2實現(xiàn)directive自定義指令的封裝與全局注冊流程

    自定義指令是對普通DOM元素進行的底層操作,它是一種有效的的補充和擴展,不僅可以用于定義任何的dom操作,并且是可以復用的,下面這篇文章主要給大家介紹了關于vue2實現(xiàn)directive自定義指令的封裝與全局注冊流程的相關資料,需要的朋友可以參考下
    2023-02-02

最新評論