在vue3中使用jsx的配置以及一些小问题
配置
在vue3中使用jsx十分方便,只需要安装官方的@vitejs/plugin-vue-jsx
插件,在vite.config.ts
中配置
// vite.config.ts
import vueJsx from "@vitejs/plugin-vue-jsx";
export default {
plugins: [vueJsx()]
}
配置了
vite.config.ts
后虽然已经可以使用jsx,页面也正常渲染了,但是还是会提示无法使用jsx,此时还需要在tsconfig.ts
中配置"jsx": "preserve"
属性,就可以愉快的使用jsx形式来写vue了。文章图片
// tsconfig.ts
{
"jsx": "preserve",
}
模版语法 使用jsx时setup需要返回一个函数,函数返回jsx形式。不过使用jsx形式也有不好的地方,在使用数据就比较烦,不能像模版中一样直接使用,需要加上
.value
,虽然新的volar插件已经会自动添加.value了,但还是很难受,一不小心就会忘记写。
v-if/v-show
还有不太方便的一个点就是v-if无法使用,jsx中得使用三元表达式,但是三元感觉看起来不是很舒服
export default defineComponent({
setup() {
const msg = ref("tsx component");
const isShow = ref(false);
function onClick() {
isShow.value = https://www.it610.com/article/!isShow.value;
}return () => {
return ({msg.value}
{isShow.value && {isShow.value ? "show" : "hide"}}
onClick );
};
},
});
如果直接使用v-if就会报错
无法读取未定义的属性
文章图片
但是
v-show
是可以使用的,但v-if
不行,不知道为什么,可能是直接jsx默认推荐使用isShow &&
或者三元的形式吧
{msg.value}
{isShow.value && {isShow.value ? "show" : "hide"}}
{isShow.value ? "show" : "hide"}
onClick
v-show正确显示出了show div,dom中也是通过display做的显影,三元则是创建和销毁的dom
文章图片
【在vue3中使用jsx的配置以及一些小问题】
v-for
就更不用想了,就用map吧,map也挺好用的,不过v-model
还是可以使用的,显示也正常export default defineComponent({
setup() {
const msg = ref("tsx component");
return () => {
return ({msg.value}
);
};
},
});
推荐阅读
- 见证中国云势力崛起!博睿数据实力入围2021~2022 Cloud 100 榜单
- 首届腾讯数字安全创新大赛在京启动,挖掘新锐力量推动产业创新
- 谷歌以54亿美元收购网络安全公司、数百万惠普设备存在高危漏洞|3月10日全球网络安全热点
- 【FAQ】接入HMS|【FAQ】接入HMS Core推送服务过程中一些常见问题总结
- 腾讯安全发布《容器安全在野攻击调查》
- 在SpringBoot项目中实现给所有请求加固定前缀
- Python中缓存lru_cache的基本介绍和讲解
- Spring|Spring Kafka中如何通过参数配置解决超时问题详解
- java中的GC收集器详情
- C#中Invoke的用法讲解