Taro3+Vue3重构Mpvue小程序项目踩坑记

2023-11-29 00:28

本文主要是介绍Taro3+Vue3重构Mpvue小程序项目踩坑记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、Taro小程序编译时报错;

图片描述

  • 原因:页面中存在小程序识别不了的标签;如div
  • 解决方法:
      1. 将div标签替换成小程序可识别的标签;
      1. 安装Taro中提供的插件:@tarojs/plugin-html, 使其可被识别;
        插件安装教程参考Taro官网:https://taro-docs.jd.com/docs/use-h5

2、微信的page-container组件弹出时将页面滚动至顶部?

  • 原因:page-container组件弹出时,page标签会被添加上如下样式,导致页面会被滚动至顶部;
    在这里插入图片描述

  • 微信开放社区提供的解决方案可参考:https://developers.weixin.qq.com/community/develop/doc/000ca0ca3c496803b7db22fa85bc00?_at=1584495477343.;

  • 我在项目中的解决方案如下:弹出层子组件使用了nut-popup进行弹出,当父组件滚动时记录当前滚动的高度,给标签添加scroll-top属性;
    在这里插入图片描述

3、编译时提示如下错误;

  • 原因:在两个不同页面件中a.css和b.css样式文件引入先后的顺序不一致;具体原因可查看:https://laysent.com/til/2019-11-28_conflicting-order-in-mini-css-extract-plugin
    在这里插入图片描述
  • 解决方法:
    • 如果a.css和b.css文件有关联性,即b.css必须在a.css文件后引入,则在每个页面中统一CSS的引入顺序;
    • 在config/index.js文件中增加如下配置:忽略CSS引入的顺序检查;
      在这里插入图片描述

4、给本地this变量起别名时ts报错:在这里插入图片描述* 原因:eslint 为了防止this变量和局部变量混淆

  • 解决方法:在 .eslintrc.js中的rules添加 “@typescript-eslint/no-this-alias”: [“off”]

5、Taro3中不支持样式的scoped写法,容易出现页面间的样式污染,怎么解决?

  • 解决方法:
    • 1)修改冲突的选择器名称,使其不重复;
    • 2)使用CSS Modules管理每个业务页面的样式;
  • CSS Modules使用步骤:(参考Taro官网教程:https://taro-docs.jd.com/docs/css-modules)
    • 1)在配置文件中开启css modules的使用;
    • 2)修改css的文件名;页面的xxx.scss文件修改为xxx.module.scss;
    • 3)在js文件中引入xxx.module.scss文件;
    • 4)在.vue文件中使用styles.xxxx使用选择器;
    // config/index.js文件...mini: {cssModules: {enable: true, // 默认为 false,如需使用 css modules 功能,则设为 true}}...// xxx业务模块jsimport styles from './xxx.module.scss';setup() {return {styles}}

6、使用modules时父子组件样式的问题;

  • 问题描述:子组件有一个样式stylesChild.A,父组件调用子组件的时候需要复用子组件的样式,但是在父组件中子组件的父容器样式是stylesParent.xxxx;那么子组件自己的样式就复用不了了;
  • 解决方法:
    • 1)子组件定义className属性,父组件使用子组件时将类名传入,在子组件中复写传入的className样式;
      在这里插入图片描述
    • 2)css modules和普通class混用, 在父组件使用子组件时给子组件添加普通class,然后在父组件中定义普通class样式;
      在这里插入图片描述

7、购物车页面数量输入框聚焦时输入键盘向上顶起,页面会滚动一段距离,导致输入框的内容移位?

  • 解决方案参考:https://developers.weixin.qq.com/community/develop/article/doc/000a00e1fd0790488e6a034f156813

8、nutui实现各组件主题颜色定制;

  • 官网配置参考链接:https://nutui.jd.com/theme/#/base

9、border-radius在模拟器和安卓手机上显示正常,但是在IOS手机上不显示;

  • 解决方法参考:https://developers.weixin.qq.com/community/develop/doc/000a6c9dee8fc0866e3b9ed5651400

  • 在使用transform的元素的上一级元素上添加如下css样式:-webkit-transform: rotate(0deg);

10、小程序打包上传预览版时提示: xxxx无依赖文件;

  • xxxx.LICENSE.txt: 为xxxx文件的注释单独存放的文件,
  • terserWebpackPlugin.extractComments:是否将注释提取到单独的文件;设置打包时为false,不将注释提取到单独的文件中;
  // config/dev.js的文件内容...mini: {...chain.merge({plugin: {install: {plugin: require('terser-webpack-plugin'),args: [{terserOptions: {...},extractComments: false  // 不将注释提取到单独文件}]}}...})}

11、小程序项目引入crypto-js插件后,提示包体积过大?

  • 解决方案:
    • 1)将插件包降级为3.1.9-1,因为4.1.1版本包含了bower和node部分,
      官网问题描述参考:https://github.com/brix/crypto-js/issues/276
    • 2)使用时不要整包加载,要按需引入;
      不建议: let CryptoJS = require(‘crypto-js’)

12、扫描/识别二维码进入指定的小程序中某个页面是怎么实现的?

  • 1)根据vue-qr和qr-code插件在后台管理系统动态生成二维码,该二维码绑定的有一个普通链接;
  • 2)在小程序开发者后台:开发管理-开发设置-扫普通链接二维码打开小程序选项中配置二维码地址和小程序打开路径的对应关系;即可实现扫二维码跳转到指定小程序的页面;

这篇关于Taro3+Vue3重构Mpvue小程序项目踩坑记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/430777

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

EMLOG程序单页友链和标签增加美化

单页友联效果图: 标签页面效果图: 源码介绍 EMLOG单页友情链接和TAG标签,友链单页文件代码main{width: 58%;是设置宽度 自己把设置成与您的网站宽度一样,如果自适应就填写100%,TAG文件不用修改 安装方法:把Links.php和tag.php上传到网站根目录即可,访问 域名/Links.php、域名/tag.php 所有模板适用,代码就不粘贴出来,已经打