原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)

前段时间有给大家分享一个flutter3.x桌面端os系统。今天再分享一款最新原创之作uniapp-vue3-wechat聊天实例。

原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)

uni-vue3-wechat采用vue3 setup语法糖编码开发,支持编译到h5 小程序端 APP端

原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)

技术栈

  • 开发工具:HbuilderX 4.0.8
  • 技术框架:Uniapp Vue3 Pinia2 Vite4.x
  • UI组件库:uni-ui uv-ui
  • 弹框组件:uv3-popup(uniapp vue3多端自定义弹框组件)
  • 自定义组件:uv3-navbar uv3-tabbar组件
  • 缓存服务:pinia-plugin-unistorage
  • 编译支持:H5 小程序 APP端

原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)

项目结构

使用HbuilderX 4.0.8编辑器开发项目,支持编译到h5/小程序/App端。

原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)

/** * 入口文件 main.js*/import { createSSRApp } from 'vue'import App from './App'// 引入pinia状态管理import pinia from '@/pinia'export function createApp() { const app = createSSRApp(App) app.use(pinia) return { app, pinia }}

原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)

该项目已经同步到橱窗,如果有需要,欢迎去拍哈~

https://gf.bilibili.com/item/detail/1105801011

<script setup> import { provide } from 'vue' import { onLaunch, onShow, onHide, onPageNotFound } from '@dcloudio/uni-app' onLaunch(() => { console.log('App Launch') uni.hideTabBar() loadSystemInfo() }) onShow(() => { console.log('App Show') }) onHide(() => { console.log('App Hide') }) onPageNotFound((e) => { console.warn('Route Error:', `${e.path}`) }) // 获取系统设备信息 const loadSystemInfo = () => { uni.getSystemInfo({ success: (e) => { // 获取手机状态栏高度 let statusBar = e.statusBarHeight let customBar // #ifndef MP customBar = statusBar (e.platform == 'android' ? 50 : 45) // #endif // #ifdef MP-WEIXIN // 获取胶囊按钮的布局位置信息 let menu = wx.getMenuButtonBoundingClientRect() // 导航栏高度 = 胶囊下距离 胶囊上距离 - 状态栏高度 customBar = menu.bottom menu.top - statusBar // #endif // #ifdef MP-ALIPAY customBar = statusBar e.titleBarHeight // #endif // 由于globalData在vue3 setup存在兼容性问题,改为provide/inject替代方案 provide('globalData', { statusBarH: statusBar, customBarH: customBar, screenWidth: e.screenWidth, screenHeight: e.screenHeight, platform: e.platform }) } }) }</script><style> /* #ifndef APP-NVUE */ @import 'static/fonts/iconfont.css'; /* #endif */</style><style lang="scss"> @import 'styles/reset.scss'; @import 'styles/layout.scss';</style>

uni-vue3-chat布局结构

整体项目分为顶部导航 内容区 底部区三大模块。

原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)

<!-- 公共布局模板 --><!-- #ifdef MP-WEIXIN --><script> export default { /** * 解决小程序class、id透传问题 * manifest.json中配置mergeVirtualHostAttributes: true, 在微信小程序平台不生效,组件外部传入的class没有挂到组件根节点上,在组件中增加options: { virtualHost: true } * https://github.com/dcloudio/uni-ui/issues/753 */ options: { virtualHost: true } }</script><!-- #endif --><script setup> const props = defineProps({ // 是否显示自定义tabbar showTabBar: { type: [Boolean, String], default: false }, })</script><template> <view class="uv3__container flexbox flex-col flex1"> <!-- 顶部插槽 --> <slot name="header" /> <!-- 内容区 --> <view class="uv3__scrollview flex1"> <slot /> </view> <!-- 底部插槽 --> <slot name="footer" /> <!-- tabbar栏 --> <uv3-tabbar v-if="showTabBar" hideTabBar fixed /> </view></template>

原创新作uniapp+vue3+pinia2高仿微信App聊天(uniapp实战仿微信聊天)

