微信小程序中遇到过的问题

news2025/1/4 15:33:10

记录微信小程序中遇到的问题(持续更新ing)

  • 问题描述:
  • 1. WXML中无法直接调用JavaScript方法。
  • 2. css中无法直接引用背景图片。
  • 3. 关于右上角胶囊按钮。
  • 4. 数据绑定问题。
  • 5. 事件处理问题。
  • 6. 关于movable-view组件的问题
  • 7. 关于设置宽度后设置padding内容溢出的问题

问题描述:

1. WXML中无法直接调用JavaScript方法。

原因分析:
由于WXML和JavaScript是两种不同的语言,它们之间没有直接的交互方式。
解决方案:

  • 尽量在js中处理,并在WXML中显示。
  • 使用wxs,
    创建wxs文件并通过 module.exports导出
    //index.wxs文件
    var toFixed = function (num) {
      console.log(num);
      return num.toFixed(2);
    }
    module.exports = {
      toFixed: toFixed
    }
    //index.wxml文件
    <wxs src="./index.wxs" module="XXX"></wxs> //这样引用
    <view>{{XXX.toFixed(3.1415)}}</view>       //使用

返回的3.14
最后看打印结果
在这里插入图片描述
注意事项: wxs文件中不支持es6写法,let、const、export这些都是不可以的!

2. css中无法直接引用背景图片。

原因分析:
由于微信小程序的文件结构限制,CSS文件只能引用小程序的静态资源文件,如图片、字体等。
解决方案:

  • 路径改成可以直接访问的绝对路径。
background-image: url("https://pic.netbian.com/uploads/allimg/240308/012824-17098325042f18.jpg");
  • 将图片转换为base64编码。
  • 在标签上写入样式
 	<view  style="background-image: url('../xx.png')"></image>
  • 使用image标签并使用绝对定位
	<view class="box">
	 	<image class="box-bg" src="../bg.png" />
	</view>
	//css文件
	.box{
 		 position: relative;
 		 .box-bg{ 
   			 position: absolute;
		 } 
	}

3. 关于右上角胶囊按钮。

原因分析:
由于css样式调整,需要自定义顶部导航栏。
解决方案:
- 官方自带的不能去掉,但是通过设置backgroundTextStyle等来设置文字颜色与背景等。

  • 在微信小程序的app.json文件中,可以设置navigationStyle属性为custom,来自定义顶部导航栏
    在这里插入图片描述

4. 数据绑定问题。

原因分析:
习惯使用this.XXX = data 或者 XXX.value = data 或直接XXX = data导致赋值不上
解决方案:
正确使用this.setData()来更新数据

this.setData({
  XXX: 'Data'
})

5. 事件处理问题。

**原因分析:**
习惯使用`click、@click`来绑定事件,并通过 `@click = XXX(data)` 来传参

解决方案:
在小程序中事件绑定有使用特定的语法

  • 绑定事件使用bindtap、catchtap、bindinput
  • 在事件处理函数中,使用event参数获取事件对象。或者使用data-来传递参数。

6. 关于movable-view组件的问题

原因分析:
使用movable-view滑动不生效、 想去除页面切换时滑动的动画、设置定位right、bottom等不生效

解决方案:

  • 首先movable-view组件必须放在在 movable-area 组件中,并且必须是直接子节点,否则不能移动。
  • movable-area 组件必须设置width和height属性,不设置默认为10px,不能滑动。
  • 去除页面切换时滑动的动画可以在movable-view组件中设置 animation=“{{false}}”
  • movable-view 默认为绝对定位,top和left属性为0px ,设置定位right、bottom不生效要设置left与top才行,或者在movable-view组件中设置x={{x}}y={{y}}
  • movable-view 必须设置width和height属性,不设置默认为10px。

