# 快速开始

Press UI 目前支持n+1端,nuni-app提供的能力,包括H5、微信小程序、QQ小程序等,1为普通 Vue 项目。并且同时兼容 Vue2 和 Vue3。

# 1. Vue2 的 uni-app 项目

对于 Vue2 的 uni-app 项目,Press UI 的使用方法如下。

# 1.1. npm 模式

  1. 安装npm
npm i press-ui
  1. 在页面中正常引入并使用

比如 button 组件:

<template>
  <PressButton>
    按钮
  </PressButton>
</template>
<script>
import PressButton from 'press-ui/press-button/press-button.vue'

export default {
  components: {
    PressButton, 
  }
}
</script>
  1. 配置

注意,需要在 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 组件比普通的组件多了以下内容:

  1. 条件编译,跨平台的核心,普通 Vue 项目中可以用这个 loader (opens new window) 实现
  2. scroll-viewswiperswiper-item 等全局组件

所以,要在普通Vue项目中使用 Press UI,除了执行上面的步骤外,还需要做下面几个事情。

  1. 安装 npm 包:
npm i @plugin-light/webpack-loader-ifdef -D
  1. 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();
  }
}
  1. 引入全局组件,可以直接使用 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 属性改为 modelValueinput 事件改为 update:modelValue。如果是使用的 v-model,则无需改变。

点此查看 (opens new window) Vue3 的 uni-app 示例项目。

# 4. 普通 Vue3 项目

Vite 中不支持 transpileDependencies 选项,Press UI 提供了使用方案:

  1. 脚本拷贝 node_modules/press-ui 的代码到 src 某目录下
  2. 配置 alias 指向该目录

这种方式符合 transpileDependencies 的本意,既然作为源码来编译,那就直接放到源码位置即可。

这里提供了一个 Vite 插件 (opens new window),可以自动化的进行拷贝。

点此查看 (opens new window) Vue3 非 uni-app 的示例项目。

横屏
最后更新时间: 2024/12/19 13:43:12