问答

vue functional 组件,导致渲染死循环。

作者:admin 2021-07-30 我要评论

如题,不明白为什么下面的代码会导致循环渲染。 vue version: 2.6.* 代码如下: template div smart-list :items="items"/smart-list /div/templatescriptimport...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

如题,不明白为什么下面的代码会导致循环渲染。

vue version: 2.6.*

代码如下:

<template>
  <div>
    <smart-list :items="items"></smart-list>
  </div>
</template>
<script>
import Vue from 'vue'
const components = (name) => import(`./components/EmptyList.vue`).then(m => m.default || m)
Vue.component('smart-list', {
  functional: true,
  props: {
    items: {
      type: Array,
      required: true
    },
    isOrdered: Boolean
  },
  render: function (createElement, context) {
    function appropriateListComponent() {
      var items = context.props.items
      if (items.length === 0) return async () => await components('EmptyList')
      if (typeof items[0] === 'object') return async () => await components('TableList')
      if (context.props.isOrdered) return async () => await components('OrderedList')
      return async () => await components('UnorderedList')
    }

    return createElement(
      appropriateListComponent(),
      context.data,
      context.children
    )
  }
})

export default {
  data: () => ({ items: [] })
}
</script>

./components/EmptyList.vue 里面代码:

<template>
    <div>EmptyList</div>
</template>

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • vue functional 组件,导致渲染死循环

    vue functional 组件,导致渲染死循环

  • 为什么说所有的iphone的ideal viewport

    为什么说所有的iphone的ideal viewport

  • 使用PLVideoTextureView,在视频缓冲过

    使用PLVideoTextureView,在视频缓冲过

  • js如何处理树形数据如何从最末级向上递

    js如何处理树形数据如何从最末级向上递

腾讯云代理商
海外云服务器