欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何在 Vue 中使用 JSX

 更新時間:2021年02月14日 10:14:23   作者:vickylinj  
這篇文章主要介紹了如何在 Vue 中使用 JSX,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下

JSX 是什么

JSX 是一種 Javascript 的語法擴展,JSX = Javascript + XML,即在 Javascript 里面寫 XML,因為 JSX 的這個特性,所以他即具備了 Javascript 的靈活性,同時又兼具 html 的語義化和直觀性

為什么要在 Vue 中使用 JSX

有時候,我們使用渲染函數(shù)(render function)來抽象組件,渲染函數(shù)不是很清楚的參見官方文檔, 而渲染函數(shù)有時候?qū)懫饋硎欠浅M纯嗟?/p>

createElement(
 'anchored-heading', {
 props: {
  level: 1
 }
 }, [
 createElement('span', 'Hello'),
 ' world!'
 ]
)

其對應(yīng)的模板是下面:

<anchored-heading :level="1">
 <span>Hello</span> world!
</anchored-heading>

這顯然是吃力不討好的,這個時候就派上 JSX 上場了。在 Vue 中使用 JSX,需要使用 Babel 插件,它可以讓我們回到更接近于模板的語法上,接下來就讓我們一起開始在 Vue 中寫 JSX 吧

開始

快讀創(chuàng)建一個 Vue 項目,直接使用 vue-cli 創(chuàng)建一個項目:

# 直接回車即可
vue create vue-jsx

安裝依賴:

npm install @vue/babel-preset-jsx @vue/babel-helper-vue-jsx-merge-props

配置 .babelrc :

module.exports = {
 presets: [
 '@vue/cli-plugin-babel/preset',
 ['@vue/babel-preset-jsx',
  {
  'injectH': false
  }]
 ]
}

基礎(chǔ)內(nèi)容

這里展示在 Vue 中書寫一些基礎(chǔ)內(nèi)容,包括純文本、動態(tài)內(nèi)容、標(biāo)簽使用、自定義組件的使用,這些跟我們平時使用單文件組件類似,如下所示:

render() {
 return (
 <div>
  <h3>內(nèi)容</h3>
  {/* 純文本 */}
  <p>hello, I am Gopal</p>
  {/* 動態(tài)內(nèi)容 */}
  <p>hello { this.msg }</p>
  {/* 輸入框 */}
  <input />
  {/* 自定義組件 */}
  <myComponent></myComponent>
 </div>
 );
}

Attributes/Props

Attributes 的綁定跟普通的 HTML 結(jié)構(gòu)一樣

render() {
 return <div><input placeholder="111" /></div>
}

注意,如果動態(tài)屬性,之前是 v-bind:placeholder="this.placeholderText" 變成了placeholder={this.placeholderText}

render() {
 return <input
   type="email"
   placeholder={this.placeholderText}
   />
}

我們也可以展開一個對象

render (createElement) {
 return (
  <button {...this.largeProps}></button>
 )
}

像 input 標(biāo)簽,就可以如下批量綁定屬性

const inputAttrs = {
 type: 'email',
 placeholder: 'Enter your email'
};
render() {
 return <input {...{ attrs: inputAttrs }} /> 
}

插槽

我們來看下怎么實現(xiàn)具名插槽和作用域插槽

具名插槽:父組件的寫法和單文件組件模板的類似,通過 slot="header" 這樣方式指定要插入的位置。子組件通過 this.$slots.header 方式指定插槽的名稱,其中 header 就是插槽的名稱

父組件:

render() {
 {/* 具名插槽 */}
 <myComponent>
 <header slot="header">header</header>
 <header slot="content">content</header>
 <footer slot="footer">footer</footer>
 </myComponent>
}

子組件:

render() {
 return (
 <div>
  {/* 純文本 */}
  <p>我是自定義組件</p>
  {this.$slots.header}
  {this.$slots.content}
  {this.$slots.footer}
 </div>
 );
}

作用域插槽:子組件中通過 {this.$scopedSlots.test({ user: this.user })} 指定插槽的名稱是 test,并將 user 傳遞給父組件。父組件在書寫子組件標(biāo)簽的時候,通過 scopedSlots 值指定插入的位置是 test,并在回調(diào)函數(shù)獲取到子組件傳入的 user 值

父組件:

