广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue.js之render函数使用详解
  • 282
分享到

Vue.js之render函数使用详解

2024-04-02 19:04:59 282人浏览 薄情痞子
摘要

Vue 推荐在绝大多数情况下使用 template 来创建你的 html。然而在一些场景中,你真的需要 javascript的完全编程的能力,这就是 render 函数,它比 te

Vue 推荐在绝大多数情况下使用 template 来创建你的 html。然而在一些场景中,你真的需要 javascript的完全编程的能力,这就是 render 函数,它比 template 更接近编译器。

在 HTML 层, 我们决定这样定义组件接口:通过传入不同的level 1-6 生成h1-h6标签,和使用slot生成内容


<div id="div1">
    <child :level="1">Hello world!</child>
</div>

<script type="text/x-template" id="child-template">
  <h1 v-if="level === 1">
    <slot></slot>
  </h1>
  <h2 v-if="level === 2">
    <slot></slot>
  </h2>
  <h3 v-if="level === 3">
    <slot></slot>
  </h3>
  <h4 v-if="level === 4">
    <slot></slot>
  </h4>
  <h5 v-if="level === 5">
    <slot></slot>
  </h5>
  <h6 v-if="level === 6">
    <slot></slot>
  </h6>
</script>

<script type="text/javascript">
    

    Vue.component('child', {
      template: '#child-template',
      props: {
        level: {
          type: Number,
          required: true
        }
      },
      data: function() {
        return {
          a: 1
        }
      }
    })

    new Vue({
        el:"#div1"
    })
  </script>

我们尝试使用render函数实现上面的例子,注意使用render函数,template 选项将被忽略。

createElement接收3个参数:

第一个参数可以是HTML标签名,组件或者函数都可以;此参数是必须的;
第二个为数据对象{Object}(可选);

示例如下:


<div id="div1">
    <child :level="1">
        Hello world!
    </child>
    <child :level="2">
        <!-- 将不会被显示 -->
        <span slot="footer">this is footer slot</span>
        <p slot="header">this is header slot</p>
    </child>
</div>


<script>
    Vue.component('child', {
        render: function (createElement) {
            console.log(this.$slots);
            return createElement(
                'h' + this.level, // tagName标签名称
                {
                    // 为每个h标签设置class
                    'class': {
                        foo: true,
                        bar: false
                    },
                    // 最终被渲染为内联样式
                    style: {
                        color: 'red',
                        fontSize: '14px'
                    },
                    // 其他的html属性
                    attrs: {
                        id: 'foo',
                        'data-id': 'bar'
                    },
                    // DOM属性
                    domProps: {
                        // innerHTML: 'from domProps',
                    },
                    // 事件监听器基于 "on"
                    // 所以不再支持如 v-on:keyup.enter 修饰器
                    on: {
                        click: this.clickHandler
                    },
                    // ...
                },
                // 你可以从this.$slots获取Vnodes列表中的静态内容
                // $slots.default用来访问组件的不具名slot
                // 当你可能需要具名slot的时候需要指定slot的name, this.$slots.header
                // [this.$slots.default,this.$slots.footer,this.$slots.header] //显示level2插槽
                [this.$slots.default]  //只显示不具名slot
            )
        },
        template: '<div v-if="level===1"><slot></slot></div>', // 将被忽略
        props: {
            level: {
                type: Number,
                required: true
            }
        },
        methods: {
            clickHandler: function () {
                console.log('clickHandler')
            }
        }
    })

    new Vue({
        el: "#div1"
    })
</script>

渲染如下:

这里写图片描述

到此这篇关于vue.js之render函数使用详解的文章就介绍到这了,更多相关Vue.js之render函数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Vue.js之render函数使用详解

