架构参考element-ui
tsconfig.json
- Typescript项目配置文件
- 命令行执行tsc后,会根据该配置文件将项目中的ts编译为js
选项 | 类型 | 默认值 | 描述 | --declaration -d | boolean | false | 生成相应的 .d.ts 文件。 | --declarationDir | string | | 生成声明文件的输出路径。 | --sourceMap | boolean | false | 生成相应的 .map 文件。 |
vue.shim.d.ts
/**
* vue.shim.d.ts的作用
* 为了typescript做的适配定义文件,因为.vue文件不是一个常规的文件类型,* ts是不能理解* vue文件是干嘛的,
* 加这一段是告诉ts,vue文件是这种类型。
* 可以把这一段删除,会发现import的所有vue类型的文件都会报错。
**/
declare module '*.vue' {
import { App, defineComponent } from 'vue'
const component: ReturnType<typeof defineComponent> & {
install(app: App) : void
}
export default component
}
package.json配置vue
"peerDependencies": {
"vue": "^3.0.9"
},
peerDependencies
的目的是提示宿主环境去安装满足插件peerDependencies所指定依赖的包,然后在插件import或者require所依赖的包的时候,永远都是引用宿主环境统一安装的npm包,最终解决插件与所依赖包不一致的问题。
- 白话:假如组件库工程安装了vue,业务项目工程中也安装了vue;代码运行时,组件库和业务项目各自调用的vue不是同一个,导致参数传递失败。
webpack配置文件配置babel-loader,处理ts、es6
{
test: /\.(ts|js)x?$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
presets: [
'@babel/preset-env',[
'@babel/preset-typescript',
{
allExtensions: true
}
]
]
}
}
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
- 找不到素材资源介绍文章里的示例图片?
- 对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
- 模板不会安装或需要功能定制以及二次开发?
- 请QQ联系我们
发表评论
还没有评论,快来抢沙发吧!