@tenp/tsxvue
v1.0.7
Published
> 需要在tsconfig.json中配置的compilerOptions中配置strictFunctionTypes为false
Downloads
3
Readme
Tsx for vue
需要在tsconfig.json中配置的compilerOptions中配置strictFunctionTypes为false
{
"compilerOptions": {
"strictFunctionTypes": false
}
}
包含了大量从react中移植过来的对jsx的html类型声明,及css样式声明
默认导出一个继承自vue的类,可以通过此类来添加tsx下标签的属性效验
import TsxVue from '@tenp/tsxvue';
import { Component } from 'vue-property-decorator';
@Component
class User extends TsxVue<{ id: number, name?: string }> {
@Prop() private readonly id!: number;
@Prop() private readonly name!: string;
private render() {
return <div>hello,{this.name}</div>;
}
}
//Use
@Component({})
class About extends TsxVue {
private render() {
return <div class='about'>
<User id={1} />
</div>;
}
}
如果需要使自定义组件能够拥有id,style,props等功能,可以添加如下配置来支持
@Component
class Nq extends TsxVue<{ pid: number }, TsxVue.CommonAttrs> {
render(){
return <div>fffffff</div>
}
}
包含了对vue-hooks的ts声明文件及对element-ui的tsx声明文件
element-ui的声明,需要在src目录下,创建一个xx.d.ts文件,在文件中引入如下代码,即可以实现element-ui的tsx支持, element-ui的tsx支持,是根据官方给出的对应版本的ts声明创建的,因此可能不完全
/// <reference path="../node_modules/@tenp/tsxvue/element-ui/[email protected]" />
//或者
/// <reference path="../node_modules/@tenp/tsxvue/element-ui/index.d.ts" />
目前已有的element-ui版本