vue使用jsx的多种方式分别是什么,是怎样的
Admin 2022-08-09 群英技术资讯 751 次浏览
这篇文章主要讲解了“vue使用jsx的多种方式分别是什么,是怎样的”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue使用jsx的多种方式分别是什么,是怎样的”吧!render函数和vue中的template是互斥的,template最终是要编译成virtual Dom的,而render函数可以更直接构建virtual Dom; virtual Dom由树状的vnode构成,h函数可以构建vnode
vue templates are compiled into virtual DOM render functions. vue also provides APIs that allow us to skip the template compilation step and directly author render functions
If both render and template are present in a component, render will take higher priority.
如果render和template同时出现,render会有更高的权限(vue2不太一样,下面会说)。
这些在文档中有更直接的说明vue3 render函数
jsx类似于h函数,都是更直接使用javascript来构建DOM,需要注意的是jsx语法需要去编译处理,有的脚手架可能有预先配置,有的没有。
在typescript下需要编写tsx
When not using a build step, a Vue component can be >defined as a plain JavaScript object containing >Vue-specific options:
vue组件也可以直接使用普通的js对象来注册
// 定义一个js文件,导出组件对象
// componentObject.js
export default {
data() {
return {
msg: 'hello'
}
},
created() {
setTimeout(() => {
this.msg = 'hello world'
}, 1000);
},
render() {
return <h1>{this.msg}</h1>
}
}
<script>
import componentObject from './../components/componentObject.js'
export default {
components: {
jsxComponent
}
};
</script>
这里如果template和render函数如果同时指定的话,会用template覆盖掉render,显然是template优先级更高,跟文档上的render优先级更高不一样
// sfcJsx.vue
<!-- <template>
<div>test</div>
</template> -->
<script>
export default {
data() {
return {
msg: 'i am sfc jsx'
}
},
created() {
setTimeout(() => {
this.msg = 'i am sfc jsxxxx'
}, 1000);
},
render() {
return <h1>{this.msg}</h1>
}
}
</script>
目前在setup中return jsx会报错,目测是loader没有支持(有知道解决办法的老师傅也可以告诉我一下..),只能在setup使用compositionApi再加上render函数里写jsx
// sfcJsx.vue
<script>
import { ref } from 'vue';
export default {
setup() {
const count = ref(0);
setTimeout(() => {
count.value = 12
}, 1000);
return {
count
}
},
render(h) {
return (
<h1>{this.count ? <span>11</span>: <span>22</span>}</h1>
)
}
}
</script>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Javascript生成器是什么?对于新手来说,可能对Javascript生成器比较陌生,因此这篇文章就给大家介绍一下Javascript生成器的概念以及用法。感兴趣的朋友就往下看吧。
这篇文章给大家分享的是用JS实现重置功能的方法。对于重置的功能大家应该都不陌生,当网页填写的信息需要大量修改时,重置功能快速的重置页面,非常的方便。文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
目录前言例子1. 模块加载2. jsonp动态加载script3. 执行异步脚本4. webpackJsonpCallback5. 执行异步模块代码流程图总结前言在vue中我们经常用到动态导入页面组件,那么它是如何实现的呢,本文将通过简单的案例,快速了解实现原理例子// index.jsimport(./test).t
这篇文章主要介绍了vue自定义keepalive组件的相关资料,keep-alive组件是使用 include exclude这两个属性传入组件名称来确认哪些可以被缓存的,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
这篇文章主要为大家详细介绍了js仿淘宝放大镜效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008