news 2026/4/16 12:17:01

uni-app x使用uview-plus

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
uni-app x使用uview-plus

一、概述

‌uView-Plus官网提供完整框架文档与资源下载‌,是兼容多端开发的uni-app生态框架,支持安卓、iOS、微信小程序等10个平台。

uView-Plus官网及框架概述

‌官网入口‌:主文档站(uiadmin.net)|GitHub Pages(ijry.github.io)。

包含组件文档、工具库说明及快速体验模板入口‌‌1‌‌2

‌核心特性‌:

基于uView2.0升级,支持Vue3组合式API开发。‌‌1

提供180+组件库,覆盖表单、布局、图表等场景。‌‌3

集成网络请求、路由跳转等工具库。‌‌4

‌多端兼容‌:

一次编写即可发布到Android、iOS、微信/QQ/支付宝小程序等10个平台,H5适配度达95%‌‌

官网地址:https://uview-plus.jiangruyi.com/

官网组件预览:https://uview-plus.jiangruyi.com/h5/#/

image

二、安装uview-plus

uview-plus是免费开源的,无需授权即可商用。

1.安装依赖

打开HBuilderX,新增终端标签卡

image

在项目根目录打开终端,执行

npm install uview-plus

npm install dayjs

npm install clipboard

2. 配置 main.js

在 main.js 中引入并使用 uview-plus:

复制代码

import App from './App.uvue'

import { createSSRApp } from 'vue'

import uviewPlus from 'uview-plus'

export function createApp() {

const app = createSSRApp(App)

app.use(uviewPlus)

return {

app

}

}

复制代码

3. 引入全局样式

在 uni.scss 中添加:

@import 'uview-plus/theme.scss';

最后一行,增加即可

在 App.vue 的 <style lang="scss"> 中添加:

@import 'uview-plus/index.scss';

App.vue默认没有scss,最后一行增加以下代码

<style lang="scss">

@import 'uview-plus/index.scss';

</style>

4. 配置 easycom 自动引入

在 pages.json 中添加:

复制代码

"easycom": {

"autoscan": true,

"custom": {

"^u--(.*)": "uview-plus/components/u-$1/u-$1.vue",

"^up-(.*)": "uview-plus/components/u-$1/u-$1.vue",

"^u-([^-].*)": "uview-plus/components/u-$1/u-$1.vue"

}

}

复制代码

最后几行,增加即可

5. 配置 manifest.json(可选)

如开发微信小程序,在 manifest.json 的源码视图中添加:

"mp-weixin": {

"mergeVirtualHostAttributes": true

}

6. 重启 HBuilderX

完成上述配置后,重启 HBuilderX 使配置生效。

7. 测试使用

在页面中直接使用组件,例如:

<u-button type="primary">测试按钮</u-button>

这里,直接在index.uvue里面,增加一行,例如:

复制代码

<template>

<view>

<image class="logo" src="/static/logo.png"></image>

<text class="title">{{title}}</text>

<u-button type="primary">测试按钮</u-button>

</view>

</template>

复制代码

运行,效果如下:

image

三、编写登录页面

在pages目录,新建一个文件夹login,然后在login里面,新增文件login.uvue,内容如下:

复制代码

<template>

<view class="">

<!-- 导航栏 -->

<u-navbar title="用户登录" />

<!-- 内容区 -->

<view class="content">

<!-- 头像 -->

<u-avatar :src="logo" size="80"></u-avatar>

<!-- 表单 -->

<u--form :model="form" labelPosition="left">

<u--input v-model="form.username" placeholder="请输入用户名" prefixIcon="account" />

<u--input v-model="form.password" placeholder="请输入密码" type="password" prefixIcon="lock" />

</u--form>

<!-- 按钮 -->

<u-button text="登录" type="primary" @click="login" :loading="loading" />

<!-- 链接 -->

<view class="links">

<u-cell title="忘记密码?" isLink @click="gotoForget" />

<u-cell title="注册账号" isLink @click="gotoRegister" />

</view>

</view>

</view>

</template>

<script>

export default {

data() {

return {

title: 'Hello',

logo: '/static/logo.png',

loading: false,

form: {

username: '',

password: '',

}

}

},

onLoad() {

},

methods: {

login() {

if (!this.form.username) {

uni.showToast({ title: '请输入用户名', icon: 'none' })

return

}

this.loading = true

// 模拟登录请求

setTimeout(() => {

this.loading = false

uni.showToast({ title: '登录成功' })

}, 1500)

},

gotoForget() {

uni.navigateTo({ url: '/pages/forget/index' })

},

gotoRegister() {

uni.navigateTo({ url: '/pages/register/index' })

}

}

}