render() {
 {/* 具名插槽 作用域插槽 */}
 <myComponent {
 ...{
  scopedSlots: {
  test: ({user}) => (
   <div>{user.name}</div>
  )
  }
 }
 }>
 </myComponent>

子組件:

render() {
 return (
 <div>
  {this.$scopedSlots.test({
  user: this.user
  })}
 </div>
 );
}

指令

常見的指令如下所示:

render() {
 {/* 指令 */}
 {/* v-model */}
 <div><input vModel={this.newTodoText} /></div>
 {/* v-model 以及修飾符 */}
 <div><input vModel_trim={this.tirmData} /></div>
 {/* v-on 監(jiān)聽事件 */}
 <div><input vOn:input={this.inputText} /></div>
 {/* v-on 監(jiān)聽事件以及修飾符 */}
 <div><input vOn:click_stop_prevent={this.inputText} /></div>
 {/* v-html */}
 <p domPropsInnerHTML={html} />
}

函數(shù)式組件

函數(shù)式組件是一個無狀態(tài)、無實例的組件,詳見官網(wǎng)說明,新建一個 FunctionalComponent.js 文件,內(nèi)容如下:

export default ({ props }) => <p>hello {props.message}</p>

父組件中調(diào)用如下:

import funComponent from './FunctionalComponent'

...

render() {
 return {/* 函數(shù)式組件 */}
  <funComponent message="Gopal"></funComponent>
}

以上就是如何在 Vue 中使用 JSX的詳細(xì)內(nèi)容,更多關(guān)于Vue 中使用 JSX的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue項目實戰(zhàn)之優(yōu)雅使用axios

    vue項目實戰(zhàn)之優(yōu)雅使用axios

    axios是一個基于promise的HTTP庫,可以用在瀏覽器和?node.js?中,下面這篇文章主要給大家介紹了關(guān)于vue項目實戰(zhàn)之優(yōu)雅使用axios的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-02-02
  • 記一次vue去除#問題處理經(jīng)過小結(jié)

    記一次vue去除#問題處理經(jīng)過小結(jié)

    這篇文章主要介紹了vue去除#問題處理經(jīng)過,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • 關(guān)于配置babel-plugin-import報錯的坑及解決

    關(guān)于配置babel-plugin-import報錯的坑及解決

    這篇文章主要介紹了關(guān)于配置babel-plugin-import報錯的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Vue transition實現(xiàn)點贊動畫效果的示例

    Vue transition實現(xiàn)點贊動畫效果的示例

    點贊動畫是網(wǎng)頁評論中常見的功能,本文將介紹如何用vue實現(xiàn)這一效果。點贊時愛心縮小變大,變大時略微大一點再變正常,取消點贊時愛心無動畫,同時數(shù)字滾動,+1 時向上滾動,-1 時向下滾動
    2021-05-05
  • vue2移動端+swiper實現(xiàn)異形的slide方式

    vue2移動端+swiper實現(xiàn)異形的slide方式

    這篇文章主要介紹了vue2移動端+swiper實現(xiàn)異形的slide方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue前端柱狀圖實例(疊狀條形圖)

    Vue前端柱狀圖實例(疊狀條形圖)

    這篇文章主要介紹了Vue前端柱狀圖實例(疊狀條形圖),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • VUE中的export default和export使用方法解析

    VUE中的export default和export使用方法解析

    export default和export都能導(dǎo)出一個模塊里面的常量,函數(shù),文件,模塊等,在其它文件或模塊中通過import來導(dǎo)入常量,函數(shù),文件或模塊。但是,在一個文件或模塊中export,import可以有多個,export default卻只能有一個。
    2022-12-12
  • element-ui中實現(xiàn)tree子節(jié)點部分選中時父節(jié)點也選中

    element-ui中實現(xiàn)tree子節(jié)點部分選中時父節(jié)點也選中

    這篇文章主要介紹了element-ui中實現(xiàn)tree子節(jié)點部分選中時父節(jié)點也選中的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 教你使用vue3寫Json-Preview的示例代碼

    教你使用vue3寫Json-Preview的示例代碼

    這篇文章主要介紹了用vue3寫了一個Json-Preview的相關(guān)知識,引入后直接<json-preview?v-model="jsonData"></json-preview>就可以使用了,本文通過示例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • Vue或者React項目配置@路徑別名及智能提示方案

    Vue或者React項目配置@路徑別名及智能提示方案

    這篇文章主要介紹了Vue或者React項目配置@路徑別名及智能提示方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10

最新評論