vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > Vue3手机外观组件库

Vue3手机外观组件库超详细代码示例

作者:早发白帝城

vue作为一款深受广大群众喜欢的前端框架,拥有众多优秀的开源UI组件库,这篇文章主要介绍了Vue3手机外观组件库的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

前言

前一段时间开发了一个移动端画布编辑器,为了方便在真机上预览效果,抽离了手机外观组件库。这个库可以帮助开发者快速创建手机 UI 模拟器,支持多种机型和灵活的配置选项。

一个专为 Vue 3 设计的手机外观组件库,使用 TypeScript 开发,支持多机型预设和完全自定义外观。

⚠️ 本组件所有机型外观均为演示效果,并非真实手机尺寸,仅供开发测试参考!

特点

演示

实际项目演示,左边编辑,右边预览,完美。

安装

npm install @scqilin/phone-ui-vue

快速开始

全局注册(推荐)

// main.ts
import { createApp } from 'vue'
import PhoneUIVue from '@scqilin/phone-ui-vue'
import App from './App.vue'

const app = createApp(App)
app.use(PhoneUIVue)
app.mount('#app')

局部引入

// 组件内使用
import { PhoneUI } from '@scqilin/phone-ui-vue'

使用示例

预设机型

<template>
  <PhoneUI 
    phoneType="iphone16pro"
    frameColor="#111"
    screenColor="#fff"
    :showButtons="true"
  >
    <!-- 在这里放置你的应用内容 -->
    <div class="my-app">
      <header>我的应用头部</header>
      <main>
        <h1>欢迎使用</h1>
        <p>这里是应用内容</p>
        <MyComponent />
      </main>
      <footer>底部导航</footer>
    </div>
  </PhoneUI>
</template>

预设机型 + 覆盖配置

<template>
  <PhoneUI 
    phoneType="iphone16"
    :width="400"
    :borderRadius="30"
    frameColor="#333"
    notchType="0"
  >
    <!-- 使用 iPhone 16 预设,但覆盖部分配置 -->
    <MyCustomContent />
  </PhoneUI>
</template>

完全自定义机型

<template>
  <PhoneUI 
    phoneType="custom"
    :width="375"
    :height="812"
    frameColor="#003e9f"
    screenColor="#f0f8ff"
    :showButtons="true"
    :borderRadius="25"
    :frameWidth="12"
    notchType="1"
  >
    <CustomAppContent />
  </PhoneUI>
</template>

创建新机型

<template>
  <PhoneUI 
    phoneType="xiaomi14"
    :width="360"
    :height="780"
    :borderRadius="20"
    notchType="0"
    :buttonConfig="{
      left: [{ top: 100, height: 30 }],
      right: [{ top: 120, height: 50 }]
    }"
  >
    <XiaomiContent />
  </PhoneUI>
</template>

API 文档

Props

属性类型默认值说明
phoneTypestring'custom'手机机型标识,支持预设机型或自定义名称
widthnumber393屏幕宽度,可覆盖预设配置
heightnumber852屏幕高度,可覆盖预设配置
frameColorstring'#1a1a1a'手机边框颜色
screenColorstring'#ffffff'屏幕背景颜色
showButtonsbooleantrue是否显示侧边按钮
borderRadiusnumber22边框圆角大小,可覆盖预设配置
frameWidthnumber16边框宽度(包含屏幕黑边+物理边框)
notchTypestring'0'灵动岛类型:'0'无灵动岛,'1'椭圆形灵动岛
buttonConfigobject{left:[], right:[]}按钮配置,可覆盖预设配置

插槽

名称说明
default屏幕内容区域,可放置任意 Vue 组件

支持的机型

机型phoneType 值屏幕尺寸灵动岛
iPhone 16'iphone16'393×852
iPhone 16 Plus'iphone16plus'430×932
iPhone 16 Pro'iphone16pro'402×874
iPhone 16 Pro Max'iphone16promax'440×956
自定义机型'custom' 或任意字符串自定义可选

使用说明

配置优先级

组件使用智能配置合并系统:

  1. 用户传入的 props(最高优先级)
  2. 预设机型配置(如果 phoneType 在库中存在)
  3. 默认配置(兜底配置)

预设机型模式

自定义机型模式

灵动岛类型

按钮配置

buttonConfig: {
  left: [
    { top: 100, height: 30 }, // 按钮位置和高度
    { top: 150, height: 40 }
  ],
  right: [
    { top: 120, height: 50 }
  ]
}

插槽内容

样式自定义

组件使用 scoped CSS,不会影响全局样式。如需深度自定义样式,可以通过以下方式:

<style>
/* 自定义屏幕内容样式 */
.phone-content {
  /* 您的自定义样式 */
}
</style>

开发与构建

# 克隆项目
git clone https://github.com/scqilin/phone-ui-vue.git

# 安装依赖
npm install

# 开发模式
npm run dev

# 构建库文件
npm run build:lib

# 预览
npm run preview

# 发布到 npm
npm publish --access public

注意事项

  1. 需要 Vue 3.0+ 版本
  2. 按钮为装饰性元素,不提供点击交互功能
  3. 组件会自动适配内容高度,建议为内容设置适当的 CSS
  4. 在移动端使用时,建议设置合适的缩放比例

总结

到此这篇关于Vue3手机外观组件库的文章就介绍到这了,更多相关Vue3手机外观组件库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文