请添加图片描述
实现代码

  //wxml
  <movable-area class="card-box">
    <movable-view class="card-view" animation="{{false}}" x="{{x}}" y="{{y}}" direction="all">
    <image class="card-view" src="../../../public/card.png"></image>
    </movable-view>
  </movable-area>
  //css
  .card-box {
  position: absolute;
  top: 0;
  width: 100%;
  height: 90vh;
  .card-view {
    width: 64rpx;
    height: 64rpx;
    z-index: 999;
  }
} 
//js
  data: {
    x: 340,
    y: 700,  //这里根据wx.getSystemInfoSync这个方法获取设备信息去具体计算
  },

7. 关于设置宽度后设置padding内容溢出的问题

原因分析:
父组件中使用padding: 0 24rpx; 然后再使用width: 100%;导致页面元素内容溢出
在这里插入图片描述
解决方案:
因为 width: 100%; 是相对于父组件的宽度计算的,而父组件的 padding 会导致父组件的实际宽度大于其内容的宽度。

  • 父元素设置box-sizing: border-box;
  • 调整子组件的宽度width: calc(100% - 48rpx);
  • 去除width: 100%;
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2268865.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【C++】B2084 质因数分解

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af; 题目描述&#xff1a;质因数分解输入格式输出格式输入输出样例&#xff1a; &#x1f4af; 问题解析1. 质数的定义2. 题目特点3. 约束范围4. 问题分解 &#x1f4af; 解题…

Unity中列表List使用出类似字典Dictionary的感觉

首先为什么会有这个标题&#xff1f; 因为字典很好用&#xff0c;只需要键就能拿到值&#xff0c;这种感觉是真的爽&#xff0c;新手最喜欢用了&#xff0c;遇事不决就字典&#xff0c;但是也有不好的地方&#xff0c;字典的内存开销比列表List要大&#xff0c;遍历也是List占…

分布式项目___某污水处理项目

一.分布式项目___污水处理项目 项目地址:https://gitee.com/yanyigege/collaborative-water-springboot.git ​ 1.项目背景 总公司在全国各地有处理污水的项目部,各项目部处理自己的污水,总部需要监控各地分项目部每天处理污水的原料用量,掌握各分部的污水处理情况 ​ 2.功…

WebRTC:实现浏览器与移动应用的实时通信

1.技术简介 &#xff08;Web Real-Time&#xff09;是一种开放式实时通信技术&#xff0c;旨在使浏览器和移动应用程序通过简单的API即可实现实时音频、视频和数据传输&#xff0c;而无需安装插件或额外软件。它支持网络应用中的点对点通信&#xff0c;例如视频聊天、语音通话…

小程序基础 —— 07 创建小程序项目

创建小程序项目 打开微信开发者工具&#xff0c;左侧选择小程序&#xff0c;点击 号即可新建项目&#xff1a; 在弹出的新页面&#xff0c;填写项目信息&#xff08;后端服务选择不使用云服务&#xff0c;开发模式为小程序&#xff0c;模板选择为不使用模板&#xff09;&…

数据结构之线性表之链表(附加一个考研题)

链表的定义 链表的结构&#xff1a; 单链表-初始化 代码实现&#xff1a; 单链表-头插法 代码实现&#xff1a; 这里我给大家分析一下 我们每创建一个新的节点都要插在头节点的后面&#xff0c;我们一定要注意顺序 一定要先让新节点指向头节点指向的下一个节点&#xff0c;…

RocketMQ(二)RocketMQ实战

文章目录 一、RocketMQ实战1.1 批量消息发送1.2 消息发送队列自选择1.3 事务消息1.4 SpringCloud集成RocketMQ 二、最佳实践2.1 生产者2.1.1 发送消息注意事项2.1.2 消息发送失败处理方式 2.2 消费者2.2.1 消费过程幂等2.2.2 消费打印日志 2.3 Broker 三、相关问题3.1 为什么要…

Vue router router-link router-view keep-alive

Vue router router-link router-view keep-alive keep-alive 1. /:id 2 ?id

掌握 PostgreSQL 的 psql 命令行工具

title: 掌握 PostgreSQL 的 psql 命令行工具 date: 2024/12/30 updated: 2024/12/30 author: cmdragon excerpt: psql 是 PostgreSQL 关系数据库管理系统的交互式命令行工具,是数据库管理员和开发人员进行数据库管理和操作的主要接口。熟练使用 psql 工具,不仅能够提高对 …