本文链接: https://www.lsjlt.com/news/135582.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vue.js之render函数使用详解
    Vue 推荐在绝大多数情况下使用 template 来创建你的 HTML。然而在一些场景中,你真的需要 JavaScript的完全编程的能力,这就是 render 函数,它比 te...
    99+
    2022-11-12
  • 详解Django中 render() 函数的使用方法
    render() 函数 在讲 render() 函数之前,我们在 Django 项目 index 文件夹的 urls.py 和 views.py 中编写如下功能代码:(不难,望读者细...
    99+
    2022-11-12
  • vue中的render函数、h()函数、函数式组件详解
    目录一、什么是render二、vue中的render三、函数式组件补充 h函数使用场景一、什么是render 官网:用于编程式地创建组件虚拟 DOM 树的函数。 在我们使用webpa...
    99+
    2023-02-09
    vue render函数 vue  h()函数 vue函数式组件
  • 详解Python之find函数的使用
    目录          一、find函数的官方定义          二、find函数的详细函数使用解释 一、find函数的官方定义 首先,Python的find函数多用在字符串的处理上,也是Python计算机二级的小考点。 定义:P...
    99+
    2023-10-12
    python
  • vue如何使用render函数
    这篇文章主要介绍了vue如何使用render函数,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。render 函数在某些场景下你可能需要ren...
    99+
    2022-10-19
  • linux shell 编程之函数使用详解
    目录前言shell 函数分类系统函数1、basename语法简单案例2、dirname语法简单案例自定义函数语法语法说明注意点案例1:无参无返回值函数案例2:无参有返回值函数案例3:有参函数案例介绍补充:Shell程序与...
    99+
    2022-10-28
  • linux shell 编程之函数使用详解
    目录前言shell 函数分类系统函数1、basename语法简单案例2、dirname语法简单案例自定义函数语法语法说明注意点案例1:无参无返回值函数案例2:无参有返回值函数案例3:...
    99+
    2022-11-13
    linux shell 函数使用 linux shell 函数
  • kotlin协程之coroutineScope函数使用详解
    目录正文代码分析正文 public suspend fun <R> coroutineScope(block: suspend CoroutineScope.() -&g...
    99+
    2022-11-13
  • PHP函数之日期时间函数date()使用详解
    日期时间函数是PHP 的核心组成部分。无需安装即可使用这些函数。下面来详细说说date函数的具体用法: PHP Date() 函数PHP Date() 函数可把时间戳格式化为可读性更...
    99+
    2022-11-15
    日期时间函数 date
  • vue中Render函数怎么使用
    这篇文章主要介绍“vue中Render函数怎么使用”,在日常操作中,相信很多人在vue中Render函数怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中Render函数怎么使用”的疑惑有所帮助!...
    99+
    2023-07-04
  • 实例详解vue render函数中如何修改props
    Vue的render函数是一个很强大的工具,可以帮助我们更加自由地创建组件并渲染页面,并且在某些场景下render函数也可以帮我们提升一些性能。在一些情况下,我们希望在render函数中修改props,那么该怎么做呢?下面来一起看看。在我们...
    99+
    2023-05-14
  • Java8之Function函数、BiFunction函数详解
    众所周知,Java8提供了一下非常重要的函数式接口。今天我们就来讲讲其中一个函数式接口-----Function接口。 下面的代码就是Function接口的全部代码。接下来我们逐个分析一下。 @Fun...
    99+
    2023-08-31
    Java Function BiFunction 新特性
  • Python之map()函数详解
    文章目录 一、map() 函数简介1.1 map() 函数基本语法1.2 map() 函数+ lambda表达式1.3 map() 函数输入多个可迭代对象iterable1.4 查看返回的迭代...
    99+
    2023-09-24
    python 开发语言
  • JQuery之each函数详解
    JQuery的each()函数是用来遍历一个集合(如数组或对象)的方法。它可以用于循环遍历每个元素,并对每个元素执行特定的操作。语法...
    99+
    2023-09-23
    JQuery
  • Java之Pattern.compile函数用法详解
    除了Pattern Pattern.compile(String regex), Pattern类的compile()方法还有另一个版本: Pattern Pattern.compl...
    99+
    2022-11-12
  • python内置函数之eval函数详解
    目录一、简介二、语法三、举例1、计算str表达式的值2、将str转换成list3、将str转换成dict四、Reference总结一、简介 eval()函数用来执行一个字符表达式的值...
    99+
    2022-11-12
  • Python数据分析之NumPy常用函数使用详解
    目录文件读入1、保存或创建新文件 2、读取csv文件的函数loadtxt3、常见的函数4、股票的收益率等5、对数收益与波动率6、日期分析总结本篇我们将以分析历史股价为例,介...
    99+
    2022-11-11
  • Python必备技巧之函数的使用详解
    目录1.如何用函数2.默认参数陷阱2.1针对可变数据类型,不可变不受影响3.名称空间和作用域4.闭包函数5.函数的参数5.1定义阶段5.2调用阶段6.装饰器:闭包函数的应用6.1装饰...
    99+
    2022-11-13
  • socket编程之bind()函数使用示例详解
    目录正文端口号具体是怎么绑定老代码端口被占用的问题解决正文 当你创建了socket之后,你会想要把这个socket和你本机上的某个端口号(port)进行关联。 端口号是内核用来确认将...
    99+
    2022-11-13
    socket编程bind函数 socket bind
  • Python学习之字符串函数使用详解
    目录1 搜索字符串函数2 设置字符串格式函数3 改变字符串大小写函数4 选定字符串函数5 拆分字符串函数6 替换字符串函数Python的友好在于提供了非常好强大的功能函数模块,对于字...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作