1.前言

我抵赖了我是题目党,本篇文章是在vue我的项目里写tsx的一篇介绍。作为一个reacter,目前的业务天天应用vue2+ts让我非常的不难受。我对于vue也不是很相熟,想回到我的react时代。于是在查问官网之后发现在vue外面写jsx也挺有意思的,遂记录。

2.注释

vue2+ts的我的项目配置这里就不开展了,网上一搜一大推。

index.vue是页面路由,寄存各个组件和专用逻辑。components文件夹中寄存我的tsx组件。

接下来就开始写tsx。

你能够间接创立jsx/tsx文件

这次的我的项目构造是这样的:

在vue文件里这么应用

// index.vue<template>  <div class="wrapper">    <Common :opt="list" />  </div></template> <script lang="ts">import { Component, Vue } from "vue-property-decorator";import Common from "./components/Common";@Component({  name: "App",  components: {    Common,  },})export default class App extends Vue {  private list = ["我要去淘宝", "我要去百度", "我要去京东"];}</script>

tsx这么写

import { CreateElement } from 'vue';import { Component, Vue, Prop } from 'vue-property-decorator';@Component({    name: 'Common'})export default class Common extends Vue {    @Prop(Object) opt!: any[]    render(h: CreateElement) {        return <span>            {                this.opt.map((it) => {                    return <span style="marginRight:10px">{it}</span>                })            }        </span>    }}

在来看一下页面

这该死的react既视感,竟是如此的迷人

可能有心者留神到了 我还援用了一个CreateElement,这是干嘛的呢。这玩意叫渲染函数。不喜爱读vue那么大串的文档的兄弟看这里。简略解释:这个货色能够渲染一个vnode节点。它比模板更靠近编译器。什么意思呢?意思就是模板语法也会编译成渲染函数。所以咱们间接用渲染函数不就相当于节俭了模板语法到渲染函数的过程。四舍五入我的项目性能又是一个大的晋升!

简略介绍一下传参:

第一个参数: {String | Object | Function} 一个 HTML 标签名、组件选项对象,或者 resolve 了上述任何一种的一个 async 函数。必填项。

第二个参数: Object 一个与模板中 attribute 对应的数据对象。

第三个参数: {String | Array} 文本节点或子级虚构节点 (VNodes)。

渲染函数给vue带来了很多的灵活性,以前你想自定义在子组件里插入货色,得写一大堆的插槽。<slot>。有了渲染函数咱们能够这么玩。

// 革新一下下面的index.vue的data  private list = [    { render: () => ["a", { style: { color: "red" } }, "我要去淘宝"] },    { render: () => ["a", { style: { color: "green" } }, "我要去京东"] },    { render: () => ["a", { style: { color: "pink" } }, "我要去百度"] },  ];

tsx中这么写:

  {                this.opt.map((it) => {                    return h(...it.render())                })            }

就能够渲染出花里胡哨的页面了

咱们还能够这么玩:

// tsx革新<span>            {                this.opt.map((it) => {                    return it.render(h)                })            }</span>在index.vue页面咱们就能够这么玩:// index.vueprivate list = [    {      render: (h: CreateElement) =>        h("a", { style: { color: "red", marginRight: "5px" } }, "我要去淘宝"),    },    {      render: (h: CreateElement) =>        h("a", { style: { color: "green", marginRight: "5px" } }, "我要去京东"),    },    {      render: (h: CreateElement) =>        h("a", { style: { color: "pink", marginRight: "5px" } }, "我要去百度"),    },  ];

后果也是同样的花哨

咱们同样能够渲染乌七八糟的标签!

// index.vue革新 {      render: (h: CreateElement) =>        h(          "h1",          {            style: { color: "green", marginRight: "5px" },          },          "我要去京东"        ),    },

咱们能够得心应手的在渲染函数中定义事件:

// index.vueprivate list = [   {      render: (h: CreateElement) =>        h(          "a",          {            style: { color: "red", marginRight: "5px" },            on: {              click: () => this.iWillGoWhere("TB"),            },          },          "我要去淘宝"        ),   }]    iWillGoWhere(type: string) {    const goWhere: any = {      TB: () => {        alert("我要去淘宝!");      },      JD: () => {        alert("我要去京东!");      },      BD: () => {        alert("我要去百度!");      },    };    goWhere[type]();  }

这样就能够啦!

结尾

本次文章是对vue灵活性应用的入门。请各位vue大佬不要喷我~