# 快速开始
Press UI
目前支持n+1
端,n
为uni-app
提供的能力,包括H5、微信小程序、QQ小程序等,1
为普通 Vue 项目。并且同时兼容 Vue2 和 Vue3。
# 1. Vue2 的 uni-app 项目
对于 Vue2 的 uni-app
项目,Press UI
的使用方法如下。
# 1.1. npm 模式
- 安装
npm
包
npm i press-ui
- 在页面中正常引入并使用
比如 button
组件:
<template>
<PressButton>
按钮
</PressButton>
</template>
<script>
import PressButton from 'press-ui/press-button/press-button.vue'
export default {
components: {
PressButton,
}
}
</script>
- 配置
注意,需要在 vue.config.js
中配置下 transpileDependencies
:
module.exports = {
transpileDependencies: ['press-ui'],
}
点此查看 (opens new window) Vue2 的 uni-app 示例项目。
# 1.2. uni_modules 方式
插件市场 (opens new window)直接导入即可
# 2. 普通 Vue2 项目
Press UI
支持非 uni-app
的普通 Vue 项目。
Press UI
组件比普通的组件多了以下内容:
- 条件编译,跨平台的核心,普通 Vue 项目中可以用这个 loader (opens new window) 实现
scroll-view
、swiper
、swiper-item
等全局组件
所以,要在普通Vue项目中使用 Press UI
,除了执行上面的步骤外,还需要做下面几个事情。
- 安装 npm 包:
npm i @plugin-light/webpack-loader-ifdef -D
- 在
vue.config.js
中添加如下设置:
const IF_DEF_LOADER = '@plugin-light/webpack-loader-ifdef';
module.export = {
chainWebpack(config) {
config.module
.rule('ifdef-loader')
// 根据项目实际配置文件类型
.test(/press-ui.*(\.vue|\.ts|\.js|\.css|\.scss)$/)
.use(IF_DEF_LOADER)
.loader(IF_DEF_LOADER)
.options({
context: { H5: true },
type: ['css', 'js', 'html'],
})
.end();
}
}
- 引入全局组件,可以直接使用
Press UI
封装好的方法。
// main.js
import { initPureAdapter } from 'press-ui/common/pure/adapter';
initPureAdapter();
此外,针对非 uni-app
环境的 Vue 项目,在函数式调用组件时,需要传入 context: this
,比如:
import { imagePreview } from 'press-ui/press-image-preview/index';
export default {
methods: {
show() {
imagePreview({
context: this,
selector: `#${FUNCTIONAL_ID_MAP.IMAGE_PREVIEW}`,
images: this.images,
})
}
}
}
Press UI
支持函数式调用的组件有:
点此查看 (opens new window) Vue2 非 uni-app 的示例项目。
# 3. Vue3 的 uni-app 项目
Press UI
支持 Vue3 项目。
对于 Vue3 的 uni-app
项目,在函数式调用组件时,需传入ref
,而非id
。
之前:
<press-popup
:id="PRESS_PICKER_ID"
mode="functional"
>
xxx
</press-popup>
现在:
<press-popup
:ref="PRESS_PICKER_ID"
mode="functional"
>
xxx
</press-popup>
另外,对于以下组件,在 Vue3 下做了 v-model
相关的适配,具体使用变化为: value
属性改为 modelValue
,input
事件改为 update:modelValue
。如果是使用的 v-model
,则无需改变。
点此查看 (opens new window) Vue3 的 uni-app 示例项目。
# 4. 普通 Vue3 项目
Vite 中不支持 transpileDependencies
选项,Press UI
提供了使用方案:
- 脚本拷贝
node_modules/press-ui
的代码到src
某目录下 - 配置
alias
指向该目录
这种方式符合 transpileDependencies
的本意,既然作为源码来编译,那就直接放到源码位置即可。
这里提供了一个 Vite 插件 (opens new window),可以自动化的进行拷贝。
点此查看 (opens new window) Vue3 非 uni-app 的示例项目。