UniApp-Vue3踩坑记录&心得体会

5 篇文章 0 订阅

踩坑记录

1. 图片路径动态渲染不显示问题;

解决方案:修改静态图片存放路径

1.1 定义图片map,用于对图片路径的统一储存与管理,例如

1.2 由于uni-app——小程序的编译性质,静态图片等资源文件需放在/public/static/images下(编写页面时使用,部署到生产环境时移除),同时还须在vite.config.ts文件的配置项加上publicDir: ‘public’:

开发时路径:

编译后路径:

引用路径:如上1.1图示。

2. 弹窗滑动下面文本跟着滑动的问题。

解决方案:弹窗显示时给下层盒子加上宽高固定样式

3. ios底部安全区域显示问题

解决方案:在入口文件App.vue编写组件穿透样式,复写其默认样式

4. 跳转路由之后pinia持久化不生效

解决方案:在入口文件App.vue里手动调用一次需要实例化的store

5. uni-swiper指示器样式修改不生效

解决方案:在入口文件App.vue里复写swiper对应的样式集

经过h5和小程序dom tree的对比,uni-app框架对swiper组件进行过样式的条件编译,所以在这里我们采取针对小程序样式单独复写的方法,达到修改指示器样式的目的。

心得体会

1. css相关

1.1 高斯模糊

  • filter

只能让它作用的背景变模糊,当有元素拖动到它下面时,不会模糊下面的元素。仅仅是当前背景变模糊。

  • backdrop-filer

这个属性可以让你为一个元素后面区域添加图形效果(如模糊或颜色偏移)。 因为它适用于元素背后的所有元素,为了看到效果,必须使元素或其背景至少部分透明。

1.2 状态驱动的动态CSS: v-bind的使用

很多时候我们需要动态渲染某些“选中”、“切换”、“不同状态”等样式或者需要计算才能得到的样式,这时候我们就可以使用Vue3的状态驱动的动态css——v-bind

  • 定义ref响应式对象

  • 定义css样式集,并将其与响应式的ref对象进行绑定

  • 在template对应的标签上引用该样式

效果:

2. 父子组件相关

2.1 父组件调用子组件属性方法:defineExpose 单文件组件 < script setup> | Vue.js

  • 定义子组件实例
  • 子组件暴露父组件需要引用的属性方法
  • 父组件调用子组件属性方法

父组件:

子组件:

2.2 组件传参高级用法,v-model | Vue.js

  • 定义子组件emit钩子

  • 触发update指令,更新父组件的值

  • 父组件使用v-model:指令接收

3. Vue3调试工具

在谷歌浏览器>扩展程序 里面添加https://chrome.google.com/webstore/detail/vuejs-devtools/ljjemllljcmogpfapbkkighbhhppjdbg?hl=en

  • 2
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值