<!-- 语音面板 --><view v-if="voicePanelEnable" class="uv3__voicepanel-popup"> <view class="uv3__voicepanel-body flexbox flex-col"> <!-- 取消发送 语音转文字 --> <view v-if="!voiceToTransfer" class="uv3__voicepanel-transfer"> <!-- 提示动效 --> <view class="animtips flexbox" :class="voiceType == 2 ? 'left' : voiceType == 3 ? 'right' : null"><Waves :lines="[2, 3].includes(voiceType) ? 10 : 20" /></view> <!-- 操作项 --> <view class="icobtns flexbox"> <view class="vbtn cancel flexbox flex-col" :class="{'hover': voiceType == 2}" @click="handleVoiceCancel"><text class="vicon uv3-icon uv3-icon-close"></text></view> <view class="vbtn word flexbox flex-col" :class="{'hover': voiceType == 3}"><text class="vicon uv3-icon uv3-icon-word"></text></view> </view> </view> <!-- 语音转文字(识别结果状态) --> <view v-if="voiceToTransfer" class="uv3__voicepanel-transfer result fail"> <!-- 提示动效 --> <view class="animtips flexbox"><uni-icons type="info-filled" color="#fff" size="20"></uni-icons><text class="c-fff">未识别到文字</text></view> <view class="icobtns flexbox"> <view class="vbtn cancel flexbox flex-col" @click="handleVoiceCancel"><text class="vicon uv3-icon uv3-icon-chexiao"></text>取消</view> <view class="vbtn word flexbox flex-col"><text class="vicon uv3-icon uv3-icon-audio"></text>发送原语音</view> <view class="vbtn check flexbox flex-col"><text class="vicon uv3-icon uv3-icon-duigou"></text></view> </view> </view> <!-- 背景语音图 --> <view class="uv3__voicepanel-cover"> <image v-if="!voiceToTransfer" src="/static/voice_bg.webp" :webp="true" mode="widthFix" style="width: 100%;" /> </view> <!-- // 提示文字 --> <view v-if="!voiceToTransfer" class="uv3__voicepanel-tooltip">{{voiceTypeMap[voiceType]}}</view> <!-- 背景图标 --> <view v-if="!voiceToTransfer" class="uv3__voicepanel-fixico"><text class="uv3-icon uv3-icon-audio fs-50"></text></view> </view></view>

由于该项目涉及到的知识点还是蛮多的,这次就先分享到这里,感谢大家的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年5月9日 下午12:25
下一篇 2024年5月9日 下午12:37

相关推荐

  • 教育部科研项目分类

    教育部科研项目分类 随着教育事业的发展,教育部越来越重视科研项目的分类和管理。为了更好地推进教育科学研究,教育部对科研项目进行了分类,并对研究人员进行了培训。本文将介绍教育部科研项…

    科研百科 2025年5月1日
    2
  • 做进度的软件

    做进度的软件 随着现代软件开发的不断推进,我们越来越需要一种能够方便、高效地管理项目进度的软件。而在这种情况下,做进度的软件应运而生。 做进度的软件可以大大提高软件开发的效率,因为…

    科研百科 2024年8月22日
    51
  • 我乐家居:必开智能软件南京有限公司是全资子公司

    金融界4月12日消息,有投资者在互动平台向我乐家居提问:请问必开智能软件南京有限公司是我乐子公司吗,请问我乐家居有没有自己的人工智能软件公司。 公司回答表示:必开智能软件南京有限公…

    科研百科 2024年5月9日
    93
  • 协同办公的系统设计有哪些(协同办公的系统设计)

    协同办公系统是一种用于组织和管理各种不同领域的工作的工具,包括电子邮件, 日历, 聊天和文件共享等。在现代商业环境中,协同办公系统已经成为了一种必不可少的工具,帮助团队更好地协作和…

    科研百科 2024年6月4日
    90
  • 南宁市第一人民医院神经外科党建

    南宁市第一人民医院神经外科党建 南宁市第一人民医院神经外科是南宁市一家综合性医院,作为神经外科的专业机构,其一直秉承“以患者为中心”的理念,致力于为患者提供优质的医疗服务。然而,作…

    科研百科 2024年11月22日
    0
  • 科研项目流程八个阶段(科研项目前后管理制度汇编)

    科研项目前后管理制度汇编 科研项目是现代科学发展的重要支撑,也是提高国家竞争力的重要手段。为了保障科研项目的顺利进行,制定一套完整的科研项目前后管理制度汇编是必要的。本汇编包括科研…

    科研百科 2024年4月6日
    729
  • 企业党纪学习总结

    企业党纪学习总结 企业党纪是企业管理层必须掌握的知识和技能,也是企业稳定、发展和可持续发展的基础。在当前激烈的市场竞争中,企业党纪的重要性更加凸显。因此,企业党纪学习是企业管理层必…

    科研百科 2024年10月21日
    0
  • 支部可以自己做公众号么

    支部可以自己做公众号吗? 随着数字化时代的到来,许多组织都在尝试利用社交媒体平台来推广其业务和信息。其中,微信公众号已成为许多支部的重要推广渠道之一。但是,对于没有微信公众平台账号…

    科研百科 2024年10月24日
    0
  • 生产型企业管理之质量管理详解(生产型企业管理之质量管理详解视频)

    质量管理是生产型企业管理的重要一环,但很多制造业虽深谙质量管理的重要性,却始终无法做好质量管理,究其原因,无非有以下几种: 1、质量管理系统不完善 没有认识到员工个人与系统环境相辅…

    科研百科 2022年7月31日
    204
  • 课题真实性查询方式

    课题真实性查询方式 随着科技的不断发展,课题真实性查询方式已经成为了科学研究中不可或缺的一部分。在科学研究中,我们需要通过一些技术手段来验证某个实验或者研究项目的真实性,以确保其研…

    科研百科 2024年10月11日
    25