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

JSX在render函數(shù)中的應用詳解

 更新時間:2019年09月04日 08:58:01   作者:前端優(yōu)選  
這篇文章主要介紹了JSX在render函數(shù)中的應用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

一.JSX簡介

const element = <h1>Hello, world!</h1>;

JSX 可以很好地描述 UI 應該呈現(xiàn)出它應有交互的本質(zhì)形式。JSX 可能會使人聯(lián)想到模版語言,但它具有 JavaScript 的全部功能。

Babel 會把 JSX 轉(zhuǎn)譯成一個名為 React.createElement() 函數(shù)調(diào)用。

以下兩種示例代碼完全等效:

const element = (
 <h1 className="greeting">
  Hello, world!
 </h1>
);
const element = React.createElement(
 'h1',
 {className: 'greeting'},
 'Hello, world!'
);

React.createElement() 會預先執(zhí)行一些檢查,以幫助你編寫無錯代碼,但實際上它創(chuàng)建了一個這樣的對象:

const element = {
 type: 'h1',
 props: {
  className: 'greeting',
  children: 'Hello, world!'
 }
};

二.模板缺陷

模板的最大特點是擴展難度大,不易擴展。可能會造成邏輯冗余:

<Level :type="1">哈哈</Level>
<Level :type="2">哈哈</Level>
<Level :type="3">哈哈</Level>

Level組件需要對不同的type產(chǎn)生不同的標簽

<template>
 <h1 v-if="type==1">
 <slot></slot>
 </h1>
 <h2 v-else-if="type==2">
 <slot></slot>
 </h2>
 <h3 v-else-if="type==3">
 <slot></slot>
 </h3>
</template>
<script>
export default {
 props: {
 type: {
  type: Number
 }
 }
};
</script>

三.函數(shù)式組件

函數(shù)式組件沒有模板,只允許提供render函數(shù)

export default {
 render(h) {
 return h("h" + this.type, {}, this.$slots.default);
 },
 props: {
 type: {
  type: Number
 }
 }
};

復雜的邏輯變得非常簡單

四.JSX應用

使用jsx會讓代碼看起來更加簡潔、易于讀取

export default {
 render(h) {
 const tag = "h" + this.type;
 return <tag>{this.$slots.default}</tag>;
 },
 props: {
 type: {
  type: Number
 }
 }
};

五.render方法定制組件

編寫List組件,可以根據(jù)用戶傳入的數(shù)據(jù)自動循環(huán)列表

<List :data="data"></List>
<script>
import List from "./components/List";
export default {
 data() {
 return { 
  data: ["蘋果", "香蕉", "橘子"] 
 };
 },
 components: {
 List
 }
};
</script>

<!-- List組件渲染列表 -->
<template>
 <div class="list">
 <ul v-for="(item,index) in data" :key="index">
  <li>{{item}}</li>
 </ul>
 </div>
</template>
<script>
export default {
 props: {
 data: Array,
 default: () => []
 }
};
</script>

通過render方法來定制組件,在父組件中傳入render方法

<List :data="data" :render="render"></List>
render(h, name) {
  return <span>{name}</span>;
}

我們需要createElement方法,就會想到可以編寫個函數(shù)組件,將createElement方法傳遞出來

<template>
 <div class="list">
 <div v-for="(item,index) in data" :key="index">
  <li v-if="!render">{{item}}</li>
  <!-- 將render方法傳到函數(shù)組件中,將渲染項傳入到組件中,在內(nèi)部回調(diào)這個render方法 -->
  <ListItem v-else :item="item" :render="render"></ListItem>
 </div>
 </div>
</template>
<script>
import ListItem from "./ListItem";
export default {
 components: {
 ListItem
 },
 props: {
 render: {
  type: Function
 },
 data: Array,
 default: () => []
 }
};
</script>

ListItem.vue調(diào)用最外層的render方法,將createElement和當前項傳遞出來

<script>
export default {
 props: {
 render: {
  type: Function
 },
 item: {}
 },
 render(h) {
 return this.render(h, this.item);
 }
};
</script>

六.scope-slot

使用v-slot 將內(nèi)部值傳入即可

<List :arr="arr">
  <template v-slot="{item}">
    {{item}}
  </template>
</List>

<div v-for="(item,key) in arr" :key="key">
  <slot :item="item"></slot>