</script>

<style scoped>

.content {

padding: 40rpx;

display: flex;

flex-direction: column;

align-items: center;

}

.links {

margin-top: 30rpx;

width: 100%;

}

</style>

复制代码

编辑文件pages.json,增加login路由

复制代码

"pages": [ //pages数组中第一项表示应用启动页,参考:https://doc.dcloud.net.cn/uni-app-x/collocation/pagesjson.html

{

"path": "pages/index/index",

"style": {

"navigationBarTitleText": "uni-app x"

}

},

{

"path": "pages/login/login"

}

]

复制代码

访问页面:http://localhost:5173/#/pages/login/login

效果如下:

image

目前安装的uview-plus,版本为3.6.4,使用HBuilderX运行是,会出现很多警告信息。

这是因为uview-plus 的 SFC 代码里大量用了隐式的 this 成员,在 uni-app x + TS 严格模式 下被识别为 never,于是直接拉进项目就会报 编译期类型警告,但 运行期功能正常

uview-plus 仓库已知晓 uni-app x 的 TS 严格模式问题,3.3.8 之后计划发版解决。

因此,那些警告信息可以忽略,不影响项目正常运行。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 12:14:18

Vue指令 (1)

控制元素的隐藏 v-show 1. 语法结构v-show"表达式" 表达式中结果为true隐藏&#xff1b;为false时显示 本质原理&#xff1a;通过切换css的display&#xff1a;none来控制隐藏&#xff0c;适合于频发切换显示隐藏的场景场景示例&#xff1a;鼠标悬停在小米官网中购物…

作者头像 李华
网站建设 2026/4/16 2:34:27

Unity 3D塔防游戏开发终极指南:从零到专业级项目实战

想要亲手打造一款令人惊艳的3D塔防游戏吗&#xff1f;这个完整的Unity教程项目将带你从基础概念到高级功能&#xff0c;全面掌握3D塔防游戏开发的核心技能。无论你是游戏开发新手还是希望提升Unity技能的开发者&#xff0c;这个项目都能为你提供实用的学习路径和可复用的代码架…

作者头像 李华
网站建设 2026/4/16 9:18:39

10分钟精通CopyQ脚本:零基础打造智能剪贴板系统

10分钟精通CopyQ脚本&#xff1a;零基础打造智能剪贴板系统 【免费下载链接】CopyQ hluk/CopyQ: CopyQ 是一个高级剪贴板管理器&#xff0c;具有强大的编辑和脚本功能&#xff0c;可以保存系统剪贴板的内容并在以后使用。 项目地址: https://gitcode.com/gh_mirrors/co/CopyQ…

作者头像 李华
网站建设 2026/4/11 9:52:50

Vue.js终极资源指南:从零到精通的完整清单

Vue.js终极资源指南&#xff1a;从零到精通的完整清单 【免费下载链接】awesome-vue &#x1f389; A curated list of awesome things related to Vue.js 项目地址: https://gitcode.com/gh_mirrors/awe/awesome-vue 想要快速掌握Vue.js开发技能&#xff1f;这份精心整…

作者头像 李华
网站建设 2026/4/16 9:18:35

JD-GUI:零基础掌握Java反编译核心技术 [特殊字符]

JD-GUI&#xff1a;零基础掌握Java反编译核心技术 &#x1f680; 【免费下载链接】jd-gui A standalone Java Decompiler GUI 项目地址: https://gitcode.com/gh_mirrors/jd/jd-gui 在Java开发的世界中&#xff0c;JD-GUI作为一款专业的Java反编译图形界面工具&#xff…

作者头像 李华
网站建设 2026/4/16 9:18:40

ArduinoFFT快速傅里叶变换库:将Arduino变成专业信号分析仪

ArduinoFFT快速傅里叶变换库&#xff1a;将Arduino变成专业信号分析仪 【免费下载链接】arduinoFFT Fast Fourier Transform for Arduino 项目地址: https://gitcode.com/gh_mirrors/ar/arduinoFFT 你是否想过&#xff0c;那个小小的Arduino开发板竟然能分析声音频率、检…

作者头像 李华