news 2026/6/23 10:15:55

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/6/23 13:38:12

3天掌握VAR模型:零基础搭建GPT式图像生成系统

3天掌握VAR模型&#xff1a;零基础搭建GPT式图像生成系统 【免费下载链接】VAR [GPT beats diffusion&#x1f525;] [scaling laws in visual generation&#x1f4c8;] Official impl. of "Visual Autoregressive Modeling: Scalable Image Generation via Next-Scale P…

作者头像 李华
网站建设 2026/6/23 17:08:29

Headless Recorder完整指南:从零掌握浏览器自动化脚本生成

还在为编写复杂的浏览器自动化测试脚本而烦恼吗&#xff1f;Headless Recorder 正是你需要的解决方案&#xff01;这款强大的 Chrome 扩展能够将你的浏览器操作实时转换为专业的 Playwright 或 Puppeteer 脚本&#xff0c;让自动化测试变得前所未有的简单高效。 【免费下载链接…

作者头像 李华
网站建设 2026/6/23 18:19:09

终极指南:如何用ConvNeXt实现高效语义分割(UperNet完整教程)

终极指南&#xff1a;如何用ConvNeXt实现高效语义分割&#xff08;UperNet完整教程&#xff09; 【免费下载链接】ConvNeXt Code release for ConvNeXt model 项目地址: https://gitcode.com/gh_mirrors/co/ConvNeXt 语义分割作为计算机视觉的核心技术&#xff0c;在自动…

作者头像 李华
网站建设 2026/6/23 18:17:42

包装设计创意大比拼,谁才是行业王者?

行业趋势解读&#xff1a;【包装设计】创意大比拼&#xff0c;谁在定义未来行业标准&#xff1f;引言 当“颜值经济”渗透至消费全链条&#xff0c;包装设计早已突破“容器”的物理属性&#xff0c;成为品牌与用户对话的第一触点。据2024年一项行业调研显示&#xff0c;超过65%…

作者头像 李华
网站建设 2026/6/23 15:14:53

项目分享|Tabby:打造你自己的智能代码补全服务

无需依赖云端服务&#xff0c;用消费级GPU即可部署的企业级GitHub Copilot替代方案 引言 在AI编程辅助工具日益普及的今天&#xff0c;GitHub Copilot已成为许多开发者的效率利器。然而&#xff0c;对于注重代码隐私、希望完全掌控内部数据的企业和团队而言&#xff0c;将代码…

作者头像 李华
网站建设 2026/6/23 16:14:44

终极音频解锁指南:3分钟掌握浏览器端音乐格式转换

终极音频解锁指南&#xff1a;3分钟掌握浏览器端音乐格式转换 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库&#xff1a; 1. https://github.com/unlock-music/unlock-music &#xff1b;2. https://git.unlock-music.dev/um/web 项目地址: https://g…

作者头像 李华