</div>

七.編寫可編輯表格

基于iview使用jsx擴展成可編輯的表格

<template>
<div>
 <Table :columns="columns" :data="data"></Table>
</div>
</template>
<script>
import Vue from 'vue';
export default {
 methods:{
  render(h,{column,index,row}){
   let value = row[column.key];
   return <div on-click={(e)=>this.changeIndex(e,index)} >
    {this.index === index ? 
     <i-input type="text" value={value} on-input={(value)=>{
      this.handleChange(value,column,row)
     }} onOn-enter={()=>this.enter(row,index)}/>:
     <span>{value}</span>
    }
   </div>
  },
  enter(row,index){
   this.data.splice(index,1,row);
   this.index = -1;
  },
  handleChange(value,column,row){
   row[column['key']]= value;
  },
  changeIndex(e,index){
   this.index = index;
   this.$nextTick(()=>{
    e.currentTarget.getElementsByTagName("input")[0].focus();
   })
  }
 },
 data() {
  return {
   index:-1,
   columns: [
    {
     title: 'Name',
     key: 'name',
     render:this.render
    },
    {
     title: 'Age',
     key: 'age',
    },
    {
     title: 'Address',
     key: 'address',
    },
   ],
   data: [
    {
     name: 'John Brown',
     age: 18,
     address: 'New York No. 1 Lake Park',
     date: '2016-10-03',
    },
    {
     name: 'Jim Green',
     age: 24,
     address: 'London No. 1 Lake Park',
     date: '2016-10-01',
    },
    {
     name: 'Joe Black',
     age: 30,
     address: 'Sydney No. 1 Lake Park',
     date: '2016-10-02',
    },
    {
     name: 'Jon Snow',
     age: 26,
     address: 'Ottawa No. 2 Lake Park',
     date: '2016-10-04',
    },
   ],
  };
 },
};
</script>

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

相關(guān)文章

  • js設(shè)置隨機切換背景圖片的簡單實例

    js設(shè)置隨機切換背景圖片的簡單實例

    下面小編就為大家?guī)硪黄猨s設(shè)置隨機切換背景圖片的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • layer彈出層取消遮罩的方法

    layer彈出層取消遮罩的方法

    今天小編就為大家分享一篇layer彈出層取消遮罩的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • uni-app如何實現(xiàn)增量更新功能

    uni-app如何實現(xiàn)增量更新功能

    這篇文章主要介紹了uni-app如何實現(xiàn)增量更新功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-01-01
  • 深入淺析javascript中的作用域(推薦)

    深入淺析javascript中的作用域(推薦)

    js作用域是前端開發(fā)必掌握的基礎(chǔ)知識。這篇文章主要介紹了javascript中的作用域的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • JavaScript如何實現(xiàn)數(shù)組按屬性分組

    JavaScript如何實現(xiàn)數(shù)組按屬性分組

    在JavaScript中,有多種方法可以對數(shù)組按屬性進行分組,這篇文章主要為大家至少介紹了6種常見的方法,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-08-08
  • js實現(xiàn)登陸與注冊功能

    js實現(xiàn)登陸與注冊功能

    這篇文章主要為大家詳細介紹了js實現(xiàn)登陸與注冊功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • js中的getAttribute方法使用示例

    js中的getAttribute方法使用示例

    getAttribute()方法是一個函數(shù)。它只有一個參數(shù)——你打算查詢的屬性的名字,下面為大家介紹下其具體的使用
    2014-08-08
  • ES6 Iterator遍歷器原理,應用場景及相關(guān)常用知識拓展詳解

    ES6 Iterator遍歷器原理,應用場景及相關(guān)常用知識拓展詳解

    這篇文章主要介紹了ES6 Iterator遍歷器原理,應用場景及相關(guān)常用知識拓展,結(jié)合實例形式詳細分析了ES6 Iterator遍歷器具體原理、功能、用法、應用場景及知識拓展,需要的朋友可以參考下
    2020-02-02
  • layui對工具條進行選擇性的顯示方法

    layui對工具條進行選擇性的顯示方法

    今天小編就為大家分享一篇layui對工具條進行選擇性的顯示方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 微信小程序?qū)崿F(xiàn)簡單彈框效果

    微信小程序?qū)崿F(xiàn)簡單彈框效果

    這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)簡單彈框效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07

最新評論