【UniApp开发小程序】项目创建+整合UI组件(FirstUI和uView)

创建项目

下图为初始化的项目的文件结构

引入组件

俗话说:"工欲善其事,必先利其器",为了更加方便地开发出页面较为美观的小程序,我们先引入成熟的UI组件,再开始开发之旅。(如果你是前端高手,也可以选择手写样式,冲!!!)

FirstUI

npm安装

首先动动小手打开终端

输入一下命令,安装组件到项目中

配置

在pages.json添加配置,添加了这段配置之后,无需在页面中引入组件,直接使用组件即可。

json 复制代码
"easycom": {
	"autoscan": true,
	"custom": {
		"fui-(.*)": "firstui-uni/firstui/fui-$1/fui-$1.vue"
	}
}

测试

组件生效,引入组件完成

html 复制代码
<fui-button style="width: 720rpx;margin-top: 10rpx;">你好</fui-button>
<fui-button type="success" style="width: 720rpx;margin-top: 10rpx;">你好</fui-button>
<fui-button type="warning" style="width: 720rpx;margin-top: 10rpx;">你好</fui-button>
<fui-button type="danger" style="width: 720rpx;margin-top: 10rpx;">你好</fui-button>
<fui-button type="purple" style="width: 720rpx;margin-top: 10rpx;">你好</fui-button>

引入之后,发现有的组件需要vip,所以我决定换一套UI组件(富哥请直接开通vip,哈哈)

uView

npm安装

复制代码
npm install uview-ui@2.0.36

uView依赖于SCSS,需要通过一下命令安装对sass(scss)的支持

复制代码
// 安装sass
npm i sass -D

// 安装sass-loader,注意需要版本10,否则可能会导致vue与sass的兼容问题而报错
npm i sass-loader@10 -D

配置

main.js中引入uView的JS库

js 复制代码
import uView from "uview-ui";
Vue.use(uView);

注意:这两行要放在import Vue之后

uni.scss中引入uview的scss文件

复制代码
@import 'uview-ui/theme.scss';

App.vue引入uView基础样式

css 复制代码
<style lang="scss">
	/* 注意要写在第一行,同时给style标签加入lang="scss"属性 */
	@import "uview-ui/index.scss";
</style>

pages.json中配置easycom组件模式

配置easycom之后,不需要在页面中import相应的组件,直接使用即可

json 复制代码
"easycom": {
	"^u-(.*)": "uview-ui/components/u-$1/u-$1.vue"
},

注意点

  • page.json中只能有一个easycom字段
  • 配置之后,需要重启项目才能生效

测试


组件引入成功,可以愉快地开始开发了

相关推荐
星栈独行20 小时前
写 Makepad Demo 不难,难的是把它写成项目
前端·程序人生·ui·rust
川石课堂软件测试20 小时前
UI自动化测试|下拉选择框&弹出框&滚动条操作实践
开发语言·python·jmeter·ui·docker·单元测试·harmonyos
狼哥168620 小时前
《新闻资讯》九、应用各分层模块实现指南
ui·华为·harmonyos
小羊Yveesss21 小时前
2026年个人能做微信小程序吗?
微信小程序·小程序
kidding72321 小时前
BMI 健康测量仪工具类小程序
前端·微信小程序·小程序
云迈科技-软件定制开发21 小时前
智慧物业小程序完整技术功能清单(业主端+管理后台+硬件联动|可直接落地)
小程序
console.log('npc')1 天前
AI前端工程与生成式UI学习路线
前端·人工智能·ui
梦曦i1 天前
uni-router v1.1.1发布:守卫超时保护+路由监听
前端·uni-app
梦曦i1 天前
全面解析uni-router v1.2.0功能
前端·uni-app