【C++】深入理解 break 和 continue 语句

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;break 和 continue 介绍**break** 的作用**continue** 的作用注意事项 &#x1f4af;break 示例代码示例**执行结果****解析过程** &#x1f4af;continue 示例代码示例&am…

【C++】B2064 斐波那契数列

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目描述输入格式输出格式输入输出样例输入输出 &#x1f4af;思路分析**题目本质** &#x1f4af;代码实现与对比**我的代码实现**代码展示思路解析优点不足 **老师的代码…

在 Ubuntu 24.04.1 LTS | Python 3.12 环境下部署 Crypto 库

测试一些密码学方案需要用到 Crypto 库&#xff0c;网上教程大多针对 Windows 和 Python 3.10 或以下的环境&#xff0c;所以写下了这篇博文。 部署与使用 首先执行 su 输入密码进入超级用户&#xff0c;部署完 Python 3.12 环境后&#xff0c;执行以下命令进行安装&#xff…

【ArcGIS Pro/GeoScene Pro】可视化时态数据

可视化过去二十年新西兰国际旅游业的发展变化 工程数据下载 ArcGIS Pro 快速入门指南—ArcGIS Pro | 文档 添加数据 数据为中国旅客数据 转置表字段 列数据转行数据

Junit4单元测试快速上手

文章目录 POM依赖引入业务层测试代码Web层测试代码生成测试类文件 在工作中我用的最多的单元测试框架是Junit4。通常在写DAO、Service、Web层代码的时候都会进行单元测试&#xff0c;方便后续编码&#xff0c;前端甩锅。 POM依赖引入 <dependency><groupId>org.spr…

HTML——24.图片引入1

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title>图片的引入</title></head><body><!--网页中引入图片&#xff1a;使用img标签&#xff0c;<img src"图片路径"/>--><!--src属性…

云计算基础实验

云计算基础实验报告 实验一 Linux环境下算法的测试 一&#xff0c; 根据基本计算思想&#xff0c;验证和求解&#xff0c;设计算法。 根据运行需要&#xff0c;自行完成&#xff08;C和Python&#xff09;环境配置。 1.1验证卡布列克常数6174 原理过程&#xff1a; 循环输…

京东供应链创新与实践:应用数据驱动的库存选品和调拨算法提升履约效率

2024 年度总结系列 2024 年 10 月&#xff0c;京东零售供应链技术团队凭借其在库存选品与调拨技术上的创新与实践&#xff0c;荣获运筹与管理学领域的国际顶级奖项 Daniel H. Wagner Prize。本文为您介绍获奖背后的供应链技术创新和落地应用。 00 摘要 在电商行业中&#x…

按照人们阅读Excel习惯来格式化BigDecimal

1、环境/问题描述 使用springboot发送邮件(附件)的方式将月度报表发送给领导查阅&#xff0c;数据是准确的&#xff0c;领导基本满意。 就是对一些数字的格式化提出了改进建议&#xff0c;比如不要让大数字自动转为科学计数法、浮点数小数点后都是0就不要带出来&#xff0c;根…

软体机器人研究报告:设计方法、材料与驱动、感知与控制

软体机器人因其出色的可变形性和高适应性受到了广泛关注&#xff0c;这些特性使其在医疗、救援、探测等复杂场景中展现出独特的优势和巨大的应用潜力。研究人员对软体机器人的设计方法、材料与驱动技术、感知与控制策略等方面进行深入研究&#xff0c;取得了一系列成果。 本文汇…

医疗数仓业务数据采集与同步

业务数据采集与同步 业务采集组件配置业务数据同步概述数据同步策略选择数据同步工具概述1.1.4 全量表数据同步DataX配置文件生成全量表数据同步脚本增量表数据同步 MySQL - Maxwell - Kafka - Flume - HDFSMaxwell配置增量表首日全量同步 业务采集组件配置 Maxwell将业务采集到…